Update NOTES.opensolaris with scheduling details
[kopensolaris-gnu/glibc.git] / stdlib / strtold.c
index f1bb2f1..da9f927 100644 (file)
@@ -1,41 +1,65 @@
-#include <math.h>
+/* Read decimal floating point numbers.
+   This file is part of the GNU C Library.
+   Copyright (C) 1995-2002,2003,2004,2006,2007 Free Software Foundation, Inc.
+   Contributed by Ulrich Drepper <drepper@gnu.org>, 1995.
+
+   The GNU C Library is free software; you can redistribute it and/or
+   modify it under the terms of the GNU Lesser General Public
+   License as published by the Free Software Foundation; either
+   version 2.1 of the License, or (at your option) any later version.
+
+   The GNU C Library is distributed in the hope that it will be useful,
+   but WITHOUT ANY WARRANTY; without even the implied warranty of
+   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+   Lesser General Public License for more details.
+
+   You should have received a copy of the GNU Lesser General Public
+   License along with the GNU C Library; if not, write to the Free
+   Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA
+   02111-1307 USA.  */
 
-#ifndef __NO_LONG_DOUBLE_MATH
 /* The actual implementation for all floating point sizes is in strtod.c.
-   These macros tell it to produce the `long double' version, `strtold'.  */
+   These macros tell it to produce the `float' version, `strtof'.  */
+
+#include <bits/wordsize.h>
+
+#ifdef __LONG_DOUBLE_MATH_OPTIONAL
+# include <wchar.h>
+# define NEW(x) NEW1(x)
+# define NEW1(x) __new_##x
+long double ____new_strtold_internal (const char *, char **, int);
+long double __new_strtold (const char *, char **);
+long double ____new_wcstold_internal (const wchar_t *, wchar_t **, int);
+long double __new_wcstold (const wchar_t *, wchar_t **);
+libc_hidden_proto (____new_strtold_internal)
+libc_hidden_proto (____new_wcstold_internal)
+libc_hidden_proto (__new_strtold)
+libc_hidden_proto (__new_wcstold)
+#else
+# define NEW(x) x
+#endif
+
+#define        FLOAT           long double
+#define        FLT             LDBL
+#ifdef USE_WIDE_CHAR
+# define STRTOF                NEW (wcstold)
+# define STRTOF_L      __wcstold_l
+#else
+# define STRTOF                NEW (strtold)
+# define STRTOF_L      __strtold_l
+#endif
+
+#include "strtod.c"
 
-# define FLOAT         long double
-# define FLT           LDBL
-# ifdef USE_IN_EXTENDED_LOCALE_MODEL
-#  define STRTOF       __strtold_l
+#ifdef __LONG_DOUBLE_MATH_OPTIONAL
+# include <math_ldbl_opt.h>
+# ifdef USE_WIDE_CHAR
+long_double_symbol (libc, __new_wcstold, wcstold);
+long_double_symbol (libc, ____new_wcstold_internal, __wcstold_internal);
+libc_hidden_ver (____new_wcstold_internal, __wcstold_internal)
 # else
-#  define STRTOF       strtold
+long_double_symbol (libc, __new_strtold, strtold);
+long_double_symbol (libc, ____new_strtold_internal, __strtold_internal);
+libc_hidden_ver (____new_strtold_internal, __strtold_internal)
 # endif
-# define MPN2FLOAT     __mpn_construct_long_double
-# define FLOAT_HUGE_VAL        HUGE_VALL
-# define SET_MANTISSA(flt, mant) \
-  do { union ieee854_long_double u;                                          \
-       u.d = (flt);                                                          \
-       if ((mant & 0x7fffffffffffffffULL) == 0)                                      \
-        mant = 0x4000000000000000ULL;                                        \
-       u.ieee.mantissa0 = (((mant) >> 32) & 0x7fffffff) | 0x80000000;        \
-       u.ieee.mantissa1 = (mant) & 0xffffffff;                               \
-       (flt) = u.d;                                                          \
-  } while (0)
-
-# include "strtod.c"
-#else
-# include <stdlib.h>
-/* There is no `long double' type, use the `double' implementations.  */
-long double
-__strtold_internal (const char *nptr, char **endptr, int group)
-{
-  return __strtod_internal (nptr, endptr, group);
-}
-
-long double
-strtold (const char *nptr, char **endptr)
-{
-  return __strtod_internal (nptr, endptr, 0);
-}
 #endif