// 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 <auto> struct A {}; // #A
namespace t1 {
// notree-error@#1 {{no viable conversion from 'A<0>' to 'A<n + 1>'}}
/* tree-error@#1 {{no viable conversion
A<
[0 != n + 1]>}}*/
A<n + 1> 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<n>' to 'A<n + 1>'}}
/* tree-error@#2 {{no viable conversion
A<
[n != n + 1]>}}*/
A<n + 1> v2 = A<n>(); // #2
// expected-note@#A {{no known conversion from 'A<n>' to 'const A<&n[1]> &' for 1st argument}}
// expected-note@#A {{no known conversion from 'A<n>' to 'A<&n[1]> &&' for 1st argument}}
} // namespace t1
namespace t2 {
A<n> v1;
A<n + 1> v2;
// notree-note@#A {{no known conversion from 'A<n>' to 'const A<(no argument)>' for 1st argument}}
// notree-note@#A {{no known conversion from 'A<n>' 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