123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051 |
- /* Copyright (C) 1999, 2004 Free Software Foundation, Inc.
- This file is part of the GNU C Library.
- 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. */
- /* The actual implementation for all floating point sizes is in strtod.c.
- These macros tell it to produce the `__float128' version, `strtold'. */
- #define FLOAT __float128
- #define FLT FLT128
- #ifdef USE_WIDE_CHAR
- # define STRTOF wcstoflt128
- # define __STRTOF __wcstoflt128
- #else
- # define STRTOF strtoflt128
- # define __STRTOF __strtoflt128
- #endif
- #define MPN2FLOAT mpn_construct_float128
- #define FLOAT_HUGE_VAL HUGE_VALQ
- #define SET_MANTISSA(flt, mant) \
- do { ieee854_float128 u; \
- u.value = (flt); \
- u.ieee.mant_high = 0x800000000000ULL; \
- u.ieee.mant_low = mant; \
- (flt) = u.value; \
- } while (0)
- static inline __attribute__((__always_inline__))
- __float128 ____strtoflt128_internal (const char *, char **, int);
- #include "strtod_l.c"
- __float128
- strtoflt128 (const char *nptr, char **endptr)
- {
- return ____STRTOF_INTERNAL (nptr, endptr, 0);
- }
|