1 // Tests that we can merge the concept declarations with lambda well.
5 // RUN: split-file %s %t
7 // RUN: %clang_cc1 -std=c++20 %t/A.cppm -emit-module-interface -o %t/A.pcm
8 // RUN: %clang_cc1 -std=c++20 %t/A0.cppm -emit-module-interface -o %t/A0.pcm
9 // RUN: %clang_cc1 -std=c++20 %t/TestA.cpp -fprebuilt-module-path=%t -fsyntax-only -verify
11 // RUN: %clang_cc1 -std=c++20 %t/A1.cppm -emit-module-interface -o %t/A1.pcm
12 // RUN: %clang_cc1 -std=c++20 %t/TestA1.cpp -fprebuilt-module-path=%t -fsyntax-only -verify
14 // RUN: %clang_cc1 -std=c++20 %t/A2.cppm -emit-module-interface -o %t/A2.pcm
15 // RUN: %clang_cc1 -std=c++20 %t/TestA2.cpp -fprebuilt-module-path=%t -fsyntax-only -verify
17 // RUN: %clang_cc1 -std=c++20 %t/A3.cppm -emit-module-interface -o %t/A3.pcm
18 // RUN: %clang_cc1 -std=c++20 %t/TestA3.cpp -fprebuilt-module-path=%t -fsyntax-only -verify
22 concept A = requires(const _Tp& __t) { []<class __Up>(const __Up&) {}(__t); };
26 concept A = requires(const _Tp& __t) { []<class __Up>(__Up) {}(__t); };
30 concept A = requires(const _Tp& __t) { []<class __Up>(const __Up& __u) {
36 concept A = requires(const _Tp& __t) { [t = '?']<class __Up>(const __Up&) {
53 // expected-no-diagnostics
58 void f(C) requires(A<C>) {}
71 void f(C) requires(A<C>) {} // expected-error 1+{{reference to 'A' is ambiguous}}
72 // expected-note@* 1+{{candidate found by name lookup is 'A'}}
85 void f(C) requires(A<C>) {} // expected-error 1+{{reference to 'A' is ambiguous}}
86 // expected-note@* 1+{{candidate found by name lookup is 'A'}}
99 void f(C) requires(A<C>) {} // expected-error 1+{{reference to 'A' is ambiguous}}
100 // expected-note@* 1+{{candidate found by name lookup is 'A'}}