From: Martin Sebor Date: Tue, 26 Apr 2016 22:57:34 +0000 (+0000) Subject: PR c++/66639 - declare __func__ , __FUNCTION__ & __PRETTY_FUNCTION__ constexpr X-Git-Tag: basepoints/gcc-8~7420 X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=8ac432938d3c29cc1fd25f8fe33a5dfefd9c2ff6;p=thirdparty%2Fgcc.git PR c++/66639 - declare __func__ , __FUNCTION__ & __PRETTY_FUNCTION__ constexpr PR c++/66639 - declare __func__ , __FUNCTION__ & __PRETTY_FUNCTION__ constexpr * g++.dg/cpp1y/func_constexpr.C: New test. From-SVN: r235458 --- diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index 8401206c7a0c..ecd3fa9519f7 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,8 @@ +2016-04-26 Martin Sebor + + PR c++/66639 + * g++.dg/cpp1y/func_constexpr.C: New test. + 2016-04-26 Patrick Palka PR c++/70241 diff --git a/gcc/testsuite/g++.dg/cpp1y/func_constexpr.C b/gcc/testsuite/g++.dg/cpp1y/func_constexpr.C new file mode 100644 index 000000000000..2edcd01980f4 --- /dev/null +++ b/gcc/testsuite/g++.dg/cpp1y/func_constexpr.C @@ -0,0 +1,29 @@ +// PR c++/66639 - declare __func__ , __FUNCTION__ & __PRETTY_FUNCTION__ +// as constexpr +// { dg-do compile { target c++11 } } + +#define Assert(expr) static_assert ((expr), #expr) +#define Compare(a, b) Assert (0 == __builtin_strcmp (a, b)) + +constexpr const char* func () +{ + return __func__; +} + +constexpr const char* function () +{ + return __FUNCTION__; +} + +constexpr const char* pretty_function () +{ + return __PRETTY_FUNCTION__; +} + +constexpr const char* f0 = func (); +constexpr const char* f1 = function (); +constexpr const char* f2 = pretty_function (); + +Compare (f0, "func"); +Compare (f1, "function"); +Compare (f2, "constexpr const char* pretty_function()");