http://gcc.gnu.org/bugzilla/show_bug.cgi?id=52757
Bug #: 52757 Summary: [C++11] A lamba functions is not able to be used as a function pointer when passed as an explicit template argument Classification: Unclassified Product: gcc Version: 4.7.0 Status: UNCONFIRMED Severity: normal Priority: P3 Component: c++ AssignedTo: unassig...@gcc.gnu.org ReportedBy: metaprogrammingthewo...@gmail.com The following are two simple test-cases for what appears to be the same problem. The main issue is that you can't use a lambda function as a template argument where the template parameter type is a function pointer type. It seems that this happens because there is no constexpr conversion operator from the lambda function type to the corresponding function pointer type (in places where the pointer is not required to be a compile-time constant, the conversion works properly, as expected). First test-case: ////////// template< int (*)() > struct foo; typedef foo< [] { return 0; } > bar; ////////// main.cpp:2:31: error: could not convert template argument '{}' to 'int (*)()' main.cpp:2:36: error: invalid type in declaration before ';' token Second test-case (error message may shed light on the root of the problem): ////////// constexpr int (*foo)() = [] { return 0; }; ////////// main.cpp:1:41: error: '<lambda()>::operator int (*)()() const' is not a constexpr function