2008-01-10 Paul Thomas <pault@gcc.gnu.org>
[official-gcc.git] / libgfortran / c99_protos.h
blob59cbe4cac14a3c8ba2e5729df6cc5ddc85b246c6
1 /* Declarations of various C99 functions
2 Copyright (C) 2004, 2006, 2007 Free Software Foundation, Inc.
4 This file is part of the GNU Fortran 95 runtime library (libgfortran).
6 Libgfortran is free software; you can redistribute it and/or
7 modify it under the terms of the GNU Lesser General Public
8 License as published by the Free Software Foundation; either
9 version 2.1 of the License, or (at your option) any later version.
11 Libgfortran is distributed in the hope that it will be useful,
12 but WITHOUT ANY WARRANTY; without even the implied warranty of
13 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 GNU Lesser General Public License for more details.
16 You should have received a copy of the GNU Lesser General Public
17 License along with libgfortran; see the file COPYING.LIB. If not,
18 write to the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
19 Boston, MA 02110-1301, USA. */
21 /* As a special exception, if you link this library with other files,
22 some of which are compiled with GCC, to produce an executable,
23 this library does not by itself cause the resulting executable
24 to be covered by the GNU General Public License.
25 This exception does not however invalidate any other reasons why
26 the executable file might be covered by the GNU General Public License. */
29 #ifndef C99_PROTOS_H
30 #define C99_PROTOS_H 1
32 /* float variants of libm functions */
33 #ifndef HAVE_ACOSF
34 #define HAVE_ACOSF 1
35 extern float acosf(float);
36 #endif
38 #if HAVE_ACOSH && !HAVE_ACOSHF
39 #define HAVE_ACOSHF 1
40 extern float acoshf(float);
41 #endif
43 #ifndef HAVE_ASINF
44 #define HAVE_ASINF 1
45 extern float asinf(float);
46 #endif
48 #if HAVE_ASINH && !HAVE_ASINHF
49 #define HAVE_ASINHF 1
50 extern float asinhf(float);
51 #endif
53 #ifndef HAVE_ATAN2F
54 #define HAVE_ATAN2F 1
55 extern float atan2f(float, float);
56 #endif
58 #ifndef HAVE_ATANF
59 #define HAVE_ATANF 1
60 extern float atanf(float);
61 #endif
63 #if HAVE_ATANH && !HAVE_ATANHF
64 #define HAVE_ATANHF 1
65 extern float atanhf(float);
66 #endif
68 #ifndef HAVE_CEILF
69 #define HAVE_CEILF 1
70 extern float ceilf(float);
71 #endif
73 #ifndef HAVE_COPYSIGNF
74 #define HAVE_COPYSIGNF 1
75 extern float copysignf(float, float);
76 #endif
78 #ifndef HAVE_COSF
79 #define HAVE_COSF 1
80 extern float cosf(float);
81 #endif
83 #ifndef HAVE_COSHF
84 #define HAVE_COSHF 1
85 extern float coshf(float);
86 #endif
88 #ifndef HAVE_EXPF
89 #define HAVE_EXPF 1
90 extern float expf(float);
91 #endif
93 #ifndef HAVE_FABSF
94 #define HAVE_FABSF 1
95 extern float fabsf(float);
96 #endif
98 #ifndef HAVE_FLOORF
99 #define HAVE_FLOORF 1
100 extern float floorf(float);
101 #endif
103 #ifndef HAVE_FLOORL
104 #define HAVE_FLOORL 1
105 extern long double floorl (long double x);
106 #endif
108 #ifndef HAVE_FMODF
109 #define HAVE_FMODF 1
110 extern float fmodf (float x, float y);
111 #endif
113 #ifndef HAVE_FMODL
114 #define HAVE_FMODL 1
115 extern long double fmodl (long double x, long double y);
116 #endif
118 #ifndef HAVE_FREXPF
119 #define HAVE_FREXPF 1
120 extern float frexpf(float, int *);
121 #endif
123 #ifndef HAVE_HYPOTF
124 #define HAVE_HYPOTF 1
125 extern float hypotf(float, float);
126 #endif
128 #ifndef HAVE_LOGF
129 #define HAVE_LOGF 1
130 extern float logf(float);
131 #endif
133 #ifndef HAVE_LOG10F
134 #define HAVE_LOG10F 1
135 extern float log10f(float);
136 #endif
138 #ifndef HAVE_SCALBN
139 #define HAVE_SCALBN 1
140 extern double scalbn(double, int);
141 #endif
143 #ifndef HAVE_SCALBNF
144 #define HAVE_SCALBNF 1
145 extern float scalbnf(float, int);
146 #endif
148 #ifndef HAVE_SINF
149 #define HAVE_SINF 1
150 extern float sinf(float);
151 #endif
153 #ifndef HAVE_SINHF
154 #define HAVE_SINHF 1
155 extern float sinhf(float);
156 #endif
158 #ifndef HAVE_SQRTF
159 #define HAVE_SQRTF 1
160 extern float sqrtf(float);
161 #endif
163 #ifndef HAVE_TANF
164 #define HAVE_TANF 1
165 extern float tanf(float);
166 #endif
168 #ifndef HAVE_TANHF
169 #define HAVE_TANHF 1
170 extern float tanhf(float);
171 #endif
173 #ifndef HAVE_TRUNC
174 #define HAVE_TRUNC 1
175 extern double trunc(double);
176 #endif
178 #ifndef HAVE_TRUNCF
179 #define HAVE_TRUNCF 1
180 extern float truncf(float);
181 #endif
183 #ifndef HAVE_NEXTAFTERF
184 #define HAVE_NEXTAFTERF 1
185 extern float nextafterf(float, float);
186 #endif
188 #ifndef HAVE_POWF
189 #define HAVE_POWF 1
190 extern float powf(float, float);
191 #endif
193 #ifndef HAVE_ROUND
194 #define HAVE_ROUND 1
195 extern double round(double);
196 #endif
198 #ifndef HAVE_ROUNDF
199 #define HAVE_ROUNDF 1
200 extern float roundf(float);
201 #endif
203 #if !defined(HAVE_ROUNDL)
204 #define HAVE_ROUNDL 1
205 extern long double roundl(long double);
206 #endif
210 #if !defined(HAVE_LROUNDF) && defined(HAVE_ROUNDF)
211 #define HAVE_LROUNDF 1
212 long int lroundf (float);
213 #endif
215 #if !defined(HAVE_LROUND) && defined(HAVE_ROUND)
216 #define HAVE_LROUND 1
217 long int lround (double);
218 #endif
220 #if !defined(HAVE_LROUNDL) && defined(HAVE_ROUNDL)
221 #define HAVE_LROUNDL 1
222 long int lroundl (long double);
223 #endif
225 #if !defined(HAVE_LLROUNDF) && defined(HAVE_ROUNDF)
226 #define HAVE_LLROUNDF 1
227 long long int llroundf (float);
228 #endif
230 #if !defined(HAVE_LLROUND) && defined(HAVE_ROUND)
231 #define HAVE_LLROUND 1
232 long long int llround (double);
233 #endif
235 #if !defined(HAVE_LLROUNDL) && defined(HAVE_ROUNDL)
236 #define HAVE_LLROUNDL 1
237 long long int llroundl (long double);
238 #endif
240 /* Wrappers for systems without the various C99 single precision Bessel
241 functions. */
243 #if defined(HAVE_J0) && ! defined(HAVE_J0F)
244 #define HAVE_J0F 1
245 extern float j0f (float);
246 #endif
248 #if defined(HAVE_J1) && !defined(HAVE_J1F)
249 #define HAVE_J1F 1
250 extern float j1f (float);
251 #endif
253 #if defined(HAVE_JN) && !defined(HAVE_JNF)
254 #define HAVE_JNF 1
255 extern float jnf (int, float);
256 #endif
258 #if defined(HAVE_Y0) && !defined(HAVE_Y0F)
259 #define HAVE_Y0F 1
260 extern float y0f (float);
261 #endif
263 #if defined(HAVE_Y1) && !defined(HAVE_Y1F)
264 #define HAVE_Y1F 1
265 extern float y1f (float);
266 #endif
268 #if defined(HAVE_YN) && !defined(HAVE_YNF)
269 #define HAVE_YNF 1
270 extern float ynf (int, float);
271 #endif
274 /* Wrappers for systems without the C99 erff() and erfcf() functions. */
276 #if defined(HAVE_ERF) && !defined(HAVE_ERFF)
277 #define HAVE_ERFF 1
278 extern float erff (float);
279 #endif
281 #if defined(HAVE_ERFC) && !defined(HAVE_ERFCF)
282 #define HAVE_ERFCF 1
283 extern float erfcf (float);
284 #endif
288 /* log10l is needed on all platforms for decimal I/O */
289 #ifndef HAVE_LOG10L
290 #define HAVE_LOG10L 1
291 extern long double log10l(long double);
292 #endif
295 /* complex math functions */
297 #if !defined(HAVE_CABSF)
298 #define HAVE_CABSF 1
299 extern float cabsf (float complex);
300 #endif
302 #if !defined(HAVE_CABS)
303 #define HAVE_CABS 1
304 extern double cabs (double complex);
305 #endif
307 #if !defined(HAVE_CABSL) && defined(HAVE_HYPOTL)
308 #define HAVE_CABSL 1
309 extern long double cabsl (long double complex);
310 #endif
313 #if !defined(HAVE_CARGF)
314 #define HAVE_CARGF 1
315 extern float cargf (float complex);
316 #endif
318 #if !defined(HAVE_CARG)
319 #define HAVE_CARG 1
320 extern double carg (double complex);
321 #endif
323 #if !defined(HAVE_CARGL) && defined(HAVE_ATAN2L)
324 #define HAVE_CARGL 1
325 extern long double cargl (long double complex);
326 #endif
329 #if !defined(HAVE_CEXPF)
330 #define HAVE_CEXPF 1
331 extern float complex cexpf (float complex);
332 #endif
334 #if !defined(HAVE_CEXP)
335 #define HAVE_CEXP 1
336 extern double complex cexp (double complex);
337 #endif
339 #if !defined(HAVE_CEXPL) && defined(HAVE_COSL) && defined(HAVE_SINL) && defined(EXPL)
340 #define HAVE_CEXPL 1
341 extern long double complex cexpl (long double complex);
342 #endif
345 #if !defined(HAVE_CLOGF)
346 #define HAVE_CLOGF 1
347 extern float complex clogf (float complex);
348 #endif
350 #if !defined(HAVE_CLOG)
351 #define HAVE_CLOG 1
352 extern double complex clog (double complex);
353 #endif
355 #if !defined(HAVE_CLOGL) && defined(HAVE_LOGL) && defined(HAVE_CABSL) && defined(HAVE_CARGL)
356 #define HAVE_CLOGL 1
357 extern long double complex clogl (long double complex);
358 #endif
361 #if !defined(HAVE_CLOG10F)
362 #define HAVE_CLOG10F 1
363 extern float complex clog10f (float complex);
364 #endif
366 #if !defined(HAVE_CLOG10)
367 #define HAVE_CLOG10 1
368 extern double complex clog10 (double complex);
369 #endif
371 #if !defined(HAVE_CLOG10L) && defined(HAVE_LOG10L) && defined(HAVE_CABSL) && defined(HAVE_CARGL)
372 #define HAVE_CLOG10L 1
373 extern long double complex clog10l (long double complex);
374 #endif
377 #if !defined(HAVE_CPOWF)
378 #define HAVE_CPOWF 1
379 extern float complex cpowf (float complex, float complex);
380 #endif
382 #if !defined(HAVE_CPOW)
383 #define HAVE_CPOW 1
384 extern double complex cpow (double complex, double complex);
385 #endif
387 #if !defined(HAVE_CPOWL) && defined(HAVE_CEXPL) && defined(HAVE_CLOGL)
388 #define HAVE_CPOWL 1
389 extern long double complex cpowl (long double complex, long double complex);
390 #endif
393 #if !defined(HAVE_CSQRTF)
394 #define HAVE_CSQRTF 1
395 extern float complex csqrtf (float complex);
396 #endif
398 #if !defined(HAVE_CSQRT)
399 #define HAVE_CSQRT 1
400 extern double complex csqrt (double complex);
401 #endif
403 #if !defined(HAVE_CSQRTL) && defined(HAVE_COPYSIGNL) && defined(HAVE_SQRTL) && defined(HAVE_FABSL) && defined(HAVE_HYPOTL)
404 #define HAVE_CSQRTL 1
405 extern long double complex csqrtl (long double complex);
406 #endif
409 #if !defined(HAVE_CSINHF)
410 #define HAVE_CSINHF 1
411 extern float complex csinhf (float complex);
412 #endif
414 #if !defined(HAVE_CSINH)
415 #define HAVE_CSINH 1
416 extern double complex csinh (double complex);
417 #endif
419 #if !defined(HAVE_CSINHL) && defined(HAVE_COSL) && defined(HAVE_COSHL) && defined(HAVE_SINL) && defined(HAVE_SINHL)
420 #define HAVE_CSINHL 1
421 extern long double complex csinhl (long double complex);
422 #endif
425 #if !defined(HAVE_CCOSHF)
426 #define HAVE_CCOSHF 1
427 extern float complex ccoshf (float complex);
428 #endif
430 #if !defined(HAVE_CCOSH)
431 #define HAVE_CCOSH 1
432 extern double complex ccosh (double complex);
433 #endif
435 #if !defined(HAVE_CCOSHL) && defined(HAVE_COSL) && defined(HAVE_COSHL) && defined(HAVE_SINL) && defined(HAVE_SINHL)
436 #define HAVE_CCOSHL 1
437 extern long double complex ccoshl (long double complex);
438 #endif
441 #if !defined(HAVE_CTANHF)
442 #define HAVE_CTANHF 1
443 extern float complex ctanhf (float complex);
444 #endif
446 #if !defined(HAVE_CTANH)
447 #define HAVE_CTANH 1
448 extern double complex ctanh (double complex);
449 #endif
451 #if !defined(HAVE_CTANHL) && defined(HAVE_TANL) && defined(HAVE_TANHL)
452 #define HAVE_CTANHL 1
453 extern long double complex ctanhl (long double complex);
454 #endif
457 #if !defined(HAVE_CSINF)
458 #define HAVE_CSINF 1
459 extern float complex csinf (float complex);
460 #endif
462 #if !defined(HAVE_CSIN)
463 #define HAVE_CSIN 1
464 extern double complex csin (double complex);
465 #endif
467 #if !defined(HAVE_CSINL) && defined(HAVE_COSL) && defined(HAVE_COSHL) && defined(HAVE_SINL) && defined(HAVE_SINHL)
468 #define HAVE_CSINL 1
469 extern long double complex csinl (long double complex);
470 #endif
473 #if !defined(HAVE_CCOSF)
474 #define HAVE_CCOSF 1
475 extern float complex ccosf (float complex);
476 #endif
478 #if !defined(HAVE_CCOS)
479 #define HAVE_CCOS 1
480 extern double complex ccos (double complex);
481 #endif
483 #if !defined(HAVE_CCOSL) && defined(HAVE_COSL) && defined(HAVE_COSHL) && defined(HAVE_SINL) && defined(HAVE_SINHL)
484 #define HAVE_CCOSL 1
485 extern long double complex ccosl (long double complex);
486 #endif
489 #if !defined(HAVE_CTANF)
490 #define HAVE_CTANF 1
491 extern float complex ctanf (float complex);
492 #endif
494 #if !defined(HAVE_CTAN)
495 #define HAVE_CTAN 1
496 extern double complex ctan (double complex);
497 #endif
499 #if !defined(HAVE_CTANL) && defined(HAVE_TANL) && defined(HAVE_TANHL)
500 #define HAVE_CTANL 1
501 extern long double complex ctanl (long double complex);
502 #endif
505 /* Gamma-related prototypes. */
506 #if !defined(HAVE_TGAMMA)
507 #define HAVE_TGAMMA 1
508 extern double tgamma (double);
509 #endif
511 #if !defined(HAVE_LGAMMA)
512 #define HAVE_LGAMMA 1
513 extern double lgamma (double);
514 #endif
516 #if defined(HAVE_TGAMMA) && !defined(HAVE_TGAMMAF)
517 #define HAVE_TGAMMAF 1
518 extern float tgammaf (float);
519 #endif
521 #if defined(HAVE_LGAMMA) && !defined(HAVE_LGAMMAF)
522 #define HAVE_LGAMMAF 1
523 extern float lgammaf (float);
524 #endif
527 #endif /* C99_PROTOS_H */