fix broken %s and %[ with no width specifier in wide scanf
authorRich Felker <dalias@aerifal.cx>
Wed, 18 Apr 2012 02:15:33 +0000 (22:15 -0400)
committerRich Felker <dalias@aerifal.cx>
Wed, 18 Apr 2012 02:15:33 +0000 (22:15 -0400)
src/stdio/vfwscanf.c

index beb8e8fb9049f81a2755602c2bdee20c3056fc0a..a52ba3a07099bc5bb003f63c0ccbd1bb0dd4b840 100644 (file)
@@ -214,13 +214,14 @@ int vfwscanf(FILE *f, const wchar_t *fmt, va_list ap)
                        break;
 
                case 's':
+                       if (width < 1) width = -1;
                        s = dest;
                        while (width && !iswspace(c=getwc(f)) && c!=EOF) {
                                int l = wctomb(s?s:tmp, c);
                                if (l<0) goto input_fail;
                                if (s) s+=l;
                                pos++;
-                               width--;
+                               width-=(width>0);
                        }
                        if (width) ungetwc(c, f);
                        if (s) *s = 0;
@@ -228,8 +229,9 @@ int vfwscanf(FILE *f, const wchar_t *fmt, va_list ap)
 
                case 'S':
                        wcs = dest;
+                       if (width < 1) width = -1;
                        while (width && !iswspace(c=getwc(f)) && c!=EOF)
-                               width--, pos++, *wcs++ = c;
+                               width-=(width>0), pos++, *wcs++ = c;
                        if (width) ungetwc(c, f);
                        if (wcs) *wcs = 0;
                        break;
@@ -243,6 +245,8 @@ int vfwscanf(FILE *f, const wchar_t *fmt, va_list ap)
 
                        int gotmatch = 0;
 
+                       if (width < 1) width = -1;
+
                        while (width) {
                                if ((c=getwc(f))<0) break;
                                if (in_set(p, c) == invert)
@@ -255,7 +259,7 @@ int vfwscanf(FILE *f, const wchar_t *fmt, va_list ap)
                                        if (s) s+=l;
                                }
                                pos++;
-                               width--;
+                               width-=(width>0);
                                gotmatch=1;
                        }
                        if (width) ungetwc(c, f);