summaryrefslogtreecommitdiff
path: root/stdio-common
diff options
context:
space:
mode:
Diffstat (limited to 'stdio-common')
-rw-r--r--stdio-common/_i18n_number.h14
1 files changed, 5 insertions, 9 deletions
diff --git a/stdio-common/_i18n_number.h b/stdio-common/_i18n_number.h
index f3404c5a0a..04d6619b4c 100644
--- a/stdio-common/_i18n_number.h
+++ b/stdio-common/_i18n_number.h
@@ -27,13 +27,9 @@ static CHAR_T *
_i18n_number_rewrite (CHAR_T *w, CHAR_T *rear_ptr)
{
#ifdef COMPILE_WPRINTF
- wint_t wdecimal = L'\0';
- wint_t wthousands = L'\0';
# define decimal NULL
# define thousands NULL
#else
- wint_t wdecimal = L'\0';
- wint_t wthousands = L'\0';
char decimal[MB_LEN_MAX];
char thousands[MB_LEN_MAX];
#endif
@@ -42,12 +38,12 @@ _i18n_number_rewrite (CHAR_T *w, CHAR_T *rear_ptr)
to their equivalent in locale. This is defined for locales which
use extra decimal point and thousands-sep. */
wctrans_t map = __wctrans ("to_outpunct");
- if (map != NULL)
- {
- wdecimal = __towctrans (L'.', map);
- wthousands = __towctrans (L',', map);
+ wint_t wdecimal = __towctrans (L'.', map);
+ wint_t wthousands = __towctrans (L',', map);
#ifndef COMPILE_WPRINTF
+ if (__builtin_expect (map != NULL, 0))
+ {
mbstate_t state;
memset (&state, '\0', sizeof (state));
@@ -58,8 +54,8 @@ _i18n_number_rewrite (CHAR_T *w, CHAR_T *rear_ptr)
if (__wcrtomb (thousands, wthousands, &state) == (size_t) -1)
memcpy (thousands, ",", 2);
-#endif
}
+#endif
/* Copy existing string so that nothing gets overwritten. */
CHAR_T *src = (CHAR_T *) alloca ((rear_ptr - w) * sizeof (CHAR_T));