diff options
| author | Joseph Myers <joseph@codesourcery.com> | 2012-11-07 19:36:48 +0000 |
|---|---|---|
| committer | Joseph Myers <joseph@codesourcery.com> | 2012-11-07 19:36:48 +0000 |
| commit | 05bcf62afbfcf1a42ef2d8e80e0dba887d970781 (patch) | |
| tree | c83528edc34f837ad2ce15e54c890d25faf14ad7 /conform/data | |
| parent | 01f34a3bd8c087ca4be0bd24857e454c8d29f20b (diff) | |
| download | glibc-05bcf62afbfcf1a42ef2d8e80e0dba887d970781.tar.xz glibc-05bcf62afbfcf1a42ef2d8e80e0dba887d970781.zip | |
conformtest: Clean up / correct / expand C99 and C11 expectations.
Diffstat (limited to 'conform/data')
| -rw-r--r-- | conform/data/complex.h-data | 31 | ||||
| -rw-r--r-- | conform/data/inttypes.h-data | 288 | ||||
| -rw-r--r-- | conform/data/iso646.h-data | 2 | ||||
| -rw-r--r-- | conform/data/stdalign.h-data | 6 | ||||
| -rw-r--r-- | conform/data/stdbool.h-data | 10 | ||||
| -rw-r--r-- | conform/data/stdint.h-data | 107 | ||||
| -rw-r--r-- | conform/data/stdnoreturn.h-data | 3 | ||||
| -rw-r--r-- | conform/data/tgmath.h-data | 363 | ||||
| -rw-r--r-- | conform/data/uchar.h-data | 2 | ||||
| -rw-r--r-- | conform/data/wchar.h-data | 25 | ||||
| -rw-r--r-- | conform/data/wctype.h-data | 14 |
11 files changed, 302 insertions, 549 deletions
diff --git a/conform/data/complex.h-data b/conform/data/complex.h-data index 8abfb507b9..7de888f81b 100644 --- a/conform/data/complex.h-data +++ b/conform/data/complex.h-data @@ -79,4 +79,35 @@ macro-function {double complex} CMPLX (double, double) macro-function {float complex} CMPLXF (float, float) macro-function {long double complex} CMPLXL (long double, long double) # endif + +allow cerf +allow cerfc +allow cexp2 +allow cexpm1 +allow clog10 +allow clog1p +allow clog2 +allow clgamma +allow ctgamma + +allow cerff +allow cerfcf +allow cexp2f +allow cexpm1f +allow clog10f +allow clog1pf +allow clog2f +allow clgammaf +allow ctgammaf + +allow cerfl +allow cerfcl +allow cexp2l +allow cexpm1l +allow clog10l +allow clog1pl +allow clog2l +allow clgammal +allow ctgammal + #endif diff --git a/conform/data/inttypes.h-data b/conform/data/inttypes.h-data index 5ef54f6ebe..8c076dff88 100644 --- a/conform/data/inttypes.h-data +++ b/conform/data/inttypes.h-data @@ -1,14 +1,5 @@ #if !defined ISO && !defined POSIX && !defined XPG3 && !defined XPG4 && !defined UNIX98 -type int8_t -type int16_t -type int32_t -type int64_t -type uint8_t -type uint16_t -type uint32_t -type uint64_t -type intptr_t -type uintptr_t +#include "stdint.h-data" type imaxdiv_t element imaxdiv_t intmax_t rem @@ -21,125 +12,166 @@ function uintmax_t strtoumax (const char*, char**, int) function intmax_t wcstoimax (const __gwchar_t*, __gwchar_t**, int) function uintmax_t wcstoumax (const __gwchar_t*, __gwchar_t**, int) -allow PRI* -allow SCN* -allow *_t +macro PRId8 +macro PRIi8 +macro PRIo8 +macro PRIu8 +macro PRIx8 +macro PRIX8 +macro SCNd8 +macro SCNi8 +macro SCNo8 +macro SCNu8 +macro SCNx8 +macro PRIdLEAST8 +macro PRIiLEAST8 +macro PRIoLEAST8 +macro PRIuLEAST8 +macro PRIxLEAST8 +macro PRIXLEAST8 +macro SCNdLEAST8 +macro SCNiLEAST8 +macro SCNoLEAST8 +macro SCNuLEAST8 +macro SCNxLEAST8 +macro PRIdFAST8 +macro PRIiFAST8 +macro PRIoFAST8 +macro PRIuFAST8 +macro PRIxFAST8 +macro PRIXFAST8 +macro SCNdFAST8 +macro SCNiFAST8 +macro SCNoFAST8 +macro SCNuFAST8 +macro SCNxFAST8 + +macro PRId16 +macro PRIi16 +macro PRIo16 +macro PRIu16 +macro PRIx16 +macro PRIX16 +macro SCNd16 +macro SCNi16 +macro SCNo16 +macro SCNu16 +macro SCNx16 +macro PRIdLEAST16 +macro PRIiLEAST16 +macro PRIoLEAST16 +macro PRIuLEAST16 +macro PRIxLEAST16 +macro PRIXLEAST16 +macro SCNdLEAST16 +macro SCNiLEAST16 +macro SCNoLEAST16 +macro SCNuLEAST16 +macro SCNxLEAST16 +macro PRIdFAST16 +macro PRIiFAST16 +macro PRIoFAST16 +macro PRIuFAST16 +macro PRIxFAST16 +macro PRIXFAST16 +macro SCNdFAST16 +macro SCNiFAST16 +macro SCNoFAST16 +macro SCNuFAST16 +macro SCNxFAST16 + +macro PRId32 +macro PRIi32 +macro PRIo32 +macro PRIu32 +macro PRIx32 +macro PRIX32 +macro SCNd32 +macro SCNi32 +macro SCNo32 +macro SCNu32 +macro SCNx32 +macro PRIdLEAST32 +macro PRIiLEAST32 +macro PRIoLEAST32 +macro PRIuLEAST32 +macro PRIxLEAST32 +macro PRIXLEAST32 +macro SCNdLEAST32 +macro SCNiLEAST32 +macro SCNoLEAST32 +macro SCNuLEAST32 +macro SCNxLEAST32 +macro PRIdFAST32 +macro PRIiFAST32 +macro PRIoFAST32 +macro PRIuFAST32 +macro PRIxFAST32 +macro PRIXFAST32 +macro SCNdFAST32 +macro SCNiFAST32 +macro SCNoFAST32 +macro SCNuFAST32 +macro SCNxFAST32 + +macro PRId64 +macro PRIi64 +macro PRIo64 +macro PRIu64 +macro PRIx64 +macro PRIX64 +macro SCNd64 +macro SCNi64 +macro SCNo64 +macro SCNu64 +macro SCNx64 +macro PRIdLEAST64 +macro PRIiLEAST64 +macro PRIoLEAST64 +macro PRIuLEAST64 +macro PRIxLEAST64 +macro PRIXLEAST64 +macro SCNdLEAST64 +macro SCNiLEAST64 +macro SCNoLEAST64 +macro SCNuLEAST64 +macro SCNxLEAST64 +macro PRIdFAST64 +macro PRIiFAST64 +macro PRIoFAST64 +macro PRIuFAST64 +macro PRIxFAST64 +macro PRIXFAST64 +macro SCNdFAST64 +macro SCNiFAST64 +macro SCNoFAST64 +macro SCNuFAST64 +macro SCNxFAST64 + +macro PRIdMAX +macro PRIiMAX +macro PRIoMAX +macro PRIuMAX +macro PRIxMAX +macro PRIXMAX +macro SCNdMAX +macro SCNiMAX +macro SCNoMAX +macro SCNuMAX +macro SCNxMAX + +macro PRIdPTR +macro PRIiPTR +macro PRIoPTR +macro PRIuPTR +macro PRIxPTR +macro PRIXPTR +macro SCNdPTR +macro SCNiPTR +macro SCNoPTR +macro SCNuPTR +macro SCNxPTR -// Now the content of <stdint.h>. Update this whenever <stdint.h> changed. -type int8_t -type int16_t -type int32_t -type int64_t -type uint8_t -type uint16_t -type uint32_t -type uint64_t - -type int_least8_t -type int_least16_t -type int_least32_t -type int_least64_t -type uint_least8_t -type uint_least16_t -type uint_least32_t -type uint_least64_t - -type int_fast8_t -type int_fast16_t -type int_fast32_t -type int_fast64_t -type uint_fast8_t -type uint_fast16_t -type uint_fast32_t -type uint_fast64_t - -type intptr_t -type uintptr_t - -type intmax_t -type uintmax_t - -constant INT8_MIN == -128 -constant INT8_MAX == 127 -constant INT16_MIN == -32768 -constant INT16_MAX == 32767 -constant INT32_MIN == -2147483647-1 -constant INT32_MAX == 2147483647 -constant INT64_MIN == -9223372036854775807LL-1 -constant INT64_MAX == 9223372036854775807LL - -constant UINT8_MAX == 255 -constant UINT16_MAX == 65535 -constant UINT32_MAX == 4294967295U -constant UINT64_MAX == 18446744073709551615ULL - -constant INT_LEAST8_MIN <= -128 -constant INT_LEAST8_MAX >= 127 -constant INT_LEAST16_MIN <= -32768 -constant INT_LEAST16_MAX >= 32767 -constant INT_LEAST32_MIN <= -2147483647-1 -constant INT_LEAST32_MAX >= 2147483647 -constant INT_LEAST64_MIN <= -9223372036854775807LL-1 -constant INT_LEAST64_MAX >= 9223372036854775807LL - -constant UINT_LEAST8_MAX >= 255 -constant UINT_LEAST16_MAX >= 65535 -constant UINT_LEAST32_MAX >= 4294967295U -constant UINT_LEAST64_MAX >= 18446744073709551615ULL - -constant INT_FAST8_MIN <= -128 -constant INT_FAST8_MAX >= 127 -constant INT_FAST16_MIN <= -32768 -constant INT_FAST16_MAX >= 32767 -constant INT_FAST32_MIN <= -2147483647-1 -constant INT_FAST32_MAX >= 2147483647 -constant INT_FAST64_MIN <= -9223372036854775807LL-1 -constant INT_FAST64_MAX >= 9223372036854775807LL - -constant UINT_FAST8_MAX >= 255 -constant UINT_FAST16_MAX >= 65535 -constant UINT_FAST32_MAX >= 4294967295U -constant UINT_FAST64_MAX >= 18446744073709551615ULL - -constant INTPTR_MIN <= -32768 -constant INTPTR_MAX >= 32767 - -constant UINTPTR_MAX >= 65535 - -constant INTMAX_MIN <= -9223372036854775807LL-1 -constant INTMAX_MAX >= 9223372036854775807LL - -constant UINTMAX_MAX >= 18446744073709551615ULL - -constant PTRDIFF_MIN <= -65535 -constant PTRDIFF_MAX >= 65535 - -constant SIG_ATOMIC_MIN <= -127 -constant SIG_ATOMIC_MAX >= 127 - -constant SIZE_MAX >= 65535 - -constant WCHAR_MIN <= -127 -constant WCHAR_MAX >= 127 - -constant WINT_MIN <= -127 -constant WINT_MAX >= 127 - -macro INT8_C -macro INT16_C -macro INT32_C -macro INT64_C -macro UINT8_C -macro UINT16_C -macro UINT32_C -macro UINT64_C -macro INTMAX_C -macro UINTMAX_C - -// The following expressions are not entirely correct but the current -// poorfnmatch implementation doesn't grok the right form. -allow INT* -allow UINT* allow PRI[Xa-z]* allow SCN[Xa-z]* #endif diff --git a/conform/data/iso646.h-data b/conform/data/iso646.h-data index 7ac7d09abb..d4afaa5795 100644 --- a/conform/data/iso646.h-data +++ b/conform/data/iso646.h-data @@ -11,5 +11,7 @@ macro or_eq macro xor macro xor_eq +#if !defined ISO && !defined ISO99 && !defined ISO11 allow *_t #endif +#endif diff --git a/conform/data/stdalign.h-data b/conform/data/stdalign.h-data new file mode 100644 index 0000000000..edc2310e98 --- /dev/null +++ b/conform/data/stdalign.h-data @@ -0,0 +1,6 @@ +#if defined ISO11 +macro alignas +macro alignof +macro-int-constant __alignas_is_defined {int} == 1 +macro-int-constant __alignof_is_defined {int} == 1 +#endif diff --git a/conform/data/stdbool.h-data b/conform/data/stdbool.h-data new file mode 100644 index 0000000000..9ef218c5e2 --- /dev/null +++ b/conform/data/stdbool.h-data @@ -0,0 +1,10 @@ +#if !defined ISO && !defined POSIX && !defined XPG3 && !defined XPG4 && !defined UNIX98 +macro bool +macro-int-constant true {int} == 1 +macro-int-constant false {int} == 0 +macro-int-constant __bool_true_false_are_defined {int} == 1 + +#if !defined ISO && !defined ISO99 && !defined ISO11 +allow *_t +#endif +#endif diff --git a/conform/data/stdint.h-data b/conform/data/stdint.h-data index 99bdf22ac6..f6689513cc 100644 --- a/conform/data/stdint.h-data +++ b/conform/data/stdint.h-data @@ -1,4 +1,5 @@ #if !defined ISO && !defined POSIX && !defined XPG3 && !defined XPG4 && !defined UNIX98 +// The requirements for some types and corresponding macros are from POSIX. type int8_t type int16_t type int32_t @@ -32,71 +33,71 @@ type uintptr_t type intmax_t type uintmax_t -constant INT8_MIN == -128 -constant INT8_MAX == 127 -constant INT16_MIN == -32768 -constant INT16_MAX == 32767 -constant INT32_MIN == -2147483647-1 -constant INT32_MAX == 2147483647 -constant INT64_MIN == -9223372036854775807LL-1 -constant INT64_MAX == 9223372036854775807LL +macro-int-constant INT8_MIN {promoted:int8_t} == -128 +macro-int-constant INT8_MAX {promoted:int8_t} == 127 +macro-int-constant INT16_MIN {promoted:int16_t} == -32768 +macro-int-constant INT16_MAX {promoted:int16_t} == 32767 +macro-int-constant INT32_MIN {promoted:int32_t} == -2147483647-1 +macro-int-constant INT32_MAX {promoted:int32_t} == 2147483647 +macro-int-constant INT64_MIN {promoted:int64_t} == -9223372036854775807LL-1 +macro-int-constant INT64_MAX {promoted:int64_t} == 9223372036854775807LL -constant UINT8_MAX == 255 -constant UINT16_MAX == 65535 -constant UINT32_MAX == 4294967295U -constant UINT64_MAX == 18446744073709551615ULL +macro-int-constant UINT8_MAX {promoted:uint8_t} == 255 +macro-int-constant UINT16_MAX {promoted:uint16_t} == 65535 +macro-int-constant UINT32_MAX {promoted:uint32_t} == 4294967295U +macro-int-constant UINT64_MAX {promoted:uint64_t} == 18446744073709551615ULL -constant INT_LEAST8_MIN <= -128 -constant INT_LEAST8_MAX >= 127 -constant INT_LEAST16_MIN <= -32768 -constant INT_LEAST16_MAX >= 32767 -constant INT_LEAST32_MIN <= -2147483647-1 -constant INT_LEAST32_MAX >= 2147483647 -constant INT_LEAST64_MIN <= -9223372036854775807LL-1 -constant INT_LEAST64_MAX >= 9223372036854775807LL +macro-int-constant INT_LEAST8_MIN {promoted:int_least8_t} <= -128 +macro-int-constant INT_LEAST8_MAX {promoted:int_least8_t} >= 127 +macro-int-constant INT_LEAST16_MIN {promoted:int_least16_t} <= -32768 +macro-int-constant INT_LEAST16_MAX {promoted:int_least16_t} >= 32767 +macro-int-constant INT_LEAST32_MIN {promoted:int_least32_t} <= -2147483647-1 +macro-int-constant INT_LEAST32_MAX {promoted:int_least32_t} >= 2147483647 +macro-int-constant INT_LEAST64_MIN {promoted:int_least64_t} <= -9223372036854775807LL-1 +macro-int-constant INT_LEAST64_MAX {promoted:int_least64_t} >= 9223372036854775807LL -constant UINT_LEAST8_MAX >= 255 -constant UINT_LEAST16_MAX >= 65535 -constant UINT_LEAST32_MAX >= 4294967295U -constant UINT_LEAST64_MAX >= 18446744073709551615ULL +macro-int-constant UINT_LEAST8_MAX {promoted:uint_least8_t} >= 255 +macro-int-constant UINT_LEAST16_MAX {promoted:uint_least16_t} >= 65535 +macro-int-constant UINT_LEAST32_MAX {promoted:uint_least32_t} >= 4294967295U +macro-int-constant UINT_LEAST64_MAX {promoted:uint_least64_t} >= 18446744073709551615ULL -constant INT_FAST8_MIN <= -128 -constant INT_FAST8_MAX >= 127 -constant INT_FAST16_MIN <= -32768 -constant INT_FAST16_MAX >= 32767 -constant INT_FAST32_MIN <= -2147483647-1 -constant INT_FAST32_MAX >= 2147483647 -constant INT_FAST64_MIN <= -9223372036854775807LL-1 -constant INT_FAST64_MAX >= 9223372036854775807LL +macro-int-constant INT_FAST8_MIN {promoted:int_fast8_t} <= -128 +macro-int-constant INT_FAST8_MAX {promoted:int_fast8_t} >= 127 +macro-int-constant INT_FAST16_MIN {promoted:int_fast16_t} <= -32768 +macro-int-constant INT_FAST16_MAX {promoted:int_fast16_t} >= 32767 +macro-int-constant INT_FAST32_MIN {promoted:int_fast32_t} <= -2147483647-1 +macro-int-constant INT_FAST32_MAX {promoted:int_fast32_t} >= 2147483647 +macro-int-constant INT_FAST64_MIN {promoted:int_fast64_t} <= -9223372036854775807LL-1 +macro-int-constant INT_FAST64_MAX {promoted:int_fast64_t} >= 9223372036854775807LL -constant UINT_FAST8_MAX >= 255 -constant UINT_FAST16_MAX >= 65535 -constant UINT_FAST32_MAX >= 4294967295U -constant UINT_FAST64_MAX >= 18446744073709551615ULL +macro-int-constant UINT_FAST8_MAX {promoted:uint_fast8_t} >= 255 +macro-int-constant UINT_FAST16_MAX {promoted:uint_fast16_t} >= 65535 +macro-int-constant UINT_FAST32_MAX {promoted:uint_fast32_t} >= 4294967295U +macro-int-constant UINT_FAST64_MAX {promoted:uint_fast64_t} >= 18446744073709551615ULL -constant INTPTR_MIN <= -32768 -constant INTPTR_MAX >= 32767 +macro-int-constant INTPTR_MIN {promoted:intptr_t} <= -32768 +macro-int-constant INTPTR_MAX {promoted:intptr_t} >= 32767 -constant UINTPTR_MAX >= 65535 +macro-int-constant UINTPTR_MAX {promoted:uintptr_t} >= 65535 -constant INTMAX_MIN <= -9223372036854775807LL-1 -constant INTMAX_MAX >= 9223372036854775807LL +macro-int-constant INTMAX_MIN {promoted:intmax_t} <= -9223372036854775807LL-1 +macro-int-constant INTMAX_MAX {promoted:intmax_t} >= 9223372036854775807LL -constant UINTMAX_MAX >= 18446744073709551615ULL +macro-int-constant UINTMAX_MAX {promoted:uintmax_t} >= 18446744073709551615ULL -constant PTRDIFF_MIN <= -65535 -constant PTRDIFF_MAX >= 65535 +macro-int-constant PTRDIFF_MIN {promoted:__PTRDIFF_TYPE__} <= -65535 +macro-int-constant PTRDIFF_MAX {promoted:__PTRDIFF_TYPE__} >= 65535 -constant SIG_ATOMIC_MIN <= -127 -constant SIG_ATOMIC_MAX >= 127 +macro-int-constant SIG_ATOMIC_MIN {promoted:__SIG_ATOMIC_TYPE__} +macro-int-constant SIG_ATOMIC_MAX {promoted:__SIG_ATOMIC_TYPE__} >= 127 -constant SIZE_MAX >= 65535 +macro-int-constant SIZE_MAX {promoted:__SIZE_TYPE__} >= 65535 -constant WCHAR_MIN <= -127 -constant WCHAR_MAX >= 127 +macro-int-constant WCHAR_MIN {promoted:__WCHAR_TYPE__} +macro-int-constant WCHAR_MAX {promoted:__WCHAR_TYPE__} >= 127 -constant WINT_MIN <= -127 -constant WINT_MAX >= 127 +macro-int-constant WINT_MIN {promoted:__WINT_TYPE__} +macro-int-constant WINT_MAX {promoted:__WINT_TYPE__} >= 127 macro INT8_C macro INT16_C @@ -110,7 +111,9 @@ macro INTMAX_C macro UINTMAX_C // The following expressions are not entirely correct but the current -// fnamtch implementation doesn't grok the right form. +// poorfnmatch implementation doesn't grok the right forms (INT*_MAX, +// INT*_MIN, INT*_C, UINT*_MAX, UINT*_MIN, UINT*_C, int*_t, uint*_t). allow INT* allow UINT* +allow *_t #endif diff --git a/conform/data/stdnoreturn.h-data b/conform/data/stdnoreturn.h-data new file mode 100644 index 0000000000..77b9a589d8 --- /dev/null +++ b/conform/data/stdnoreturn.h-data @@ -0,0 +1,3 @@ +#if defined ISO11 +macro noreturn +#endif diff --git a/conform/data/tgmath.h-data b/conform/data/tgmath.h-data index ce4f301de9..5f72502191 100644 --- a/conform/data/tgmath.h-data +++ b/conform/data/tgmath.h-data @@ -1,364 +1,7 @@ -#if defined XOPEN2K || defined POSIX2008 -// <math.h> -macro fpclassify -macro isfinite -macro isinf -macro isnan -macro isnormal -macro signbit -macro isgreater -macro isgreaterequal -macro isless -macro islessequal -macro islessgreater -macro isunordered +#if !defined ISO && !defined POSIX && !defined XPG3 && !defined XPG4 && !defined UNIX98 +#include "math.h-data" +#include "complex.h-data" -#ifndef POSIX2008 -constant M_E -constant M_LOG2E -constant M_LOG10E -constant M_LN2 -constant M_LN10 -constant M_PI -constant M_PI_2 -constant M_PI_4 -constant M_1_PI -constant M_2_PI -constant M_2_SQRTPI -constant M_SQRT2 -constant M_SQRT1_2 - -constant MAXFLOAT -#endif -constant HUGE_VAL -constant HUGE_VALF -constant HUGE_VALL -constant INFINITY -constant NAN - -macro FP_INFINITE -macro FP_NAN -macro FP_NORMAL -macro FP_SUBNORMAL -macro FP_ZERO - -optional-macro FP_FAST_FMA -optional-macro FP_FAST_FMAF -optional-macro FP_FAST_FMAL - -constant FP_ILOGB0 -constant FP_ILOGBNAN - -macro MATH_ERRNO == 1 -macro MATH_ERREXCEPT == 2 - -macro math_errhandling - -function double acos (double) -function double asin (double) -function double atan (double) -function double atan2 (double, double) -function double ceil (double) -function double copysign (double, double) -function double cos (double) -function double cosh (double) -function double exp (double) -function double exp2 (double) -function double fabs (double) -function double floor (double) -function double fmod (double, double) -function double frexp (double, int*) -function double ldexp (double, int) -function double log (double) -function double log10 (double) -function double log2 (double) -function double modf (double, double*) -function double pow (double, double) -function double sin (double) -function double sinh (double) -function double sqrt (double) -function double tan (double) -function double tanh (double) -function double erf (double) -function double erfc (double) -#if defined XPG3 || defined XPG4 || defined UNIX98 -function double gamma (double) -#endif -function double hypot (double, double) -#if !defined POSIX && !defined POSIX2008 -function double j0 (double) -function double j1 (double) -function double jn (int, double) -#endif -function double lgamma (double) -function double tgamma (double) -#if !defined POSIX && !defined POSIX2008 -function double y0 (double) -function double y1 (double) -function double yn (int, double) -#endif -function double acosh (double) -function double asinh (double) -function double atanh (double) -function double cbrt (double) -function double expm1 (double) -function int ilogb (double) -function double log1p (double) -function double logb (double) -function double nextafter (double, double) -function double nexttoward (double, long double) -function double nearbyint (double) -function double remainder (double, double) -function double rint (double) -function double round (double) -function double trunc (double) -function long lrint (double) -function {long long} llrint (double) -function long lround (double) -function {long long} llround (double) -function double remquo (double, double, int*) -#if defined XPG3 && defined XPG4 && defined UNIX98 && defined XOPEN2K -function double scalb (double, double) -#endif -function double scalbn (double, int) -function double scalbln (double, long) -function double fdim (double, double) -function double fmax (double, double) -function double fmin (double, double) -function double fma (double, double, double) -function double nan (const char*) - -// variable signgam -allow signgam - -function f |
