]> git.saurik.com Git - apple/libc.git/blob - gdtoa/FreeBSD/gdtoa-gethex.c.patch
Libc-594.1.4.tar.gz
[apple/libc.git] / gdtoa / FreeBSD / gdtoa-gethex.c.patch
1 --- gdtoa-gethex.c.orig 2008-10-28 11:14:40.000000000 -0700
2 +++ gdtoa-gethex.c 2008-10-28 11:20:32.000000000 -0700
3 @@ -29,6 +29,8 @@ THIS SOFTWARE.
4 /* Please send bug reports to David M. Gay (dmg at acm dot org,
5 * with " at " changed at "@" and " dot " changed to "."). */
6
7 +#include "xlocale_private.h"
8 +
9 #include "gdtoaimp.h"
10
11 #ifdef USE_LOCALE
12 @@ -37,10 +39,10 @@ THIS SOFTWARE.
13
14 int
15 #ifdef KR_headers
16 -gethex(sp, fpi, exp, bp, sign)
17 - CONST char **sp; FPI *fpi; Long *exp; Bigint **bp; int sign;
18 +gethex(sp, fpi, exp, bp, sign, loc)
19 + CONST char **sp; FPI *fpi; Long *exp; Bigint **bp; int sign; locale_t loc;
20 #else
21 -gethex( CONST char **sp, FPI *fpi, Long *exp, Bigint **bp, int sign)
22 +gethex( CONST char **sp, FPI *fpi, Long *exp, Bigint **bp, int sign, locale_t loc)
23 #endif
24 {
25 Bigint *b;
26 @@ -50,13 +52,14 @@ gethex( CONST char **sp, FPI *fpi, Long
27 Long e, e1;
28 #ifdef USE_LOCALE
29 int i;
30 + NORMALIZE_LOCALE(loc);
31 #ifdef NO_LOCALE_CACHE
32 - const unsigned char *decimalpoint = (unsigned char*)localeconv()->decimal_point;
33 + const unsigned char *decimalpoint = (unsigned char*)localeconv_l(loc)->decimal_point;
34 #else
35 const unsigned char *decimalpoint;
36 static unsigned char *decimalpoint_cache;
37 if (!(s0 = decimalpoint_cache)) {
38 - s0 = (unsigned char*)localeconv()->decimal_point;
39 + s0 = (unsigned char*)localeconv_l(loc)->decimal_point;
40 if ((decimalpoint_cache = (char*)malloc(strlen(s0) + 1))) {
41 strcpy(decimalpoint_cache, s0);
42 s0 = decimalpoint_cache;