about summary refs log tree commit diff
diff options
context:
space:
mode:
-rw-r--r--ChangeLog4
-rw-r--r--stdio-common/_i18n_number.h9
2 files changed, 11 insertions, 2 deletions
diff --git a/ChangeLog b/ChangeLog
index 6cd6fb2733..074192afaf 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,7 @@
+2004-02-10  Ulrich Drepper  <drepper@redhat.com>
+
+	* stdio-common/_i18n_number.h: Finish last patch.
+
 2004-02-09  Ulrich Drepper  <drepper@redhat.com>
 
 	* sysdeps/i386/i686/memcmp.S: New file.  Patch by HJ Lu.
diff --git a/stdio-common/_i18n_number.h b/stdio-common/_i18n_number.h
index 0043b04470..f3404c5a0a 100644
--- a/stdio-common/_i18n_number.h
+++ b/stdio-common/_i18n_number.h
@@ -32,8 +32,8 @@ _i18n_number_rewrite (CHAR_T *w, CHAR_T *rear_ptr)
 # define decimal NULL
 # define thousands NULL
 #else
-# define wdecimal L'\0'
-# define wthousands L'\0'
+  wint_t wdecimal = L'\0';
+  wint_t wthousands = L'\0';
   char decimal[MB_LEN_MAX];
   char thousands[MB_LEN_MAX];
 #endif
@@ -44,6 +44,10 @@ _i18n_number_rewrite (CHAR_T *w, CHAR_T *rear_ptr)
   wctrans_t map = __wctrans ("to_outpunct");
   if (map != NULL)
     {
+      wdecimal = __towctrans (L'.', map);
+      wthousands = __towctrans (L',', map);
+
+#ifndef COMPILE_WPRINTF
       mbstate_t state;
       memset (&state, '\0', sizeof (state));
 
@@ -54,6 +58,7 @@ _i18n_number_rewrite (CHAR_T *w, CHAR_T *rear_ptr)
 
       if (__wcrtomb (thousands, wthousands, &state) == (size_t) -1)
 	memcpy (thousands, ",", 2);
+#endif
     }
 
   /* Copy existing string so that nothing gets overwritten.  */