Use decimap_point from localeconv() instead of hardcoded '.'

Obtained from:	inspired by NetBSD strtod
This commit is contained in:
ache 2001-02-10 05:05:09 +00:00
parent 5e1021a55a
commit 4060fa06fa

View File

@ -134,6 +134,7 @@ static char sccsid[] = "@(#)strtod.c 8.1 (Berkeley) 6/4/93";
#define Bug(x) {fprintf(stderr, "%s\n", x); exit(1);} #define Bug(x) {fprintf(stderr, "%s\n", x); exit(1);}
#endif #endif
#include <locale.h>
#ifdef __cplusplus #ifdef __cplusplus
#include "malloc.h" #include "malloc.h"
#include "memory.h" #include "memory.h"
@ -1202,6 +1203,8 @@ strtod
long L; long L;
unsigned long y, z; unsigned long y, z;
Bigint *bb, *bb1, *bd, *bd0, *bs, *delta; Bigint *bb, *bb1, *bd, *bd0, *bs, *delta;
char decimal_point = localeconv()->decimal_point[0];
sign = nz0 = nz = 0; sign = nz0 = nz = 0;
rv = 0.; rv = 0.;
for (s = s00;;s++) switch(*s) { for (s = s00;;s++) switch(*s) {
@ -1235,7 +1238,7 @@ strtod
else if (nd < 16) else if (nd < 16)
z = 10*z + c - '0'; z = 10*z + c - '0';
nd0 = nd; nd0 = nd;
if (c == '.') { if ((char)c == decimal_point) {
c = *++s; c = *++s;
if (!nd) { if (!nd) {
for (; c == '0'; c = *++s) for (; c == '0'; c = *++s)