// RUN: %clang_cc1 -fsyntax-only -verify -std=c++2a %s // Make sure we accept this templatestruct A{typedef X Y;}; templatebool operator==(A,typename A::Y); // expected-note{{candidate template ignored: could not match 'A' against 'B *'}} int a(A x) { return operator==(x,1); } int a0(A x) { return x == 1; } // FIXME: the location information for the note isn't very good templatestruct B{typedef X Y;}; templatebool operator==(B*,typename B::Y); // \ // expected-error{{overloaded 'operator==' must have at least one parameter of class or enumeration type}} \ // expected-note{{candidate template ignored: substitution failure [with X = int]}} int a(B x) { return operator==(&x,1); } // expected-error{{no matching function for call to 'operator=='}} \ // expected-note{{in instantiation of function template specialization}} // Ensure we take parameter list reversal into account in partial oredring. namespace CompareOrdering { template struct A {}; template int operator<=>(A, int) = delete; template int operator<=>(int, A); // OK, selects the more-specialized reversed function. bool b = A() < 0; }