| // RUN: %clang_cc1 -std=c++14 -fsyntax-only -verify %s |
| |
| template <class> auto fn0 = [] {}; |
| template <typename> void foo0() { fn0<char>(); } |
| |
| template<typename T> auto fn1 = [](auto a) { return a + T(1); }; |
| template<typename T> auto v1 = [](int a = T(1)) { return a; }(); |
| |
| struct S { |
| template<class T> |
| static constexpr T t = [](int f = T(7)){return f;}(); // expected-error{{constexpr variable 't<int>' must be initialized by a constant expression}} expected-note{{cannot be used in a constant expression}} |
| }; |
| |
| template <typename X> |
| int foo2() { |
| X a = 0x61; |
| fn1<char>(a); |
| (void)v1<int>; |
| (void)S::t<int>; // expected-note{{in instantiation of static data member 'S::t<int>' requested here}} |
| return 0; |
| } |
| |
| template<class C> |
| int foo3() { |
| C::m1(); // expected-error{{type 'long long' cannot be used prior to '::' because it has no members}} |
| return 1; |
| } |
| |
| template<class C> |
| auto v2 = [](int a = foo3<C>()){}; // expected-note{{in instantiation of function template specialization 'foo3<long long>' requested here}} |
| |
| int main() { |
| v2<long long>(); // This line causes foo3<long long> to be instantiated. |
| v2<long long>(2); // This line does not. |
| foo2<int>(); |
| } |