strtoflt128.c 1.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051
  1. /* Copyright (C) 1999, 2004 Free Software Foundation, Inc.
  2. This file is part of the GNU C Library.
  3. The GNU C Library is free software; you can redistribute it and/or
  4. modify it under the terms of the GNU Lesser General Public
  5. License as published by the Free Software Foundation; either
  6. version 2.1 of the License, or (at your option) any later version.
  7. The GNU C Library is distributed in the hope that it will be useful,
  8. but WITHOUT ANY WARRANTY; without even the implied warranty of
  9. MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
  10. Lesser General Public License for more details.
  11. You should have received a copy of the GNU Lesser General Public
  12. License along with the GNU C Library; if not, write to the Free
  13. Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA
  14. 02111-1307 USA. */
  15. /* The actual implementation for all floating point sizes is in strtod.c.
  16. These macros tell it to produce the `__float128' version, `strtold'. */
  17. #define FLOAT __float128
  18. #define FLT FLT128
  19. #ifdef USE_WIDE_CHAR
  20. # define STRTOF wcstoflt128
  21. # define __STRTOF __wcstoflt128
  22. #else
  23. # define STRTOF strtoflt128
  24. # define __STRTOF __strtoflt128
  25. #endif
  26. #define MPN2FLOAT mpn_construct_float128
  27. #define FLOAT_HUGE_VAL HUGE_VALQ
  28. #define SET_MANTISSA(flt, mant) \
  29. do { ieee854_float128 u; \
  30. u.value = (flt); \
  31. u.ieee.mant_high = 0x800000000000ULL; \
  32. u.ieee.mant_low = mant; \
  33. (flt) = u.value; \
  34. } while (0)
  35. static inline __attribute__((__always_inline__))
  36. __float128 ____strtoflt128_internal (const char *, char **, int);
  37. #include "strtod_l.c"
  38. __float128
  39. strtoflt128 (const char *nptr, char **endptr)
  40. {
  41. return ____STRTOF_INTERNAL (nptr, endptr, 0);
  42. }