From: Paolo Carlini Date: Fri, 12 Oct 2012 08:30:00 +0000 (+0000) Subject: re PR c++/52744 (bad handling of member (function) pointers in template parameters) X-Git-Tag: misc/gccgo-go1_1_2~212 X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=bf90c4cd8e91c2e3d6dbb25af5ca31fba535fde1;p=thirdparty%2Fgcc.git re PR c++/52744 (bad handling of member (function) pointers in template parameters) 2012-10-12 Paolo Carlini PR c++/52744 * g++.dg/cpp0x/pr52744.C: New. From-SVN: r192392 --- diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index 0612d04351fa..9f3d29906f9a 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,8 @@ +2012-10-12 Paolo Carlini + + PR c++/52744 + * g++.dg/cpp0x/pr52744.C: New. + 2012-10-12 Janus Weil PR fortran/40453 diff --git a/gcc/testsuite/g++.dg/cpp0x/pr52744.C b/gcc/testsuite/g++.dg/cpp0x/pr52744.C new file mode 100644 index 000000000000..1a01fb2957f3 --- /dev/null +++ b/gcc/testsuite/g++.dg/cpp0x/pr52744.C @@ -0,0 +1,83 @@ +// PR c++/52744 +// { dg-do compile { target c++11 } } + +struct T +{ + int a; + void b(){} + int c(int) + { + return 1; + } +}; + +template struct member_helper; + +template +struct member_helper +{ + static const char* worker() + { + return "for members"; + } +}; + +template +struct member_helper +{ + static const char* worker() + { + return "for member functions returning non void"; + } +}; + +template +struct member_helper +{ + static const char* worker() + { + return "for member functions returning void"; + } +}; + +void member_test() +{ + member_helper::worker(); + member_helper::worker(); + member_helper::worker(); +} + +typedef void lua_State; + +template class function_helper +{ + static_assert(sizeof(T) != sizeof(T), + "Error: function_helper works with functions (duh)"); +}; + +template +struct function_helper +{ + static int wrapper(lua_State* l) + { + return 1; + } +}; + +template +struct function_helper +{ + static int wrapper(lua_State* l) + { + return 0; + } +}; + +int ciao(int){ return 0; } +void ciao2(int){} + +void function_test() +{ + function_helper::wrapper(0); + function_helper::wrapper(0); +}