New module 'tanf'.
[gnulib.git] / lib / math.in.h
1 /* A GNU-like <math.h>.
2
3    Copyright (C) 2002-2003, 2007-2011 Free Software Foundation, Inc.
4
5    This program is free software: you can redistribute it and/or modify
6    it under the terms of the GNU General Public License as published by
7    the Free Software Foundation; either version 3 of the License, or
8    (at your option) any later version.
9
10    This program is distributed in the hope that it will be useful,
11    but WITHOUT ANY WARRANTY; without even the implied warranty of
12    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
13    GNU General Public License for more details.
14
15    You should have received a copy of the GNU General Public License
16    along with this program.  If not, see <http://www.gnu.org/licenses/>.  */
17
18 #ifndef _@GUARD_PREFIX@_MATH_H
19
20 #if __GNUC__ >= 3
21 @PRAGMA_SYSTEM_HEADER@
22 #endif
23 @PRAGMA_COLUMNS@
24
25 /* The include_next requires a split double-inclusion guard.  */
26 #@INCLUDE_NEXT_AS_FIRST_DIRECTIVE@ @NEXT_AS_FIRST_DIRECTIVE_MATH_H@
27
28 #ifndef _@GUARD_PREFIX@_MATH_H
29 #define _@GUARD_PREFIX@_MATH_H
30
31
32 /* The definitions of _GL_FUNCDECL_RPL etc. are copied here.  */
33
34 /* The definition of _GL_ARG_NONNULL is copied here.  */
35
36 /* The definition of _GL_WARN_ON_USE is copied here.  */
37
38 /* Helper macros to define a portability warning for the
39    classification macro FUNC called with VALUE.  POSIX declares the
40    classification macros with an argument of real-floating (that is,
41    one of float, double, or long double).  */
42 #define _GL_WARN_REAL_FLOATING_DECL(func) \
43 static inline int                                                   \
44 rpl_ ## func ## f (float f)                                         \
45 {                                                                   \
46   return func (f);                                                  \
47 }                                                                   \
48 static inline int                                                   \
49 rpl_ ## func ## d (double d)                                        \
50 {                                                                   \
51   return func (d);                                                  \
52 }                                                                   \
53 static inline int                                                   \
54 rpl_ ## func ## l (long double l)                                   \
55 {                                                                   \
56   return func (l);                                                  \
57 }                                                                   \
58 _GL_WARN_ON_USE (rpl_ ## func ## f, #func " is unportable - "       \
59                  "use gnulib module " #func " for portability");    \
60 _GL_WARN_ON_USE (rpl_ ## func ## d, #func " is unportable - "       \
61                  "use gnulib module " #func " for portability");    \
62 _GL_WARN_ON_USE (rpl_ ## func ## l, #func " is unportable - "       \
63                  "use gnulib module " #func " for portability")
64 #define _GL_WARN_REAL_FLOATING_IMPL(func, value) \
65   (sizeof (value) == sizeof (float) ? rpl_ ## func ## f (value)     \
66    : sizeof (value) == sizeof (double) ? rpl_ ## func ## d (value)  \
67    : rpl_ ## func ## l (value))
68
69
70 #if @REPLACE_ITOLD@
71 /* Pull in a function that fixes the 'int' to 'long double' conversion
72    of glibc 2.7.  */
73 _GL_EXTERN_C void _Qp_itoq (long double *, int);
74 static void (*_gl_math_fix_itold) (long double *, int) = _Qp_itoq;
75 #endif
76
77
78 /* POSIX allows platforms that don't support NAN.  But all major
79    machines in the past 15 years have supported something close to
80    IEEE NaN, so we define this unconditionally.  We also must define
81    it on platforms like Solaris 10, where NAN is present but defined
82    as a function pointer rather than a floating point constant.  */
83 #if !defined NAN || @REPLACE_NAN@
84 # if !GNULIB_defined_NAN
85 #  undef NAN
86   /* The Compaq (ex-DEC) C 6.4 compiler and the Microsoft MSVC 9 compiler
87      choke on the expression 0.0 / 0.0.  */
88 #  if defined __DECC || defined _MSC_VER
89 static float
90 _NaN ()
91 {
92   static float zero = 0.0f;
93   return zero / zero;
94 }
95 #   define NAN (_NaN())
96 #  else
97 #   define NAN (0.0f / 0.0f)
98 #  endif
99 #  define GNULIB_defined_NAN 1
100 # endif
101 #endif
102
103 /* Solaris 10 defines HUGE_VAL, but as a function pointer rather
104    than a floating point constant.  */
105 #if @REPLACE_HUGE_VAL@
106 # undef HUGE_VAL
107 # define HUGE_VAL (1.0 / 0.0)
108 #endif
109
110
111 #if @GNULIB_ACOSL@
112 # if !@HAVE_ACOSL@ || !@HAVE_DECL_ACOSL@
113 _GL_FUNCDECL_SYS (acosl, long double, (long double x));
114 # endif
115 _GL_CXXALIAS_SYS (acosl, long double, (long double x));
116 _GL_CXXALIASWARN (acosl);
117 #elif defined GNULIB_POSIXCHECK
118 # undef acosl
119 # if HAVE_RAW_DECL_ACOSL
120 _GL_WARN_ON_USE (acosl, "acosl is unportable - "
121                  "use gnulib module mathl for portability");
122 # endif
123 #endif
124
125
126 #if @GNULIB_ASINL@
127 # if !@HAVE_ASINL@ || !@HAVE_DECL_ASINL@
128 _GL_FUNCDECL_SYS (asinl, long double, (long double x));
129 # endif
130 _GL_CXXALIAS_SYS (asinl, long double, (long double x));
131 _GL_CXXALIASWARN (asinl);
132 #elif defined GNULIB_POSIXCHECK
133 # undef asinl
134 # if HAVE_RAW_DECL_ASINL
135 _GL_WARN_ON_USE (asinl, "asinl is unportable - "
136                  "use gnulib module mathl for portability");
137 # endif
138 #endif
139
140
141 #if @GNULIB_ATANL@
142 # if !@HAVE_ATANL@ || !@HAVE_DECL_ATANL@
143 _GL_FUNCDECL_SYS (atanl, long double, (long double x));
144 # endif
145 _GL_CXXALIAS_SYS (atanl, long double, (long double x));
146 _GL_CXXALIASWARN (atanl);
147 #elif defined GNULIB_POSIXCHECK
148 # undef atanl
149 # if HAVE_RAW_DECL_ATANL
150 _GL_WARN_ON_USE (atanl, "atanl is unportable - "
151                  "use gnulib module mathl for portability");
152 # endif
153 #endif
154
155
156 #if @GNULIB_CEILF@
157 # if @REPLACE_CEILF@
158 #  if !(defined __cplusplus && defined GNULIB_NAMESPACE)
159 #   undef ceilf
160 #   define ceilf rpl_ceilf
161 #  endif
162 _GL_FUNCDECL_RPL (ceilf, float, (float x));
163 _GL_CXXALIAS_RPL (ceilf, float, (float x));
164 # else
165 #  if !@HAVE_DECL_CEILF@
166 _GL_FUNCDECL_SYS (ceilf, float, (float x));
167 #  endif
168 _GL_CXXALIAS_SYS (ceilf, float, (float x));
169 # endif
170 _GL_CXXALIASWARN (ceilf);
171 #elif defined GNULIB_POSIXCHECK
172 # undef ceilf
173 # if HAVE_RAW_DECL_CEILF
174 _GL_WARN_ON_USE (ceilf, "ceilf is unportable - "
175                  "use gnulib module ceilf for portability");
176 # endif
177 #endif
178
179 #if @GNULIB_CEIL@
180 # if @REPLACE_CEIL@
181 #  if !(defined __cplusplus && defined GNULIB_NAMESPACE)
182 #   define ceil rpl_ceil
183 #  endif
184 _GL_FUNCDECL_RPL (ceil, double, (double x));
185 _GL_CXXALIAS_RPL (ceil, double, (double x));
186 # else
187 _GL_CXXALIAS_SYS (ceil, double, (double x));
188 # endif
189 _GL_CXXALIASWARN (ceil);
190 #endif
191
192 #if @GNULIB_CEILL@
193 # if @REPLACE_CEILL@
194 #  if !(defined __cplusplus && defined GNULIB_NAMESPACE)
195 #   undef ceill
196 #   define ceill rpl_ceill
197 #  endif
198 _GL_FUNCDECL_RPL (ceill, long double, (long double x));
199 _GL_CXXALIAS_RPL (ceill, long double, (long double x));
200 # else
201 #  if !@HAVE_DECL_CEILL@
202 _GL_FUNCDECL_SYS (ceill, long double, (long double x));
203 #  endif
204 _GL_CXXALIAS_SYS (ceill, long double, (long double x));
205 # endif
206 _GL_CXXALIASWARN (ceill);
207 #elif defined GNULIB_POSIXCHECK
208 # undef ceill
209 # if HAVE_RAW_DECL_CEILL
210 _GL_WARN_ON_USE (ceill, "ceill is unportable - "
211                  "use gnulib module ceill for portability");
212 # endif
213 #endif
214
215
216 #if @GNULIB_COSF@
217 # if !@HAVE_COSF@
218 #  undef cosf
219 _GL_FUNCDECL_SYS (cosf, float, (float x));
220 # endif
221 _GL_CXXALIAS_SYS (cosf, float, (float x));
222 _GL_CXXALIASWARN (cosf);
223 #elif defined GNULIB_POSIXCHECK
224 # undef cosf
225 # if HAVE_RAW_DECL_COSF
226 _GL_WARN_ON_USE (cosf, "cosf is unportable - "
227                  "use gnulib module cosf for portability");
228 # endif
229 #endif
230
231 #if @GNULIB_COSL@
232 # if !@HAVE_COSL@ || !@HAVE_DECL_COSL@
233 _GL_FUNCDECL_SYS (cosl, long double, (long double x));
234 # endif
235 _GL_CXXALIAS_SYS (cosl, long double, (long double x));
236 _GL_CXXALIASWARN (cosl);
237 #elif defined GNULIB_POSIXCHECK
238 # undef cosl
239 # if HAVE_RAW_DECL_COSL
240 _GL_WARN_ON_USE (cosl, "cosl is unportable - "
241                  "use gnulib module mathl for portability");
242 # endif
243 #endif
244
245
246 #if @GNULIB_EXPF@
247 # if !@HAVE_EXPF@
248 #  undef expf
249 _GL_FUNCDECL_SYS (expf, float, (float x));
250 # endif
251 _GL_CXXALIAS_SYS (expf, float, (float x));
252 _GL_CXXALIASWARN (expf);
253 #elif defined GNULIB_POSIXCHECK
254 # undef expf
255 # if HAVE_RAW_DECL_EXPF
256 _GL_WARN_ON_USE (expf, "expf is unportable - "
257                  "use gnulib module expf for portability");
258 # endif
259 #endif
260
261 #if @GNULIB_EXPL@
262 # if !@HAVE_EXPL@ || !@HAVE_DECL_EXPL@
263 _GL_FUNCDECL_SYS (expl, long double, (long double x));
264 # endif
265 _GL_CXXALIAS_SYS (expl, long double, (long double x));
266 _GL_CXXALIASWARN (expl);
267 #elif defined GNULIB_POSIXCHECK
268 # undef expl
269 # if HAVE_RAW_DECL_EXPL
270 _GL_WARN_ON_USE (expl, "expl is unportable - "
271                  "use gnulib module mathl for portability");
272 # endif
273 #endif
274
275
276 #if @GNULIB_FABSF@
277 # if !@HAVE_FABSF@
278 #  undef fabsf
279 _GL_FUNCDECL_SYS (fabsf, float, (float x));
280 # endif
281 _GL_CXXALIAS_SYS (fabsf, float, (float x));
282 _GL_CXXALIASWARN (fabsf);
283 #elif defined GNULIB_POSIXCHECK
284 # undef fabsf
285 # if HAVE_RAW_DECL_FABSF
286 _GL_WARN_ON_USE (fabsf, "fabsf is unportable - "
287                  "use gnulib module fabsf for portability");
288 # endif
289 #endif
290
291
292 #if @GNULIB_FLOORF@
293 # if @REPLACE_FLOORF@
294 #  if !(defined __cplusplus && defined GNULIB_NAMESPACE)
295 #   undef floorf
296 #   define floorf rpl_floorf
297 #  endif
298 _GL_FUNCDECL_RPL (floorf, float, (float x));
299 _GL_CXXALIAS_RPL (floorf, float, (float x));
300 # else
301 #  if !@HAVE_DECL_FLOORF@
302 _GL_FUNCDECL_SYS (floorf, float, (float x));
303 #  endif
304 _GL_CXXALIAS_SYS (floorf, float, (float x));
305 # endif
306 _GL_CXXALIASWARN (floorf);
307 #elif defined GNULIB_POSIXCHECK
308 # undef floorf
309 # if HAVE_RAW_DECL_FLOORF
310 _GL_WARN_ON_USE (floorf, "floorf is unportable - "
311                  "use gnulib module floorf for portability");
312 # endif
313 #endif
314
315 #if @GNULIB_FLOOR@
316 # if @REPLACE_FLOOR@
317 #  if !(defined __cplusplus && defined GNULIB_NAMESPACE)
318 #   define floor rpl_floor
319 #  endif
320 _GL_FUNCDECL_RPL (floor, double, (double x));
321 _GL_CXXALIAS_RPL (floor, double, (double x));
322 # else
323 _GL_CXXALIAS_SYS (floor, double, (double x));
324 # endif
325 _GL_CXXALIASWARN (floor);
326 #endif
327
328 #if @GNULIB_FLOORL@
329 # if @REPLACE_FLOORL@
330 #  if !(defined __cplusplus && defined GNULIB_NAMESPACE)
331 #   undef floorl
332 #   define floorl rpl_floorl
333 #  endif
334 _GL_FUNCDECL_RPL (floorl, long double, (long double x));
335 _GL_CXXALIAS_RPL (floorl, long double, (long double x));
336 # else
337 #  if !@HAVE_DECL_FLOORL@
338 _GL_FUNCDECL_SYS (floorl, long double, (long double x));
339 #  endif
340 _GL_CXXALIAS_SYS (floorl, long double, (long double x));
341 # endif
342 _GL_CXXALIASWARN (floorl);
343 #elif defined GNULIB_POSIXCHECK
344 # undef floorl
345 # if HAVE_RAW_DECL_FLOORL
346 _GL_WARN_ON_USE (floorl, "floorl is unportable - "
347                  "use gnulib module floorl for portability");
348 # endif
349 #endif
350
351
352 #if @GNULIB_FMODF@
353 # if !@HAVE_FMODF@
354 #  undef fmodf
355 _GL_FUNCDECL_SYS (fmodf, float, (float x, float y));
356 # endif
357 _GL_CXXALIAS_SYS (fmodf, float, (float x, float y));
358 _GL_CXXALIASWARN (fmodf);
359 #elif defined GNULIB_POSIXCHECK
360 # undef fmodf
361 # if HAVE_RAW_DECL_FMODF
362 _GL_WARN_ON_USE (fmodf, "fmodf is unportable - "
363                  "use gnulib module fmodf for portability");
364 # endif
365 #endif
366
367
368 /* Write x as
369      x = mantissa * 2^exp
370    where
371      If x finite and nonzero: 0.5 <= |mantissa| < 1.0.
372      If x is zero: mantissa = x, exp = 0.
373      If x is infinite or NaN: mantissa = x, exp unspecified.
374    Store exp in *EXPPTR and return mantissa.  */
375 #if @GNULIB_FREXPF@
376 # if @REPLACE_FREXPF@
377 #  if !(defined __cplusplus && defined GNULIB_NAMESPACE)
378 #   undef frexpf
379 #   define frexpf rpl_frexpf
380 #  endif
381 _GL_FUNCDECL_RPL (frexpf, float, (float x, int *expptr) _GL_ARG_NONNULL ((2)));
382 _GL_CXXALIAS_RPL (frexpf, float, (float x, int *expptr));
383 # else
384 #  if !@HAVE_FREXPF@
385 #   undef frexpf
386 _GL_FUNCDECL_SYS (frexpf, float, (float x, int *expptr) _GL_ARG_NONNULL ((2)));
387 #  endif
388 _GL_CXXALIAS_SYS (frexpf, float, (float x, int *expptr));
389 # endif
390 _GL_CXXALIASWARN (frexpf);
391 #elif defined GNULIB_POSIXCHECK
392 # undef frexpf
393 # if HAVE_RAW_DECL_FREXPF
394 _GL_WARN_ON_USE (frexpf, "frexpf is unportable - "
395                  "use gnulib module frexpf for portability");
396 # endif
397 #endif
398
399 /* Write x as
400      x = mantissa * 2^exp
401    where
402      If x finite and nonzero: 0.5 <= |mantissa| < 1.0.
403      If x is zero: mantissa = x, exp = 0.
404      If x is infinite or NaN: mantissa = x, exp unspecified.
405    Store exp in *EXPPTR and return mantissa.  */
406 #if @GNULIB_FREXP@
407 # if @REPLACE_FREXP@
408 #  if !(defined __cplusplus && defined GNULIB_NAMESPACE)
409 #   define frexp rpl_frexp
410 #  endif
411 _GL_FUNCDECL_RPL (frexp, double, (double x, int *expptr) _GL_ARG_NONNULL ((2)));
412 _GL_CXXALIAS_RPL (frexp, double, (double x, int *expptr));
413 # else
414 _GL_CXXALIAS_SYS (frexp, double, (double x, int *expptr));
415 # endif
416 _GL_CXXALIASWARN (frexp);
417 #elif defined GNULIB_POSIXCHECK
418 # undef frexp
419 /* Assume frexp is always declared.  */
420 _GL_WARN_ON_USE (frexp, "frexp is unportable - "
421                  "use gnulib module frexp for portability");
422 #endif
423
424 /* Write x as
425      x = mantissa * 2^exp
426    where
427      If x finite and nonzero: 0.5 <= |mantissa| < 1.0.
428      If x is zero: mantissa = x, exp = 0.
429      If x is infinite or NaN: mantissa = x, exp unspecified.
430    Store exp in *EXPPTR and return mantissa.  */
431 #if @GNULIB_FREXPL@ && @REPLACE_FREXPL@
432 # if !(defined __cplusplus && defined GNULIB_NAMESPACE)
433 #  undef frexpl
434 #  define frexpl rpl_frexpl
435 # endif
436 _GL_FUNCDECL_RPL (frexpl, long double,
437                   (long double x, int *expptr) _GL_ARG_NONNULL ((2)));
438 _GL_CXXALIAS_RPL (frexpl, long double, (long double x, int *expptr));
439 #else
440 # if !@HAVE_DECL_FREXPL@
441 _GL_FUNCDECL_SYS (frexpl, long double,
442                   (long double x, int *expptr) _GL_ARG_NONNULL ((2)));
443 # endif
444 # if @GNULIB_FREXPL@
445 _GL_CXXALIAS_SYS (frexpl, long double, (long double x, int *expptr));
446 # endif
447 #endif
448 #if @GNULIB_FREXPL@ && !(@REPLACE_FREXPL@ && !@HAVE_DECL_FREXPL@)
449 _GL_CXXALIASWARN (frexpl);
450 #endif
451 #if !@GNULIB_FREXPL@ && defined GNULIB_POSIXCHECK
452 # undef frexpl
453 # if HAVE_RAW_DECL_FREXPL
454 _GL_WARN_ON_USE (frexpl, "frexpl is unportable - "
455                  "use gnulib module frexpl for portability");
456 # endif
457 #endif
458
459
460 /* Return x * 2^exp.  */
461 #if @GNULIB_LDEXPF@
462 # if !@HAVE_LDEXPF@
463 #  undef ldexpf
464 _GL_FUNCDECL_SYS (ldexpf, float, (float x, int exp));
465 # endif
466 _GL_CXXALIAS_SYS (ldexpf, float, (float x, int exp));
467 _GL_CXXALIASWARN (ldexpf);
468 #elif defined GNULIB_POSIXCHECK
469 # undef ldexpf
470 # if HAVE_RAW_DECL_LDEXPF
471 _GL_WARN_ON_USE (ldexpf, "ldexpf is unportable - "
472                  "use gnulib module ldexpf for portability");
473 # endif
474 #endif
475
476 /* Return x * 2^exp.  */
477 #if @GNULIB_LDEXPL@ && @REPLACE_LDEXPL@
478 # if !(defined __cplusplus && defined GNULIB_NAMESPACE)
479 #  undef ldexpl
480 #  define ldexpl rpl_ldexpl
481 # endif
482 _GL_FUNCDECL_RPL (ldexpl, long double, (long double x, int exp));
483 _GL_CXXALIAS_RPL (ldexpl, long double, (long double x, int exp));
484 #else
485 # if !@HAVE_DECL_LDEXPL@
486 _GL_FUNCDECL_SYS (ldexpl, long double, (long double x, int exp));
487 # endif
488 # if @GNULIB_LDEXPL@
489 _GL_CXXALIAS_SYS (ldexpl, long double, (long double x, int exp));
490 # endif
491 #endif
492 #if @GNULIB_LDEXPL@
493 _GL_CXXALIASWARN (ldexpl);
494 #endif
495 #if !@GNULIB_LDEXPL@ && defined GNULIB_POSIXCHECK
496 # undef ldexpl
497 # if HAVE_RAW_DECL_LDEXPL
498 _GL_WARN_ON_USE (ldexpl, "ldexpl is unportable - "
499                  "use gnulib module ldexpl for portability");
500 # endif
501 #endif
502
503
504 #if @GNULIB_LOGB@
505 # if !@HAVE_DECL_LOGB@
506 _GL_EXTERN_C double logb (double x);
507 # endif
508 #elif defined GNULIB_POSIXCHECK
509 # undef logb
510 # if HAVE_RAW_DECL_LOGB
511 _GL_WARN_ON_USE (logb, "logb is unportable - "
512                  "use gnulib module logb for portability");
513 # endif
514 #endif
515
516
517 #if @GNULIB_LOGF@
518 # if !@HAVE_LOGF@
519 #  undef logf
520 _GL_FUNCDECL_SYS (logf, float, (float x));
521 # endif
522 _GL_CXXALIAS_SYS (logf, float, (float x));
523 _GL_CXXALIASWARN (logf);
524 #elif defined GNULIB_POSIXCHECK
525 # undef logf
526 # if HAVE_RAW_DECL_LOGF
527 _GL_WARN_ON_USE (logf, "logf is unportable - "
528                  "use gnulib module logf for portability");
529 # endif
530 #endif
531
532 #if @GNULIB_LOGL@
533 # if !@HAVE_LOGL@ || !@HAVE_DECL_LOGL@
534 _GL_FUNCDECL_SYS (logl, long double, (long double x));
535 # endif
536 _GL_CXXALIAS_SYS (logl, long double, (long double x));
537 _GL_CXXALIASWARN (logl);
538 #elif defined GNULIB_POSIXCHECK
539 # undef logl
540 # if HAVE_RAW_DECL_LOGL
541 _GL_WARN_ON_USE (logl, "logl is unportable - "
542                  "use gnulib module mathl for portability");
543 # endif
544 #endif
545
546
547 #if @GNULIB_LOG10F@
548 # if !@HAVE_LOG10F@
549 #  undef log10f
550 _GL_FUNCDECL_SYS (log10f, float, (float x));
551 # endif
552 _GL_CXXALIAS_SYS (log10f, float, (float x));
553 _GL_CXXALIASWARN (log10f);
554 #elif defined GNULIB_POSIXCHECK
555 # undef log10f
556 # if HAVE_RAW_DECL_LOG10F
557 _GL_WARN_ON_USE (log10f, "log10f is unportable - "
558                  "use gnulib module log10f for portability");
559 # endif
560 #endif
561
562
563 #if @GNULIB_MODFF@
564 # if !@HAVE_MODFF@
565 #  undef modff
566 _GL_FUNCDECL_SYS (modff, float, (float x, float *iptr) _GL_ARG_NONNULL ((2)));
567 # endif
568 _GL_CXXALIAS_SYS (modff, float, (float x, float *iptr));
569 _GL_CXXALIASWARN (modff);
570 #elif defined GNULIB_POSIXCHECK
571 # undef modff
572 # if HAVE_RAW_DECL_MODFF
573 _GL_WARN_ON_USE (modff, "modff is unportable - "
574                  "use gnulib module modff for portability");
575 # endif
576 #endif
577
578
579 #if @GNULIB_POWF@
580 # if !@HAVE_POWF@
581 #  undef powf
582 _GL_FUNCDECL_SYS (powf, float, (float x, float y));
583 # endif
584 _GL_CXXALIAS_SYS (powf, float, (float x, float y));
585 _GL_CXXALIASWARN (powf);
586 #elif defined GNULIB_POSIXCHECK
587 # undef powf
588 # if HAVE_RAW_DECL_POWF
589 _GL_WARN_ON_USE (powf, "powf is unportable - "
590                  "use gnulib module powf for portability");
591 # endif
592 #endif
593
594
595 #if @GNULIB_ROUNDF@
596 # if @REPLACE_ROUNDF@
597 #  if !(defined __cplusplus && defined GNULIB_NAMESPACE)
598 #   undef roundf
599 #   define roundf rpl_roundf
600 #  endif
601 _GL_FUNCDECL_RPL (roundf, float, (float x));
602 _GL_CXXALIAS_RPL (roundf, float, (float x));
603 # else
604 #  if !@HAVE_DECL_ROUNDF@
605 _GL_FUNCDECL_SYS (roundf, float, (float x));
606 #  endif
607 _GL_CXXALIAS_SYS (roundf, float, (float x));
608 # endif
609 _GL_CXXALIASWARN (roundf);
610 #elif defined GNULIB_POSIXCHECK
611 # undef roundf
612 # if HAVE_RAW_DECL_ROUNDF
613 _GL_WARN_ON_USE (roundf, "roundf is unportable - "
614                  "use gnulib module roundf for portability");
615 # endif
616 #endif
617
618 #if @GNULIB_ROUND@
619 # if @REPLACE_ROUND@
620 #  if !(defined __cplusplus && defined GNULIB_NAMESPACE)
621 #   undef round
622 #   define round rpl_round
623 #  endif
624 _GL_FUNCDECL_RPL (round, double, (double x));
625 _GL_CXXALIAS_RPL (round, double, (double x));
626 # else
627 #  if !@HAVE_DECL_ROUND@
628 _GL_FUNCDECL_SYS (round, double, (double x));
629 #  endif
630 _GL_CXXALIAS_SYS (round, double, (double x));
631 # endif
632 _GL_CXXALIASWARN (round);
633 #elif defined GNULIB_POSIXCHECK
634 # undef round
635 # if HAVE_RAW_DECL_ROUND
636 _GL_WARN_ON_USE (round, "round is unportable - "
637                  "use gnulib module round for portability");
638 # endif
639 #endif
640
641 #if @GNULIB_ROUNDL@
642 # if @REPLACE_ROUNDL@
643 #  if !(defined __cplusplus && defined GNULIB_NAMESPACE)
644 #   undef roundl
645 #   define roundl rpl_roundl
646 #  endif
647 _GL_FUNCDECL_RPL (roundl, long double, (long double x));
648 _GL_CXXALIAS_RPL (roundl, long double, (long double x));
649 # else
650 #  if !@HAVE_DECL_ROUNDL@
651 _GL_FUNCDECL_SYS (roundl, long double, (long double x));
652 #  endif
653 _GL_CXXALIAS_SYS (roundl, long double, (long double x));
654 # endif
655 _GL_CXXALIASWARN (roundl);
656 #elif defined GNULIB_POSIXCHECK
657 # undef roundl
658 # if HAVE_RAW_DECL_ROUNDL
659 _GL_WARN_ON_USE (roundl, "roundl is unportable - "
660                  "use gnulib module roundl for portability");
661 # endif
662 #endif
663
664
665 #if @GNULIB_SINF@
666 # if !@HAVE_SINF@
667 #  undef sinf
668 _GL_FUNCDECL_SYS (sinf, float, (float x));
669 # endif
670 _GL_CXXALIAS_SYS (sinf, float, (float x));
671 _GL_CXXALIASWARN (sinf);
672 #elif defined GNULIB_POSIXCHECK
673 # undef sinf
674 # if HAVE_RAW_DECL_SINF
675 _GL_WARN_ON_USE (sinf, "sinf is unportable - "
676                  "use gnulib module sinf for portability");
677 # endif
678 #endif
679
680 #if @GNULIB_SINL@
681 # if !@HAVE_SINL@ || !@HAVE_DECL_SINL@
682 _GL_FUNCDECL_SYS (sinl, long double, (long double x));
683 # endif
684 _GL_CXXALIAS_SYS (sinl, long double, (long double x));
685 _GL_CXXALIASWARN (sinl);
686 #elif defined GNULIB_POSIXCHECK
687 # undef sinl
688 # if HAVE_RAW_DECL_SINL
689 _GL_WARN_ON_USE (sinl, "sinl is unportable - "
690                  "use gnulib module mathl for portability");
691 # endif
692 #endif
693
694
695 #if @GNULIB_SQRTF@
696 # if !@HAVE_SQRTF@
697 #  undef sqrtf
698 _GL_FUNCDECL_SYS (sqrtf, float, (float x));
699 # endif
700 _GL_CXXALIAS_SYS (sqrtf, float, (float x));
701 _GL_CXXALIASWARN (sqrtf);
702 #elif defined GNULIB_POSIXCHECK
703 # undef sqrtf
704 # if HAVE_RAW_DECL_SQRTF
705 _GL_WARN_ON_USE (sqrtf, "sqrtf is unportable - "
706                  "use gnulib module sqrtf for portability");
707 # endif
708 #endif
709
710 #if @GNULIB_SQRTL@
711 # if !@HAVE_SQRTL@ || !@HAVE_DECL_SQRTL@
712 _GL_FUNCDECL_SYS (sqrtl, long double, (long double x));
713 # endif
714 _GL_CXXALIAS_SYS (sqrtl, long double, (long double x));
715 _GL_CXXALIASWARN (sqrtl);
716 #elif defined GNULIB_POSIXCHECK
717 # undef sqrtl
718 # if HAVE_RAW_DECL_SQRTL
719 _GL_WARN_ON_USE (sqrtl, "sqrtl is unportable - "
720                  "use gnulib module mathl for portability");
721 # endif
722 #endif
723
724
725 #if @GNULIB_TANF@
726 # if !@HAVE_TANF@
727 #  undef tanf
728 _GL_FUNCDECL_SYS (tanf, float, (float x));
729 # endif
730 _GL_CXXALIAS_SYS (tanf, float, (float x));
731 _GL_CXXALIASWARN (tanf);
732 #elif defined GNULIB_POSIXCHECK
733 # undef tanf
734 # if HAVE_RAW_DECL_TANF
735 _GL_WARN_ON_USE (tanf, "tanf is unportable - "
736                  "use gnulib module tanf for portability");
737 # endif
738 #endif
739
740 #if @GNULIB_TANL@
741 # if !@HAVE_TANL@ || !@HAVE_DECL_TANL@
742 _GL_FUNCDECL_SYS (tanl, long double, (long double x));
743 # endif
744 _GL_CXXALIAS_SYS (tanl, long double, (long double x));
745 _GL_CXXALIASWARN (tanl);
746 #elif defined GNULIB_POSIXCHECK
747 # undef tanl
748 # if HAVE_RAW_DECL_TANL
749 _GL_WARN_ON_USE (tanl, "tanl is unportable - "
750                  "use gnulib module mathl for portability");
751 # endif
752 #endif
753
754
755 #if @GNULIB_TRUNCF@
756 # if @REPLACE_TRUNCF@
757 #  if !(defined __cplusplus && defined GNULIB_NAMESPACE)
758 #   define truncf rpl_truncf
759 #  endif
760 _GL_FUNCDECL_RPL (truncf, float, (float x));
761 _GL_CXXALIAS_RPL (truncf, float, (float x));
762 # else
763 #  if !@HAVE_DECL_TRUNCF@
764 _GL_FUNCDECL_SYS (truncf, float, (float x));
765 #  endif
766 _GL_CXXALIAS_SYS (truncf, float, (float x));
767 # endif
768 _GL_CXXALIASWARN (truncf);
769 #elif defined GNULIB_POSIXCHECK
770 # undef truncf
771 # if HAVE_RAW_DECL_TRUNCF
772 _GL_WARN_ON_USE (truncf, "truncf is unportable - "
773                  "use gnulib module truncf for portability");
774 # endif
775 #endif
776
777 #if @GNULIB_TRUNC@
778 # if @REPLACE_TRUNC@
779 #  if !(defined __cplusplus && defined GNULIB_NAMESPACE)
780 #   define trunc rpl_trunc
781 #  endif
782 _GL_FUNCDECL_RPL (trunc, double, (double x));
783 _GL_CXXALIAS_RPL (trunc, double, (double x));
784 # else
785 #  if !@HAVE_DECL_TRUNC@
786 _GL_FUNCDECL_SYS (trunc, double, (double x));
787 #  endif
788 _GL_CXXALIAS_SYS (trunc, double, (double x));
789 # endif
790 _GL_CXXALIASWARN (trunc);
791 #elif defined GNULIB_POSIXCHECK
792 # undef trunc
793 # if HAVE_RAW_DECL_TRUNC
794 _GL_WARN_ON_USE (trunc, "trunc is unportable - "
795                  "use gnulib module trunc for portability");
796 # endif
797 #endif
798
799 #if @GNULIB_TRUNCL@
800 # if @REPLACE_TRUNCL@
801 #  if !(defined __cplusplus && defined GNULIB_NAMESPACE)
802 #   undef truncl
803 #   define truncl rpl_truncl
804 #  endif
805 _GL_FUNCDECL_RPL (truncl, long double, (long double x));
806 _GL_CXXALIAS_RPL (truncl, long double, (long double x));
807 # else
808 #  if !@HAVE_DECL_TRUNCL@
809 _GL_FUNCDECL_SYS (truncl, long double, (long double x));
810 #  endif
811 _GL_CXXALIAS_SYS (truncl, long double, (long double x));
812 # endif
813 _GL_CXXALIASWARN (truncl);
814 #elif defined GNULIB_POSIXCHECK
815 # undef truncl
816 # if HAVE_RAW_DECL_TRUNCL
817 _GL_WARN_ON_USE (truncl, "truncl is unportable - "
818                  "use gnulib module truncl for portability");
819 # endif
820 #endif
821
822
823 /* Definitions of function-like macros come here, after the function
824    declarations.  */
825
826
827 #if @GNULIB_ISFINITE@
828 # if @REPLACE_ISFINITE@
829 _GL_EXTERN_C int gl_isfinitef (float x);
830 _GL_EXTERN_C int gl_isfinited (double x);
831 _GL_EXTERN_C int gl_isfinitel (long double x);
832 #  undef isfinite
833 #  define isfinite(x) \
834    (sizeof (x) == sizeof (long double) ? gl_isfinitel (x) : \
835     sizeof (x) == sizeof (double) ? gl_isfinited (x) : \
836     gl_isfinitef (x))
837 # endif
838 #elif defined GNULIB_POSIXCHECK
839 # if defined isfinite
840 _GL_WARN_REAL_FLOATING_DECL (isfinite);
841 #  undef isfinite
842 #  define isfinite(x) _GL_WARN_REAL_FLOATING_IMPL (isfinite, x)
843 # endif
844 #endif
845
846
847 #if @GNULIB_ISINF@
848 # if @REPLACE_ISINF@
849 _GL_EXTERN_C int gl_isinff (float x);
850 _GL_EXTERN_C int gl_isinfd (double x);
851 _GL_EXTERN_C int gl_isinfl (long double x);
852 #  undef isinf
853 #  define isinf(x) \
854    (sizeof (x) == sizeof (long double) ? gl_isinfl (x) : \
855     sizeof (x) == sizeof (double) ? gl_isinfd (x) : \
856     gl_isinff (x))
857 # endif
858 #elif defined GNULIB_POSIXCHECK
859 # if defined isinf
860 _GL_WARN_REAL_FLOATING_DECL (isinf);
861 #  undef isinf
862 #  define isinf(x) _GL_WARN_REAL_FLOATING_IMPL (isinf, x)
863 # endif
864 #endif
865
866
867 #if @GNULIB_ISNANF@
868 /* Test for NaN for 'float' numbers.  */
869 # if @HAVE_ISNANF@
870 /* The original <math.h> included above provides a declaration of isnan macro
871    or (older) isnanf function.  */
872 #  if __GNUC__ >= 4
873     /* GCC 4.0 and newer provides three built-ins for isnan.  */
874 #   undef isnanf
875 #   define isnanf(x) __builtin_isnanf ((float)(x))
876 #  elif defined isnan
877 #   undef isnanf
878 #   define isnanf(x) isnan ((float)(x))
879 #  endif
880 # else
881 /* Test whether X is a NaN.  */
882 #  undef isnanf
883 #  define isnanf rpl_isnanf
884 _GL_EXTERN_C int isnanf (float x);
885 # endif
886 #endif
887
888 #if @GNULIB_ISNAND@
889 /* Test for NaN for 'double' numbers.
890    This function is a gnulib extension, unlike isnan() which applied only
891    to 'double' numbers earlier but now is a type-generic macro.  */
892 # if @HAVE_ISNAND@
893 /* The original <math.h> included above provides a declaration of isnan
894    macro.  */
895 #  if __GNUC__ >= 4
896     /* GCC 4.0 and newer provides three built-ins for isnan.  */
897 #   undef isnand
898 #   define isnand(x) __builtin_isnan ((double)(x))
899 #  else
900 #   undef isnand
901 #   define isnand(x) isnan ((double)(x))
902 #  endif
903 # else
904 /* Test whether X is a NaN.  */
905 #  undef isnand
906 #  define isnand rpl_isnand
907 _GL_EXTERN_C int isnand (double x);
908 # endif
909 #endif
910
911 #if @GNULIB_ISNANL@
912 /* Test for NaN for 'long double' numbers.  */
913 # if @HAVE_ISNANL@
914 /* The original <math.h> included above provides a declaration of isnan
915    macro or (older) isnanl function.  */
916 #  if __GNUC__ >= 4
917     /* GCC 4.0 and newer provides three built-ins for isnan.  */
918 #   undef isnanl
919 #   define isnanl(x) __builtin_isnanl ((long double)(x))
920 #  elif defined isnan
921 #   undef isnanl
922 #   define isnanl(x) isnan ((long double)(x))
923 #  endif
924 # else
925 /* Test whether X is a NaN.  */
926 #  undef isnanl
927 #  define isnanl rpl_isnanl
928 _GL_EXTERN_C int isnanl (long double x);
929 # endif
930 #endif
931
932 /* This must come *after* the snippets for GNULIB_ISNANF and GNULIB_ISNANL!  */
933 #if @GNULIB_ISNAN@
934 # if @REPLACE_ISNAN@
935 /* We can't just use the isnanf macro (e.g.) as exposed by
936    isnanf.h (e.g.) here, because those may end up being macros
937    that recursively expand back to isnan.  So use the gnulib
938    replacements for them directly. */
939 #  if @HAVE_ISNANF@ && __GNUC__ >= 4
940 #   define gl_isnan_f(x) __builtin_isnanf ((float)(x))
941 #  else
942 _GL_EXTERN_C int rpl_isnanf (float x);
943 #   define gl_isnan_f(x) rpl_isnanf (x)
944 #  endif
945 #  if @HAVE_ISNAND@ && __GNUC__ >= 4
946 #   define gl_isnan_d(x) __builtin_isnan ((double)(x))
947 #  else
948 _GL_EXTERN_C int rpl_isnand (double x);
949 #   define gl_isnan_d(x) rpl_isnand (x)
950 #  endif
951 #  if @HAVE_ISNANL@ && __GNUC__ >= 4
952 #   define gl_isnan_l(x) __builtin_isnanl ((long double)(x))
953 #  else
954 _GL_EXTERN_C int rpl_isnanl (long double x);
955 #   define gl_isnan_l(x) rpl_isnanl (x)
956 #  endif
957 #  undef isnan
958 #  define isnan(x) \
959    (sizeof (x) == sizeof (long double) ? gl_isnan_l (x) : \
960     sizeof (x) == sizeof (double) ? gl_isnan_d (x) : \
961     gl_isnan_f (x))
962 # elif __GNUC__ >= 4
963 #  undef isnan
964 #  define isnan(x) \
965    (sizeof (x) == sizeof (long double) ? __builtin_isnanl ((long double)(x)) : \
966     sizeof (x) == sizeof (double) ? __builtin_isnan ((double)(x)) : \
967     __builtin_isnanf ((float)(x)))
968 # endif
969 /* Ensure isnan is a macro.  */
970 # ifndef isnan
971 #  define isnan isnan
972 # endif
973 #elif defined GNULIB_POSIXCHECK
974 # if defined isnan
975 _GL_WARN_REAL_FLOATING_DECL (isnan);
976 #  undef isnan
977 #  define isnan(x) _GL_WARN_REAL_FLOATING_IMPL (isnan, x)
978 # endif
979 #endif
980
981
982 #if @GNULIB_SIGNBIT@
983 # if @REPLACE_SIGNBIT_USING_GCC@
984 #  undef signbit
985    /* GCC 4.0 and newer provides three built-ins for signbit.  */
986 #  define signbit(x) \
987    (sizeof (x) == sizeof (long double) ? __builtin_signbitl (x) : \
988     sizeof (x) == sizeof (double) ? __builtin_signbit (x) : \
989     __builtin_signbitf (x))
990 # endif
991 # if @REPLACE_SIGNBIT@
992 #  undef signbit
993 _GL_EXTERN_C int gl_signbitf (float arg);
994 _GL_EXTERN_C int gl_signbitd (double arg);
995 _GL_EXTERN_C int gl_signbitl (long double arg);
996 #  if __GNUC__ >= 2 && !__STRICT_ANSI__
997 #   define _GL_NUM_UINT_WORDS(type) \
998       ((sizeof (type) + sizeof (unsigned int) - 1) / sizeof (unsigned int))
999 #   if defined FLT_SIGNBIT_WORD && defined FLT_SIGNBIT_BIT && !defined gl_signbitf
1000 #    define gl_signbitf_OPTIMIZED_MACRO
1001 #    define gl_signbitf(arg) \
1002        ({ union { float _value;                                         \
1003                   unsigned int _word[_GL_NUM_UINT_WORDS (float)];       \
1004                 } _m;                                                   \
1005           _m._value = (arg);                                            \
1006           (_m._word[FLT_SIGNBIT_WORD] >> FLT_SIGNBIT_BIT) & 1;          \
1007         })
1008 #   endif
1009 #   if defined DBL_SIGNBIT_WORD && defined DBL_SIGNBIT_BIT && !defined gl_signbitd
1010 #    define gl_signbitd_OPTIMIZED_MACRO
1011 #    define gl_signbitd(arg) \
1012        ({ union { double _value;                                        \
1013                   unsigned int _word[_GL_NUM_UINT_WORDS (double)];      \
1014                 } _m;                                                   \
1015           _m._value = (arg);                                            \
1016           (_m._word[DBL_SIGNBIT_WORD] >> DBL_SIGNBIT_BIT) & 1;          \
1017         })
1018 #   endif
1019 #   if defined LDBL_SIGNBIT_WORD && defined LDBL_SIGNBIT_BIT && !defined gl_signbitl
1020 #    define gl_signbitl_OPTIMIZED_MACRO
1021 #    define gl_signbitl(arg) \
1022        ({ union { long double _value;                                   \
1023                   unsigned int _word[_GL_NUM_UINT_WORDS (long double)]; \
1024                 } _m;                                                   \
1025           _m._value = (arg);                                            \
1026           (_m._word[LDBL_SIGNBIT_WORD] >> LDBL_SIGNBIT_BIT) & 1;        \
1027         })
1028 #   endif
1029 #  endif
1030 #  define signbit(x) \
1031    (sizeof (x) == sizeof (long double) ? gl_signbitl (x) : \
1032     sizeof (x) == sizeof (double) ? gl_signbitd (x) : \
1033     gl_signbitf (x))
1034 # endif
1035 #elif defined GNULIB_POSIXCHECK
1036 # if defined signbit
1037 _GL_WARN_REAL_FLOATING_DECL (signbit);
1038 #  undef signbit
1039 #  define signbit(x) _GL_WARN_REAL_FLOATING_IMPL (signbit, x)
1040 # endif
1041 #endif
1042
1043
1044 #endif /* _@GUARD_PREFIX@_MATH_H */
1045 #endif /* _@GUARD_PREFIX@_MATH_H */