mirror of
https://sourceware.org/git/glibc.git
synced 2025-05-28 16:21:30 +03:00
Ensure C99 and C11 interfaces are available for C++ [BZ #21326]
This patch ensures that the C99 and C11 features required by C++ are defined according to the value of the __cplusplus macro, and not just because G++ always defines _GNU_SOURCE. This will allow G++ to stop defining _GNU_SOURCE some day, without causing the C99 and C11 interfaces to disappear for C++ programs. [BZ #21326] * include/features.h [__cplusplus >= 201103] (__USE_ISOC99): Define. [__cplusplus >= 201703] (__USE_ISOCXX17, __USE_ISOC11): Define. * math/Makefile (test-math-cxx11): New test. * math/test-math-cxx11.cc: New file.
This commit is contained in:
parent
645ac9aaf8
commit
d6c064e914
@ -1,3 +1,11 @@
|
|||||||
|
2017-10-09 Jonathan Wakely <jwakely@redhat.com>
|
||||||
|
|
||||||
|
[BZ #21326]
|
||||||
|
* include/features.h [__cplusplus >= 201703] (__USE_ISOC11): Define.
|
||||||
|
[__cplusplus >= 201103] (__USE_ISOC99): Define.
|
||||||
|
* math/Makefile (test-math-cxx11): New test.
|
||||||
|
* math/test-math-cxx11.cc: New file.
|
||||||
|
|
||||||
2017-10-08 Christian Brauner <christian.brauner@ubuntu.com>
|
2017-10-08 Christian Brauner <christian.brauner@ubuntu.com>
|
||||||
|
|
||||||
* login/openpty.c (openpty): Close slave pty file descriptor on error.
|
* login/openpty.c (openpty): Close slave pty file descriptor on error.
|
||||||
|
@ -76,6 +76,7 @@
|
|||||||
__USE_ISOC11 Define ISO C11 things.
|
__USE_ISOC11 Define ISO C11 things.
|
||||||
__USE_ISOC99 Define ISO C99 things.
|
__USE_ISOC99 Define ISO C99 things.
|
||||||
__USE_ISOC95 Define ISO C90 AMD1 (C95) things.
|
__USE_ISOC95 Define ISO C90 AMD1 (C95) things.
|
||||||
|
__USE_ISOCXX11 Define ISO C++11 things.
|
||||||
__USE_POSIX Define IEEE Std 1003.1 things.
|
__USE_POSIX Define IEEE Std 1003.1 things.
|
||||||
__USE_POSIX2 Define IEEE Std 1003.2 things.
|
__USE_POSIX2 Define IEEE Std 1003.2 things.
|
||||||
__USE_POSIX199309 Define IEEE Std 1003.1, and .1b things.
|
__USE_POSIX199309 Define IEEE Std 1003.1, and .1b things.
|
||||||
@ -238,13 +239,17 @@
|
|||||||
# define __USE_ISOC95 1
|
# define __USE_ISOC95 1
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
/* This is to enable compatibility for ISO C++17. */
|
||||||
|
# if __cplusplus >= 201703L
|
||||||
|
# define __USE_ISOC11 1
|
||||||
|
# endif
|
||||||
/* This is to enable compatibility for ISO C++11.
|
/* This is to enable compatibility for ISO C++11.
|
||||||
|
Check the temporary macro for now, too. */
|
||||||
So far g++ does not provide a macro. Check the temporary macro for
|
# if __cplusplus >= 201103L || defined __GXX_EXPERIMENTAL_CXX0X__
|
||||||
now, too. */
|
# define __USE_ISOCXX11 1
|
||||||
#if ((defined __cplusplus && __cplusplus >= 201103L) \
|
# define __USE_ISOC99 1
|
||||||
|| defined __GXX_EXPERIMENTAL_CXX0X__)
|
# endif
|
||||||
# define __USE_ISOCXX11 1
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/* If none of the ANSI/POSIX macros are defined, or if _DEFAULT_SOURCE
|
/* If none of the ANSI/POSIX macros are defined, or if _DEFAULT_SOURCE
|
||||||
|
@ -209,7 +209,7 @@ tests-static += atest-exp atest-sincos atest-exp2
|
|||||||
|
|
||||||
ifneq (,$(CXX))
|
ifneq (,$(CXX))
|
||||||
tests += test-math-isinff test-math-iszero test-math-issignaling \
|
tests += test-math-isinff test-math-iszero test-math-issignaling \
|
||||||
test-math-iscanonical
|
test-math-iscanonical test-math-cxx11
|
||||||
endif
|
endif
|
||||||
|
|
||||||
ifneq (no,$(PERL))
|
ifneq (no,$(PERL))
|
||||||
@ -354,6 +354,8 @@ CFLAGS-test-signgam-ullong-init.c = -std=c99
|
|||||||
CFLAGS-test-signgam-ullong-static.c = -std=c99
|
CFLAGS-test-signgam-ullong-static.c = -std=c99
|
||||||
CFLAGS-test-signgam-ullong-init-static.c = -std=c99
|
CFLAGS-test-signgam-ullong-init-static.c = -std=c99
|
||||||
|
|
||||||
|
CFLAGS-test-math-cxx11.cc = -std=c++11
|
||||||
|
|
||||||
CFLAGS-test-math-isinff.cc = -std=gnu++11
|
CFLAGS-test-math-isinff.cc = -std=gnu++11
|
||||||
CFLAGS-test-math-iszero.cc = -std=gnu++11
|
CFLAGS-test-math-iszero.cc = -std=gnu++11
|
||||||
CFLAGS-test-math-issignaling.cc = -std=gnu++11
|
CFLAGS-test-math-issignaling.cc = -std=gnu++11
|
||||||
|
160
math/test-math-cxx11.cc
Normal file
160
math/test-math-cxx11.cc
Normal file
@ -0,0 +1,160 @@
|
|||||||
|
/* Test C99 math functions are available in C++11 without _GNU_SOURCE.
|
||||||
|
Copyright (C) 2017 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, see
|
||||||
|
<http://www.gnu.org/licenses/>. */
|
||||||
|
|
||||||
|
#undef _GNU_SOURCE
|
||||||
|
#undef _DEFAULT_SOURCE
|
||||||
|
#undef _XOPEN_SOURCE
|
||||||
|
#undef _POSIX_SOURCE
|
||||||
|
#undef _POSIX_C_SOURCE
|
||||||
|
// __STRICT_ANSI__ gets defined by -std=c++11 in CFLAGS
|
||||||
|
#include <math.h>
|
||||||
|
#include <stdio.h>
|
||||||
|
|
||||||
|
static int
|
||||||
|
do_test (void)
|
||||||
|
{
|
||||||
|
#ifdef _GNU_SOURCE
|
||||||
|
printf ("FAIL: _GNU_SOURCE is defined.\n");
|
||||||
|
return 1;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if __cplusplus >= 201103L
|
||||||
|
/* Verify that C11 math functions and types are defined for C++11,
|
||||||
|
without _GNU_SOURCE being defined. [BZ #21326] */
|
||||||
|
(void) FP_INFINITE;
|
||||||
|
(void) FP_NAN;
|
||||||
|
(void) FP_NORMAL;
|
||||||
|
(void) FP_SUBNORMAL;
|
||||||
|
(void) FP_ZERO;
|
||||||
|
double_t d = 1.0;
|
||||||
|
(void) d;
|
||||||
|
float_t f = 1.0f;
|
||||||
|
(void) f;
|
||||||
|
(void) acosh;
|
||||||
|
(void) acoshf;
|
||||||
|
(void) acoshl;
|
||||||
|
(void) asinh;
|
||||||
|
(void) asinhf;
|
||||||
|
(void) asinhl;
|
||||||
|
(void) atanh;
|
||||||
|
(void) atanhf;
|
||||||
|
(void) atanhl;
|
||||||
|
(void) cbrt;
|
||||||
|
(void) cbrtf;
|
||||||
|
(void) cbrtl;
|
||||||
|
(void) copysign;
|
||||||
|
(void) copysignf;
|
||||||
|
(void) copysignl;
|
||||||
|
(void) erf;
|
||||||
|
(void) erff;
|
||||||
|
(void) erfl;
|
||||||
|
(void) erfc;
|
||||||
|
(void) erfcf;
|
||||||
|
(void) erfcl;
|
||||||
|
(void) exp2;
|
||||||
|
(void) exp2f;
|
||||||
|
(void) exp2l;
|
||||||
|
(void) expm1;
|
||||||
|
(void) expm1f;
|
||||||
|
(void) expm1l;
|
||||||
|
(void) fdim;
|
||||||
|
(void) fdimf;
|
||||||
|
(void) fdiml;
|
||||||
|
(void) fma;
|
||||||
|
(void) fmaf;
|
||||||
|
(void) fmal;
|
||||||
|
(void) fmax;
|
||||||
|
(void) fmaxf;
|
||||||
|
(void) fmaxl;
|
||||||
|
(void) fmin;
|
||||||
|
(void) fminf;
|
||||||
|
(void) fminl;
|
||||||
|
(void) hypot;
|
||||||
|
(void) hypotf;
|
||||||
|
(void) hypotl;
|
||||||
|
(void) ilogb;
|
||||||
|
(void) ilogbf;
|
||||||
|
(void) ilogbl;
|
||||||
|
(void) lgamma;
|
||||||
|
(void) lgammaf;
|
||||||
|
(void) lgammal;
|
||||||
|
(void) llrint;
|
||||||
|
(void) llrintf;
|
||||||
|
(void) llrintl;
|
||||||
|
(void) llround;
|
||||||
|
(void) llroundf;
|
||||||
|
(void) llroundl;
|
||||||
|
(void) log1p;
|
||||||
|
(void) log1pf;
|
||||||
|
(void) log1pl;
|
||||||
|
(void) log2;
|
||||||
|
(void) log2f;
|
||||||
|
(void) log2l;
|
||||||
|
(void) logb;
|
||||||
|
(void) logbf;
|
||||||
|
(void) logbl;
|
||||||
|
(void) lrint;
|
||||||
|
(void) lrintf;
|
||||||
|
(void) lrintl;
|
||||||
|
(void) lround;
|
||||||
|
(void) lroundf;
|
||||||
|
(void) lroundl;
|
||||||
|
(void) nan;
|
||||||
|
(void) nanf;
|
||||||
|
(void) nanl;
|
||||||
|
(void) nearbyint;
|
||||||
|
(void) nearbyintf;
|
||||||
|
(void) nearbyintl;
|
||||||
|
(void) nextafter;
|
||||||
|
(void) nextafterf;
|
||||||
|
(void) nextafterl;
|
||||||
|
(void) nexttoward;
|
||||||
|
(void) nexttowardf;
|
||||||
|
(void) nexttowardl;
|
||||||
|
(void) remainder;
|
||||||
|
(void) remainderf;
|
||||||
|
(void) remainderl;
|
||||||
|
(void) remquo;
|
||||||
|
(void) remquof;
|
||||||
|
(void) remquol;
|
||||||
|
(void) rint;
|
||||||
|
(void) rintf;
|
||||||
|
(void) rintl;
|
||||||
|
(void) round;
|
||||||
|
(void) roundf;
|
||||||
|
(void) roundl;
|
||||||
|
(void) scalbln;
|
||||||
|
(void) scalblnf;
|
||||||
|
(void) scalblnl;
|
||||||
|
(void) scalbn;
|
||||||
|
(void) scalbnf;
|
||||||
|
(void) scalbnl;
|
||||||
|
(void) tgamma;
|
||||||
|
(void) tgammaf;
|
||||||
|
(void) tgammal;
|
||||||
|
(void) trunc;
|
||||||
|
(void) truncf;
|
||||||
|
(void) truncl;
|
||||||
|
printf ("PASS: C11 math functions present in C++11 without _GNU_SOURCE.\n");
|
||||||
|
#else
|
||||||
|
printf ("UNSUPPORTED: C++11 not enabled.\n");
|
||||||
|
#endif
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
#include <support/test-driver.c>
|
Loading…
x
Reference in New Issue
Block a user