diff options
author | Ulrich Drepper <drepper@redhat.com> | 1998-12-28 14:28:07 +0000 |
---|---|---|
committer | Ulrich Drepper <drepper@redhat.com> | 1998-12-28 14:28:07 +0000 |
commit | 76235ed48f5bc3ec639e886633fc45bede1c470b (patch) | |
tree | fea71a7be41602645e2139d0552bb2378a2069fe /wcsmbs/wcstold_l.c | |
parent | Update. (diff) | |
download | glibc-76235ed48f5bc3ec639e886633fc45bede1c470b.tar.gz glibc-76235ed48f5bc3ec639e886633fc45bede1c470b.tar.bz2 glibc-76235ed48f5bc3ec639e886633fc45bede1c470b.zip |
Update.
1998-12-28 Ulrich Drepper <drepper@cygnus.com>
* stdlib/fpioconst.c: If __NO_LONG_DOUBLE_MATH don't define constants
beyond range of double.
* stdlib/fpioconst.h (_fpioconst_pow10): Reduce size according to
fpioconst.c change.
* stdlib/strtold.c: Fall back on double functions if
__NO_LONG_DOUBLE_MATH.
* stdlib/strtold_l.c: Likewise.
* wcsmbs/wcstold.c: Likewise.
* wcsmbs/wcstold_l.c: Likewise.
* sysdeps/ieee754/ldbl2mpn.c: Don't generate code if
__NO_LONG_DOUBLE_MATH.
* sysdeps/ieee754/mpn2ldbl.c: Likewise.
1998-12-28 Geoff Keating <geoffk@ozemail.com.au>
* sysdeps/powerpc/bits/endian.h: Use #warning, not #error, if
the endianness can't be determined, for makedepend.
Diffstat (limited to 'wcsmbs/wcstold_l.c')
-rw-r--r-- | wcsmbs/wcstold_l.c | 22 |
1 files changed, 20 insertions, 2 deletions
diff --git a/wcsmbs/wcstold_l.c b/wcsmbs/wcstold_l.c index f92ec78026..8f6272561c 100644 --- a/wcsmbs/wcstold_l.c +++ b/wcsmbs/wcstold_l.c @@ -19,10 +19,13 @@ Boston, MA 02111-1307, USA. */ #define __need_wchar_t +#include <math.h> #include <stddef.h> #include <locale.h> -#define USE_IN_EXTENDED_LOCALE_MODEL 1 +#ifndef __NO_LONG_DOUBLE_MATH + +# define USE_IN_EXTENDED_LOCALE_MODEL 1 extern long double ____wcstold_l_internal (const wchar_t *, wchar_t **, int, __locale_t); @@ -30,4 +33,19 @@ extern unsigned long long int ____wcstoull_l_internal (const wchar_t *, wchar_t **, int, int, __locale_t); -#include <wcstold.c> +# include <wcstold.c> +#else +/* There is no `long double' type, use the `double' implementations. */ +long double +____wcstold_l_internal (const wchar_t *nptr, wchar_t **endptr, int group, + __locale_t loc) +{ + return ____wcstod_l_internal (nptr, endptr, group, loc); +} + +long double +__wcstold_l (const wchar_t *nptr, wchar_t **endptr, __locale_t loc) +{ + return __wcstod_internal (nptr, endptr, 0, loc); +} +#endif |