// RUN: %clang_cc1 -std=c++2a -verify %s template constexpr bool is_same = false; template constexpr bool is_same = true; template struct DummyTemplate { }; void func() { auto L0 = [](T arg) { static_assert(is_same); // expected-error {{static assertion failed}} }; L0(0); L0(0.0); // expected-note {{in instantiation}} auto L1 = [] { static_assert(I == 5); // expected-error {{static assertion failed}} }; L1.operator()<5>(); L1.operator()<6>(); // expected-note {{in instantiation}} auto L2 = [] class T, class U>(T &&arg) { static_assert(is_same, DummyTemplate>); // // expected-error {{static assertion failed}} }; L2(DummyTemplate()); L2(DummyTemplate()); // expected-note {{in instantiation}} } template // expected-note {{declared here}} struct ShadowMe { void member_func() { auto L = [] { }; // expected-error {{'T' shadows template parameter}} } }; template constexpr T outer() { return []() { return x; }.template operator()<123>(); // expected-error {{no matching member function}} \ expected-note {{candidate template ignored}} } static_assert(outer() == 123); template int *outer(); // expected-note {{in instantiation}} namespace GH62611 { template struct C { static constexpr auto B = A; }; int test() { C<>::B(42); } namespace AutoParam { template auto B = A; static_assert(B<>(42) == 42); } namespace TypeParam { template auto B = T{}; static_assert(B<>(42) == 42); } } namespace GH64689 { void f(); void foo() { [](int) noexcept(requires(int t) { f(); }) -> decltype(requires(int t) { f(); }) requires requires(int t) { f(); } {return {};}.operator()(0); [](auto) noexcept(requires(int t) { f(); }) -> decltype(requires(int t) { f(); }) requires requires(int t) { f(); } {return {};}(1); } }