diff options
author | tjr <tjr@FreeBSD.org> | 2003-10-31 13:29:00 +0000 |
---|---|---|
committer | tjr <tjr@FreeBSD.org> | 2003-10-31 13:29:00 +0000 |
commit | 44278bfe73f956cea7b76d295f2ece178659f4f9 (patch) | |
tree | ec2a611770579a4bf72311eb29886037f4ae1701 /lib/libc/locale/wcstof.c | |
parent | cd4a9b77a6df92c6fce807de7c5bf3271dbcb55c (diff) | |
download | FreeBSD-src-44278bfe73f956cea7b76d295f2ece178659f4f9.zip FreeBSD-src-44278bfe73f956cea7b76d295f2ece178659f4f9.tar.gz |
Don't bother passing a freshly-zeroed mbstate to mbsrtowcs() etc.
when the current implementation won't use it, anyway. Just pass NULL.
This will need to be changed when state-dependent encodings are
supported, but there's no need to take the performance hit
in the meantime.
Diffstat (limited to 'lib/libc/locale/wcstof.c')
-rw-r--r-- | lib/libc/locale/wcstof.c | 28 |
1 files changed, 5 insertions, 23 deletions
diff --git a/lib/libc/locale/wcstof.c b/lib/libc/locale/wcstof.c index ebe392e..909db0b 100644 --- a/lib/libc/locale/wcstof.c +++ b/lib/libc/locale/wcstof.c @@ -37,46 +37,28 @@ __FBSDID("$FreeBSD$"); float wcstof(const wchar_t * __restrict nptr, wchar_t ** __restrict endptr) { - static const mbstate_t initial; - mbstate_t state; float val; - char *buf, *end, *p; + char *buf, *end; const wchar_t *wcp; - size_t clen, len; + size_t len; while (iswspace(*nptr)) nptr++; - state = initial; wcp = nptr; - if ((len = wcsrtombs(NULL, &wcp, 0, &state)) == (size_t)-1) { + if ((len = wcsrtombs(NULL, &wcp, 0, NULL)) == (size_t)-1) { if (endptr != NULL) *endptr = (wchar_t *)nptr; return (0.0); } if ((buf = malloc(len + 1)) == NULL) return (0.0); - state = initial; - wcsrtombs(buf, &wcp, len + 1, &state); + wcsrtombs(buf, &wcp, len + 1, NULL); val = strtof(buf, &end); - if (endptr != NULL) { -#if 1 /* Fast, assume 1:1 WC:MBS mapping. */ + if (endptr != NULL) *endptr = (wchar_t *)nptr + (end - buf); - (void)clen; - (void)p; -#else /* Slow, conservative approach. */ - state = initial; - *endptr = (wchar_t *)nptr; - p = buf; - while (p < end && - (clen = mbrlen(p, end - p, &state)) > 0) { - p += clen; - (*endptr)++; - } -#endif - } free(buf); |