about summary refs log tree commit diff
path: root/stdio/printf_fp.c
diff options
context:
space:
mode:
Diffstat (limited to 'stdio/printf_fp.c')
-rw-r--r--stdio/printf_fp.c17
1 files changed, 9 insertions, 8 deletions
diff --git a/stdio/printf_fp.c b/stdio/printf_fp.c
index ddf025721b..10018f01b8 100644
--- a/stdio/printf_fp.c
+++ b/stdio/printf_fp.c
@@ -32,7 +32,8 @@ Cambridge, MA 02139, USA.  */
 #include <gmp.h>
 #include <gmp-impl.h>
 #include <longlong.h>
-#include <localeinfo.h>
+#include "../locale/localeinfo.h"
+#include <limits.h>
 #include <math.h>
 #include <printf.h>
 #include <stdarg.h>
@@ -227,22 +228,22 @@ __printf_fp (fp, info, args)
 
 
   /* Figure out the decimal point character.  */
-  if (mbtowc (&decimal, _numeric_info->decimal_point,
-	      strlen (_numeric_info->decimal_point)) <= 0)
-    decimal = (wchar_t) *_numeric_info->decimal_point;
+  if (mbtowc (&decimal, _NL_CURRENT (LC_NUMERIC, DECIMAL_POINT),
+	      strlen (_NL_CURRENT (LC_NUMERIC, DECIMAL_POINT))) <= 0)
+    decimal = (wchar_t) *_NL_CURRENT (LC_NUMERIC, DECIMAL_POINT);
 
 
   if (info->group)
     {
-      grouping = _numeric_info->grouping; /* Cache the grouping info array.  */
+      grouping = _NL_CURRENT (LC_NUMERIC, GROUPING);
       if (*grouping <= 0 || *grouping == CHAR_MAX)
 	grouping = NULL;
       else
 	{
 	  /* Figure out the thousands seperator character.  */
-	  if (mbtowc (&thousands_sep, _numeric_info->thousands_sep,
-		      strlen (_numeric_info->thousands_sep)) <= 0)
-	    thousands_sep = (wchar_t) *_numeric_info->thousands_sep;
+	  if (mbtowc (&thousands_sep, _NL_CURRENT (LC_NUMERIC, THOUSANDS_SEP),
+		      strlen (_NL_CURRENT (LC_NUMERIC, THOUSANDS_SEP))) <= 0)
+	    thousands_sep = (wchar_t) *_NL_CURRENT (LC_NUMERIC, THOUSANDS_SEP);
 	  if (thousands_sep == L'\0')
 	    grouping = NULL;
 	}