From: Marc Glisse Date: Mon, 13 Aug 2012 11:55:00 +0000 (+0200) Subject: re PR libstdc++/54112 (including complex.h and complex fails in C++03) X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=6a9573cc7b1d527e61f4ef7900c0a1c21203e24a;p=gcc.git re PR libstdc++/54112 (including complex.h and complex fails in C++03) 2012-08-13 Marc Glisse PR libstdc++/54112 * include/c_compatibility/complex.h: Undefine complex, always include system's complex.h if present. * testsuite/26_numerics/complex/c99.cc: New testcase. * testsuite/17_intro/headers/c++1998/complex.cc: Likewise. * doc/xml/manual/numerics.xml: Document it. From-SVN: r190340 --- diff --git a/libstdc++-v3/ChangeLog b/libstdc++-v3/ChangeLog index 69303abec17..250c8be8e1f 100644 --- a/libstdc++-v3/ChangeLog +++ b/libstdc++-v3/ChangeLog @@ -1,3 +1,12 @@ +2012-08-13 Marc Glisse + + PR libstdc++/54112 + * include/c_compatibility/complex.h: Undefine complex, always + include system's complex.h if present. + * testsuite/26_numerics/complex/c99.cc: New testcase. + * testsuite/17_intro/headers/c++1998/complex.cc: Likewise. + * doc/xml/manual/numerics.xml: Document it. + 2012-08-12 Jonathan Wakely PR libstdc++/52681 diff --git a/libstdc++-v3/doc/xml/manual/numerics.xml b/libstdc++-v3/doc/xml/manual/numerics.xml index a9e866e78c8..eb1014e98a9 100644 --- a/libstdc++-v3/doc/xml/manual/numerics.xml +++ b/libstdc++-v3/doc/xml/manual/numerics.xml @@ -44,6 +44,11 @@ prints (u,v) and op>> can read u, (u), and (u,v). + As an extension to C++11 and for increased compatibility with C, + <complex.h> includes both <complex> + and the C99 <complex.h> (if the C library provides + it). + diff --git a/libstdc++-v3/include/c_compatibility/complex.h b/libstdc++-v3/include/c_compatibility/complex.h index 7dc5926f1e1..1e2acafc7c2 100644 --- a/libstdc++-v3/include/c_compatibility/complex.h +++ b/libstdc++-v3/include/c_compatibility/complex.h @@ -30,10 +30,11 @@ #ifdef __GXX_EXPERIMENTAL_CXX0X__ # include -#else -# if _GLIBCXX_HAVE_COMPLEX_H -# include_next -# endif +#endif + +#if _GLIBCXX_HAVE_COMPLEX_H +# include_next +# undef complex #endif #ifndef _GLIBCXX_COMPLEX_H diff --git a/libstdc++-v3/testsuite/17_intro/headers/c++1998/complex.cc b/libstdc++-v3/testsuite/17_intro/headers/c++1998/complex.cc new file mode 100644 index 00000000000..893de06173a --- /dev/null +++ b/libstdc++-v3/testsuite/17_intro/headers/c++1998/complex.cc @@ -0,0 +1,26 @@ +// { dg-do compile } + +// Copyright (C) 2012 Free Software Foundation, Inc. +// +// This file is part of the GNU ISO C++ Library. This library is free +// software; you can redistribute it and/or modify it under the +// terms of the GNU General Public License as published by the +// Free Software Foundation; either version 3, or (at your option) +// any later version. + +// This 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 General Public License for more details. + +// You should have received a copy of the GNU General Public License along +// with this library; see the file COPYING3. If not see +// . + +// libstdc++/54112 +#include +#if _GLIBCXX_HAVE_COMPLEX_H +# include +#endif +#include +std::complex x; diff --git a/libstdc++-v3/testsuite/26_numerics/complex/c99.cc b/libstdc++-v3/testsuite/26_numerics/complex/c99.cc new file mode 100644 index 00000000000..59a9ef197dd --- /dev/null +++ b/libstdc++-v3/testsuite/26_numerics/complex/c99.cc @@ -0,0 +1,36 @@ +// { dg-do compile } +// { dg-options "-std=gnu++11" } + +// Copyright (C) 2012 Free Software Foundation, Inc. +// +// This file is part of the GNU ISO C++ Library. This library is free +// software; you can redistribute it and/or modify it under the +// terms of the GNU General Public License as published by the +// Free Software Foundation; either version 3, or (at your option) +// any later version. + +// This 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 General Public License for more details. + +// You should have received a copy of the GNU General Public License along +// with this library; see the file COPYING3. If not see +// . + +// libstdc++/54112 +#include +#if _GLIBCXX_HAVE_COMPLEX_H +# include +#endif + +int main() +{ + bool test __attribute__((unused)) = true; + +#if _GLIBCXX_HAVE_COMPLEX_H + double _Complex x = .5; + double _Complex y = cacos (x); + (void)y; +#endif +}