summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorRich Felker <dalias@aerifal.cx>2012-04-17 23:08:58 -0400
committerRich Felker <dalias@aerifal.cx>2012-04-17 23:08:58 -0400
commita12aa2918535fd370419bd24b50a33974091c5a7 (patch)
tree1a3f5c791708fcbd89f15248e57f8d24bff9004d
parent2dd5dc78d4502381e2933137ed525acf339cb383 (diff)
downloadmusl-a12aa2918535fd370419bd24b50a33974091c5a7.tar.gz
musl-a12aa2918535fd370419bd24b50a33974091c5a7.tar.bz2
musl-a12aa2918535fd370419bd24b50a33974091c5a7.tar.xz
musl-a12aa2918535fd370419bd24b50a33974091c5a7.zip
fix failure to distinguish input/match failure in wide %[ scanf
this also includes a related fix for vswscanf's read function, which was returning a spurious (uninitialized) character for empty strings.
-rw-r--r--src/stdio/vfwscanf.c4
-rw-r--r--src/stdio/vswscanf.c2
2 files changed, 4 insertions, 2 deletions
diff --git a/src/stdio/vfwscanf.c b/src/stdio/vfwscanf.c
index a52ba3a0..dbba8652 100644
--- a/src/stdio/vfwscanf.c
+++ b/src/stdio/vfwscanf.c
@@ -264,7 +264,9 @@ int vfwscanf(FILE *f, const wchar_t *fmt, va_list ap)
}
if (width) ungetwc(c, f);
- if (!gotmatch) goto match_fail;
+ if (!gotmatch)
+ if (c>=0) goto match_fail;
+ else goto input_fail;
if (*p==']') p++;
while (*p!=']') {
diff --git a/src/stdio/vswscanf.c b/src/stdio/vswscanf.c
index 4396d7df..4c39f806 100644
--- a/src/stdio/vswscanf.c
+++ b/src/stdio/vswscanf.c
@@ -17,7 +17,7 @@ static size_t wstring_read(FILE *f, unsigned char *buf, size_t len)
f->rend = f->buf + k;
f->cookie = (void *)src;
- if (!len) return 0;
+ if (!len || !k) return 0;
*buf = *f->rpos++;
return 1;