// RUN: %clang_cc1 -fsyntax-only %s -std=c++26 -verify=expected,notree // RUN: %clang_cc1 -fsyntax-only %s -std=c++26 -fno-elide-type -verify=expected,notree // RUN: %clang_cc1 -fsyntax-only %s -std=c++26 -fdiagnostics-show-template-tree -verify=expected,tree // RUN: %clang_cc1 -fsyntax-only %s -std=c++26 -fno-elide-type -fdiagnostics-show-template-tree -verify=expected,tree namespace GH93068 { int n[2]; template struct A {}; // #A namespace t1 { // notree-error@#1 {{no viable conversion from 'A<0>' to 'A'}} /* tree-error@#1 {{no viable conversion A< [0 != n + 1]>}}*/ A v1 = A<0>(); // #1 // expected-note@#A {{no known conversion from 'A<0>' to 'const A<&n[1]> &' for 1st argument}} // expected-note@#A {{no known conversion from 'A<0>' to 'A<&n[1]> &&' for 1st argument}} // notree-error@#2 {{no viable conversion from 'A' to 'A'}} /* tree-error@#2 {{no viable conversion A< [n != n + 1]>}}*/ A v2 = A(); // #2 // expected-note@#A {{no known conversion from 'A' to 'const A<&n[1]> &' for 1st argument}} // expected-note@#A {{no known conversion from 'A' to 'A<&n[1]> &&' for 1st argument}} } // namespace t1 namespace t2 { A v1; A v2; // notree-note@#A {{no known conversion from 'A' to 'const A<(no argument)>' for 1st argument}} // notree-note@#A {{no known conversion from 'A' to 'A<(no argument)>' for 1st argument}} /* tree-note@#A {{no known conversion from argument type to parameter type for 1st argument [(no qualifiers) != const] A< [n != (no argument)]>}}*/ /* tree-note@#A {{no known conversion from argument type to parameter type for 1st argument A< [n != (no argument)]>}}*/ void f() { v2 = v1; } // expected-error {{no viable overloaded '='}} } // namespace t2 } // namespace GH93068