提交 e039db27 编写于 作者: R Rich Felker

implement 'm' modifier for wide scanf variants

上级 16a1e036
...@@ -103,6 +103,7 @@ int vfwscanf(FILE *restrict f, const wchar_t *restrict fmt, va_list ap) ...@@ -103,6 +103,7 @@ int vfwscanf(FILE *restrict f, const wchar_t *restrict fmt, va_list ap)
static const char size_pfx[][3] = { "hh", "h", "", "l", "L", "ll" }; static const char size_pfx[][3] = { "hh", "h", "", "l", "L", "ll" };
char tmp[3*sizeof(int)+10]; char tmp[3*sizeof(int)+10];
const wchar_t *set; const wchar_t *set;
size_t i, k;
FLOCK(f); FLOCK(f);
...@@ -140,7 +141,7 @@ int vfwscanf(FILE *restrict f, const wchar_t *restrict fmt, va_list ap) ...@@ -140,7 +141,7 @@ int vfwscanf(FILE *restrict f, const wchar_t *restrict fmt, va_list ap)
} }
if (*p=='m') { if (*p=='m') {
alloc = 1; alloc = !!dest;
p++; p++;
} else { } else {
alloc = 0; alloc = 0;
...@@ -233,16 +234,39 @@ int vfwscanf(FILE *restrict f, const wchar_t *restrict fmt, va_list ap) ...@@ -233,16 +234,39 @@ int vfwscanf(FILE *restrict f, const wchar_t *restrict fmt, va_list ap)
if (width < 1) width = -1; if (width < 1) width = -1;
i = 0;
if (alloc) {
k = t=='c' ? width+1U : 31;
if (size == SIZE_l) {
wcs = malloc(k*sizeof(wchar_t));
if (!wcs) goto alloc_fail;
} else {
s = malloc(k);
if (!s) goto alloc_fail;
}
}
while (width) { while (width) {
if ((c=getwc(f))<0) break; if ((c=getwc(f))<0) break;
if (in_set(set, c) == invert) if (in_set(set, c) == invert)
break; break;
if (wcs) { if (wcs) {
*wcs++ = c; wcs[i++] = c;
if (alloc && i==k) {
k += k+1;
wchar_t *tmp = realloc(wcs, k*sizeof(wchar_t));
if (!tmp) goto alloc_fail;
wcs = tmp;
}
} else if (size != SIZE_l) { } else if (size != SIZE_l) {
int l = wctomb(s?s:tmp, c); int l = wctomb(s?s+i:tmp, c);
if (l<0) goto input_fail; if (l<0) goto input_fail;
if (s) s+=l; i += l;
if (alloc && i > k-4) {
k += k+1;
char *tmp = realloc(s, k);
if (!tmp) goto alloc_fail;
s = tmp;
}
} }
pos++; pos++;
width-=(width>0); width-=(width>0);
...@@ -253,8 +277,12 @@ int vfwscanf(FILE *restrict f, const wchar_t *restrict fmt, va_list ap) ...@@ -253,8 +277,12 @@ int vfwscanf(FILE *restrict f, const wchar_t *restrict fmt, va_list ap)
if (t == 'c' || !gotmatch) goto match_fail; if (t == 'c' || !gotmatch) goto match_fail;
} }
if (wcs) *wcs++ = 0; if (alloc) {
if (s) *s++ = 0; if (size == SIZE_l) *(wchar_t **)dest = wcs;
else *(char **)dest = s;
}
if (wcs) wcs[i] = 0;
if (s) s[i] = 0;
break; break;
case 'd': case 'i': case 'o': case 'u': case 'x': case 'd': case 'i': case 'o': case 'u': case 'x':
...@@ -279,10 +307,15 @@ int vfwscanf(FILE *restrict f, const wchar_t *restrict fmt, va_list ap) ...@@ -279,10 +307,15 @@ int vfwscanf(FILE *restrict f, const wchar_t *restrict fmt, va_list ap)
} }
if (0) { if (0) {
fmt_fail: fmt_fail:
alloc_fail:
input_fail: input_fail:
if (!matches) matches--; if (!matches) matches--;
}
match_fail: match_fail:
if (alloc) {
free(s);
free(wcs);
}
}
FUNLOCK(f); FUNLOCK(f);
return matches; return matches;
} }
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册