diff options
Diffstat (limited to 'src/stdio')
| -rw-r--r-- | src/stdio/vfwscanf.c | 11 | 
1 files changed, 7 insertions, 4 deletions
| diff --git a/src/stdio/vfwscanf.c b/src/stdio/vfwscanf.c index 4426a129..92b7fa40 100644 --- a/src/stdio/vfwscanf.c +++ b/src/stdio/vfwscanf.c @@ -83,7 +83,7 @@ static int in_set(const wchar_t *set, int c)  #undef ungetwc  #define ungetwc(c,f) \ -	((f)->rend && (c)<128 ? *--(f)->rpos : ungetwc((c),(f))) +	((f)->rend && (c)<128U ? *--(f)->rpos : ungetwc((c),(f)))  #endif  int vfwscanf(FILE *f, const wchar_t *fmt, va_list ap) @@ -215,19 +215,22 @@ int vfwscanf(FILE *f, const wchar_t *fmt, va_list ap)  		case 's':  			s = dest; -			while (!iswspace(c=getwc(f)) && c!=EOF) { +			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--;  			} +			if (width) ungetwc(c, f);  			if (s) *s = 0;  			break;  		case 'S':  			wcs = dest; -			while (!iswspace(c=getwc(f)) && c!=EOF) -				pos++, *wcs++ = c; +			while (width && !iswspace(c=getwc(f)) && c!=EOF) +				width--, pos++, *wcs++ = c; +			if (width) ungetwc(c, f);  			if (wcs) *wcs = 0;  			break; | 
