1bd851eecSMatheus Izvekov // RUN: not %clang_cc1 -fsyntax-only %s -std=c++11 2>&1 | FileCheck %s -check-prefix=CHECK-ELIDE-NOTREE 2bd851eecSMatheus Izvekov // RUN: not %clang_cc1 -fsyntax-only %s -fno-elide-type -std=c++11 2>&1 | FileCheck %s -check-prefix=CHECK-NOELIDE-NOTREE 3bd851eecSMatheus Izvekov // RUN: not %clang_cc1 -fsyntax-only %s -fdiagnostics-show-template-tree -std=c++11 2>&1 | FileCheck %s -check-prefix=CHECK-ELIDE-TREE 4bd851eecSMatheus Izvekov // RUN: not %clang_cc1 -fsyntax-only %s -fno-elide-type -fdiagnostics-show-template-tree -std=c++11 2>&1 | FileCheck %s -check-prefix=CHECK-NOELIDE-TREE 5bd851eecSMatheus Izvekov 6bd851eecSMatheus Izvekov // PR9548 - "no known conversion from 'vector<string>' to 'vector<string>'" 7bd851eecSMatheus Izvekov // vector<string> refers to two different types here. Make sure the message 8bd851eecSMatheus Izvekov // gives a way to tell them apart. 9bd851eecSMatheus Izvekov class versa_string; 10bd851eecSMatheus Izvekov typedef versa_string string; 11bd851eecSMatheus Izvekov 12bd851eecSMatheus Izvekov namespace std {template <typename T> class vector;} 13bd851eecSMatheus Izvekov using std::vector; 14bd851eecSMatheus Izvekov 15bd851eecSMatheus Izvekov void f(vector<string> v); 16bd851eecSMatheus Izvekov 17bd851eecSMatheus Izvekov namespace std { 18bd851eecSMatheus Izvekov class basic_string; 19bd851eecSMatheus Izvekov typedef basic_string string; 20bd851eecSMatheus Izvekov template <typename T> class vector {}; 21bd851eecSMatheus Izvekov void g() { 22bd851eecSMatheus Izvekov vector<string> v; 23bd851eecSMatheus Izvekov f(v); 24bd851eecSMatheus Izvekov } 25bd851eecSMatheus Izvekov } // end namespace std 26bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: no matching function for call to 'f' 27bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: candidate function not viable: no known conversion from 'vector<std::string>' to 'vector<string>' for 1st argument 28bd851eecSMatheus Izvekov // CHECK-NOELIDE-NOTREE: no matching function for call to 'f' 29bd851eecSMatheus Izvekov // CHECK-NOELIDE-NOTREE: candidate function not viable: no known conversion from 'vector<std::string>' to 'vector<string>' for 1st argument 30bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: no matching function for call to 'f' 31bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: candidate function not viable: no known conversion from argument type to parameter type for 1st argument 32bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: vector< 33bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: [std::string != string]> 34bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: no matching function for call to 'f' 35bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: candidate function not viable: no known conversion from argument type to parameter type for 1st argument 36bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: vector< 37bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: [std::string != string]> 38bd851eecSMatheus Izvekov 39bd851eecSMatheus Izvekov template <int... A> 40bd851eecSMatheus Izvekov class I1{}; 41bd851eecSMatheus Izvekov void set1(I1<1,2,3,4,2,3,4,3>) {}; 42bd851eecSMatheus Izvekov void test1() { 43bd851eecSMatheus Izvekov set1(I1<1,2,3,4,2,2,4,3,7>()); 44bd851eecSMatheus Izvekov } 45bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: no matching function for call to 'set1' 46bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: candidate function not viable: no known conversion from 'I1<[5 * ...], 2, [2 * ...], 7>' to 'I1<[5 * ...], 3, [2 * ...], (no argument)>' for 1st argument 47bd851eecSMatheus Izvekov // CHECK-NOELIDE-NOTREE: no matching function for call to 'set1' 48bd851eecSMatheus Izvekov // CHECK-NOELIDE-NOTREE: candidate function not viable: no known conversion from 'I1<1, 2, 3, 4, 2, 2, 4, 3, 7>' to 'I1<1, 2, 3, 4, 2, 3, 4, 3, (no argument)>' for 1st argument 49bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: no matching function for call to 'set1' 50bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: candidate function not viable: no known conversion from argument type to parameter type for 1st argument 51bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: I1< 52bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: [5 * ...], 53bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: [2 != 3], 54bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: [2 * ...], 55bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: [7 != (no argument)]> 56bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: no matching function for call to 'set1' 57bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: candidate function not viable: no known conversion from argument type to parameter type for 1st argument 58bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: I1< 59bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: 1, 60bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: 2, 61bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: 3, 62bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: 4, 63bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: 2, 64bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: [2 != 3], 65bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: 4, 66bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: 3, 67bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: [7 != (no argument)]> 68bd851eecSMatheus Izvekov 69bd851eecSMatheus Izvekov template <class A, class B, class C = void> 70bd851eecSMatheus Izvekov class I2{}; 71bd851eecSMatheus Izvekov void set2(I2<int, int>) {}; 72bd851eecSMatheus Izvekov void test2() { 73bd851eecSMatheus Izvekov set2(I2<double, int, int>()); 74bd851eecSMatheus Izvekov } 75bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: no matching function for call to 'set2' 76bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: candidate function not viable: no known conversion from 'I2<double, [...], int>' to 'I2<int, [...], (default) void>' for 1st argument 77bd851eecSMatheus Izvekov // CHECK-NOELIDE-NOTREE: no matching function for call to 'set2' 78bd851eecSMatheus Izvekov // CHECK-NOELIDE-NOTREE: candidate function not viable: no known conversion from 'I2<double, int, int>' to 'I2<int, int, (default) void>' for 1st argument 79bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: no matching function for call to 'set2' 80bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: candidate function not viable: no known conversion from argument type to parameter type for 1st argument 81bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: I2< 82bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: [double != int], 83bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: [...], 84bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: [int != (default) void]> 85bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: no matching function for call to 'set2' 86bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: candidate function not viable: no known conversion from argument type to parameter type for 1st argument 87bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: I2< 88bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: [double != int], 89bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: int, 90bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: [int != (default) void]> 91bd851eecSMatheus Izvekov 92bd851eecSMatheus Izvekov int V1, V2, V3; 93bd851eecSMatheus Izvekov template <int* A, int *B> 94bd851eecSMatheus Izvekov class I3{}; 95bd851eecSMatheus Izvekov void set3(I3<&V1, &V2>) {}; 96bd851eecSMatheus Izvekov void test3() { 97bd851eecSMatheus Izvekov set3(I3<&V3, &V2>()); 98bd851eecSMatheus Izvekov } 99bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: no matching function for call to 'set3' 100bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: candidate function not viable: no known conversion from 'I3<&V3, [...]>' to 'I3<&V1, [...]>' for 1st argument 101bd851eecSMatheus Izvekov // CHECK-NOELIDE-NOTREE: no matching function for call to 'set3' 102bd851eecSMatheus Izvekov // CHECK-NOELIDE-NOTREE: candidate function not viable: no known conversion from 'I3<&V3, &V2>' to 'I3<&V1, &V2>' for 1st argument 103bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: no matching function for call to 'set3' 104bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: candidate function not viable: no known conversion from argument type to parameter type for 1st argument 105bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: I3< 106bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: [&V3 != &V1] 107bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: [...]> 108bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: no matching function for call to 'set3' 109bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: candidate function not viable: no known conversion from argument type to parameter type for 1st argument 110bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: I3< 111bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: [&V3 != &V1] 112bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: &V2> 113bd851eecSMatheus Izvekov 114bd851eecSMatheus Izvekov template <class A, class B> 115bd851eecSMatheus Izvekov class Alpha{}; 116bd851eecSMatheus Izvekov template <class A, class B> 117bd851eecSMatheus Izvekov class Beta{}; 118bd851eecSMatheus Izvekov template <class A, class B> 119bd851eecSMatheus Izvekov class Gamma{}; 120bd851eecSMatheus Izvekov template <class A, class B> 121bd851eecSMatheus Izvekov class Delta{}; 122bd851eecSMatheus Izvekov 123bd851eecSMatheus Izvekov void set4(Alpha<int, int>); 124bd851eecSMatheus Izvekov void test4() { 125bd851eecSMatheus Izvekov set4(Beta<void, void>()); 126bd851eecSMatheus Izvekov } 127bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: no matching function for call to 'set4' 128bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: candidate function not viable: no known conversion from 'Beta<void, void>' to 'Alpha<int, int>' for 1st argument 129bd851eecSMatheus Izvekov // CHECK-NOELIDE-NOTREE: no matching function for call to 'set4' 130bd851eecSMatheus Izvekov // CHECK-NOELIDE-NOTREE: candidate function not viable: no known conversion from 'Beta<void, void>' to 'Alpha<int, int>' for 1st argument 131bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: no matching function for call to 'set4' 132bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: candidate function not viable: no known conversion from 'Beta<void, void>' to 'Alpha<int, int>' for 1st argument 133bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: no matching function for call to 'set4' 134bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: candidate function not viable: no known conversion from 'Beta<void, void>' to 'Alpha<int, int>' for 1st argument 135bd851eecSMatheus Izvekov 136bd851eecSMatheus Izvekov void set5(Alpha<Beta<Gamma<Delta<int, int>, int>, int>, int>); 137bd851eecSMatheus Izvekov void test5() { 138bd851eecSMatheus Izvekov set5(Alpha<Beta<Gamma<void, void>, double>, double>()); 139bd851eecSMatheus Izvekov } 140bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: no matching function for call to 'set5' 141bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: candidate function not viable: no known conversion from 'Alpha<Beta<Gamma<void, void>, double>, double>' to 'Alpha<Beta<Gamma<Delta<int, int>, int>, int>, int>' for 1st argument 142bd851eecSMatheus Izvekov // CHECK-NOELIDE-NOTREE: no matching function for call to 'set5' 143bd851eecSMatheus Izvekov // CHECK-NOELIDE-NOTREE: candidate function not viable: no known conversion from 'Alpha<Beta<Gamma<void, void>, double>, double>' to 'Alpha<Beta<Gamma<Delta<int, int>, int>, int>, int>' for 1st argument 144bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: no matching function for call to 'set5' 145bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: candidate function not viable: no known conversion from argument type to parameter type for 1st argument 146bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: Alpha< 147bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: Beta< 148bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: Gamma< 149bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: [void != Delta<int, int>], 150bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: [void != int]> 151bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: [double != int]> 152bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: [double != int]> 153bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: no matching function for call to 'set5' 154bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: candidate function not viable: no known conversion from argument type to parameter type for 1st argument 155bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: Alpha< 156bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: Beta< 157bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: Gamma< 158bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: [void != Delta<int, int>], 159bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: [void != int]> 160bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: [double != int]> 161bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: [double != int]> 162bd851eecSMatheus Izvekov 163bd851eecSMatheus Izvekov void test6() { 164bd851eecSMatheus Izvekov set5(Alpha<Beta<Delta<int, int>, int>, int>()); 165bd851eecSMatheus Izvekov } 166bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: no matching function for call to 'set5' 167bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: candidate function not viable: no known conversion from 'Alpha<Beta<Delta<int, int>, [...]>, [...]>' to 'Alpha<Beta<Gamma<Delta<int, int>, int>, [...]>, [...]>' for 1st argument 168bd851eecSMatheus Izvekov // CHECK-NOELIDE-NOTREE: no matching function for call to 'set5' 169bd851eecSMatheus Izvekov // CHECK-NOELIDE-NOTREE: candidate function not viable: no known conversion from 'Alpha<Beta<Delta<int, int>, int>, int>' to 'Alpha<Beta<Gamma<Delta<int, int>, int>, int>, int>' for 1st argument 170bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: no matching function for call to 'set5' 171bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: candidate function not viable: no known conversion from argument type to parameter type for 1st argument 172bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: Alpha< 173bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: Beta< 174bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: [Delta<int, int> != Gamma<Delta<int, int>, int>], 175bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: [...]> 176bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: [...]> 177bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: no matching function for call to 'set5' 178bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: candidate function not viable: no known conversion from argument type to parameter type for 1st argument 179bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: Alpha< 180bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: Beta< 181bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: [Delta<int, int> != Gamma<Delta<int, int>, int>], 182bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: int> 183bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: int> 184bd851eecSMatheus Izvekov 185bd851eecSMatheus Izvekov int a7, b7; 186bd851eecSMatheus Izvekov int c7[] = {1,2,3}; 187bd851eecSMatheus Izvekov template<int *A> 188bd851eecSMatheus Izvekov class class7 {}; 189bd851eecSMatheus Izvekov void set7(class7<&a7> A) {} 190bd851eecSMatheus Izvekov void test7() { 191bd851eecSMatheus Izvekov set7(class7<&a7>()); 192bd851eecSMatheus Izvekov set7(class7<&b7>()); 193bd851eecSMatheus Izvekov set7(class7<c7>()); 194bd851eecSMatheus Izvekov set7(class7<nullptr>()); 195bd851eecSMatheus Izvekov } 196bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: no matching function for call to 'set7' 197bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: candidate function not viable: no known conversion from 'class7<&b7>' to 'class7<&a7>' for 1st argument 198bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: no matching function for call to 'set7' 199bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: candidate function not viable: no known conversion from 'class7<c7>' to 'class7<&a7>' for 1st argument 200bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: no matching function for call to 'set7' 201bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: candidate function not viable: no known conversion from 'class7<nullptr>' to 'class7<&a7>' for 1st argument 202bd851eecSMatheus Izvekov // CHECK-NOELIDE-NOTREE: no matching function for call to 'set7' 203bd851eecSMatheus Izvekov // CHECK-NOELIDE-NOTREE: candidate function not viable: no known conversion from 'class7<&b7>' to 'class7<&a7>' for 1st argument 204bd851eecSMatheus Izvekov // CHECK-NOELIDE-NOTREE: no matching function for call to 'set7' 205bd851eecSMatheus Izvekov // CHECK-NOELIDE-NOTREE: candidate function not viable: no known conversion from 'class7<c7>' to 'class7<&a7>' for 1st argument 206bd851eecSMatheus Izvekov // CHECK-NOELIDE-NOTREE: no matching function for call to 'set7' 207bd851eecSMatheus Izvekov // CHECK-NOELIDE-NOTREE: candidate function not viable: no known conversion from 'class7<nullptr>' to 'class7<&a7>' for 1st argument 208bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: no matching function for call to 'set7' 209bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: candidate function not viable: no known conversion from argument type to parameter type for 1st argument 210bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: class7< 211bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: [&b7 != &a7]> 212bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: no matching function for call to 'set7' 213bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: candidate function not viable: no known conversion from argument type to parameter type for 1st argument 214bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: class7< 215bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: [c7 != &a7]> 216bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: no matching function for call to 'set7' 217bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: candidate function not viable: no known conversion from argument type to parameter type for 1st argument 218bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: class7< 219bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: [nullptr != &a7]> 220bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: no matching function for call to 'set7' 221bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: candidate function not viable: no known conversion from argument type to parameter type for 1st argument 222bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: class7< 223bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: [&b7 != &a7]> 224bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: no matching function for call to 'set7' 225bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: candidate function not viable: no known conversion from argument type to parameter type for 1st argument 226bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: class7< 227bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: [c7 != &a7]> 228bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: no matching function for call to 'set7' 229bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: candidate function not viable: no known conversion from argument type to parameter type for 1st argument 230bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: class7< 231bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: [nullptr != &a7]> 232bd851eecSMatheus Izvekov 233bd851eecSMatheus Izvekov template<typename ...T> struct S8 {}; 234bd851eecSMatheus Izvekov template<typename T> using U8 = S8<int, char, T>; 235bd851eecSMatheus Izvekov int f8(S8<int, char, double>); 236bd851eecSMatheus Izvekov int k8 = f8(U8<char>()); 237bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: no matching function for call to 'f8' 238bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: candidate function not viable: no known conversion from 'S8<[2 * ...], char>' to 'S8<[2 * ...], double>' for 1st argument 239bd851eecSMatheus Izvekov // CHECK-NOELIDE-NOTREE: no matching function for call to 'f8' 240bd851eecSMatheus Izvekov // CHECK-NOELIDE-NOTREE: candidate function not viable: no known conversion from 'S8<int, char, char>' to 'S8<int, char, double>' for 1st argument 241bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: no matching function for call to 'f8' 242bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: candidate function not viable: no known conversion from argument type to parameter type for 1st argument 243bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: S8< 244bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: [2 * ...], 245bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: [char != double]> 246bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: no matching function for call to 'f8' 247bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: candidate function not viable: no known conversion from argument type to parameter type for 1st argument 248bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: S8< 249bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: int, 250bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: char, 251bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: [char != double]> 252bd851eecSMatheus Izvekov 253bd851eecSMatheus Izvekov template<typename ...T> struct S9 {}; 254bd851eecSMatheus Izvekov template<typename T> using U9 = S9<int, char, T>; 255bd851eecSMatheus Izvekov template<typename T> using V9 = U9<U9<T>>; 256bd851eecSMatheus Izvekov int f9(S9<int, char, U9<const double>>); 257bd851eecSMatheus Izvekov int k9 = f9(V9<double>()); 258bd851eecSMatheus Izvekov 259bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: no matching function for call to 'f9' 260*7f78f99fSMatheus Izvekov // CHECK-ELIDE-NOTREE: candidate function not viable: no known conversion from 'S9<[2 * ...], U9<double>>' to 'S9<[2 * ...], U9<const double>>' for 1st argument 261bd851eecSMatheus Izvekov // CHECK-NOELIDE-NOTREE: no matching function for call to 'f9' 262*7f78f99fSMatheus Izvekov // CHECK-NOELIDE-NOTREE: candidate function not viable: no known conversion from 'S9<int, char, U9<double>>' to 'S9<int, char, U9<const double>>' for 1st argument 263bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: no matching function for call to 'f9' 264bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: candidate function not viable: no known conversion from argument type to parameter type for 1st argument 265bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: S9< 266bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: [2 * ...], 267*7f78f99fSMatheus Izvekov // CHECK-ELIDE-TREE: U9< 268*7f78f99fSMatheus Izvekov // CHECK-ELIDE-TREE: [(no qualifiers) != const] double>> 269bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: no matching function for call to 'f9' 270bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: candidate function not viable: no known conversion from argument type to parameter type for 1st argument 271bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: S9< 272bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: int, 273bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: char, 274*7f78f99fSMatheus Izvekov // CHECK-NOELIDE-TREE: U9< 275*7f78f99fSMatheus Izvekov // CHECK-NOELIDE-TREE: [(no qualifiers) != const] double>> 276bd851eecSMatheus Izvekov 277bd851eecSMatheus Izvekov template<typename ...A> class class_types {}; 278bd851eecSMatheus Izvekov void set10(class_types<int, int>) {} 279bd851eecSMatheus Izvekov void test10() { 280bd851eecSMatheus Izvekov set10(class_types<int>()); 281bd851eecSMatheus Izvekov set10(class_types<int, int, int>()); 282bd851eecSMatheus Izvekov } 283bd851eecSMatheus Izvekov 284bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: no matching function for call to 'set10' 285bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: candidate function not viable: no known conversion from 'class_types<[...], (no argument)>' to 'class_types<[...], int>' for 1st argument 286bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: no matching function for call to 'set10' 287bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: candidate function not viable: no known conversion from 'class_types<[2 * ...], int>' to 'class_types<[2 * ...], (no argument)>' for 1st argument 288bd851eecSMatheus Izvekov // CHECK-NOELIDE-NOTREE: no matching function for call to 'set10' 289bd851eecSMatheus Izvekov // CHECK-NOELIDE-NOTREE: candidate function not viable: no known conversion from 'class_types<int, (no argument)>' to 'class_types<int, int>' for 1st argument 290bd851eecSMatheus Izvekov // CHECK-NOELIDE-NOTREE: no matching function for call to 'set10' 291bd851eecSMatheus Izvekov // CHECK-NOELIDE-NOTREE: candidate function not viable: no known conversion from 'class_types<int, int, int>' to 'class_types<int, int, (no argument)>' for 1st argument 292bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: no matching function for call to 'set10' 293bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: candidate function not viable: no known conversion from argument type to parameter type for 1st argument 294bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: class_types< 295bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: [...], 296bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: [(no argument) != int]> 297bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: no matching function for call to 'set10' 298bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: candidate function not viable: no known conversion from argument type to parameter type for 1st argument 299bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: class_types< 300bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: [2 * ...], 301bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: [int != (no argument)]> 302bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: no matching function for call to 'set10' 303bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: candidate function not viable: no known conversion from argument type to parameter type for 1st argument 304bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: class_types< 305bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: int, 306bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: [(no argument) != int]> 307bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: no matching function for call to 'set10' 308bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: candidate function not viable: no known conversion from argument type to parameter type for 1st argument 309bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: class_types< 310bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: int, 311bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: int, 312bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: [int != (no argument)]> 313bd851eecSMatheus Izvekov 314bd851eecSMatheus Izvekov template<int ...A> class class_ints {}; 315bd851eecSMatheus Izvekov void set11(class_ints<2, 3>) {} 316bd851eecSMatheus Izvekov void test11() { 317bd851eecSMatheus Izvekov set11(class_ints<1>()); 318bd851eecSMatheus Izvekov set11(class_ints<0, 3, 6>()); 319bd851eecSMatheus Izvekov } 320bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: no matching function for call to 'set11' 321bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: candidate function not viable: no known conversion from 'class_ints<1, (no argument)>' to 'class_ints<2, 3>' for 1st argument 322bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: no matching function for call to 'set11' 323bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: candidate function not viable: no known conversion from 'class_ints<0, [...], 6>' to 'class_ints<2, [...], (no argument)>' for 1st argument 324bd851eecSMatheus Izvekov // CHECK-NOELIDE-NOTREE: no matching function for call to 'set11' 325bd851eecSMatheus Izvekov // CHECK-NOELIDE-NOTREE: candidate function not viable: no known conversion from 'class_ints<1, (no argument)>' to 'class_ints<2, 3>' for 1st argument 326bd851eecSMatheus Izvekov // CHECK-NOELIDE-NOTREE: no matching function for call to 'set11' 327bd851eecSMatheus Izvekov // CHECK-NOELIDE-NOTREE: candidate function not viable: no known conversion from 'class_ints<0, 3, 6>' to 'class_ints<2, 3, (no argument)>' for 1st argument 328bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: no matching function for call to 'set11' 329bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: candidate function not viable: no known conversion from argument type to parameter type for 1st argument 330bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: class_ints< 331bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: [1 != 2], 332bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: [(no argument) != 3]> 333bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: no matching function for call to 'set11' 334bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: candidate function not viable: no known conversion from argument type to parameter type for 1st argument 335bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: class_ints< 336bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: [0 != 2], 337bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: [...], 338bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: [6 != (no argument)]> 339bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: no matching function for call to 'set11' 340bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: candidate function not viable: no known conversion from argument type to parameter type for 1st argument 341bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: class_ints< 342bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: [1 != 2], 343bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: [(no argument) != 3]> 344bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: no matching function for call to 'set11' 345bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: candidate function not viable: no known conversion from argument type to parameter type for 1st argument 346bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: class_ints< 347bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: [0 != 2], 348bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: 3, 349bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: [6 != (no argument)]> 350bd851eecSMatheus Izvekov 351bd851eecSMatheus Izvekov template<template<class> class ...A> class class_template_templates {}; 352bd851eecSMatheus Izvekov template<class> class tt1 {}; 353bd851eecSMatheus Izvekov template<class> class tt2 {}; 354bd851eecSMatheus Izvekov void set12(class_template_templates<tt1, tt1>) {} 355bd851eecSMatheus Izvekov void test12() { 356bd851eecSMatheus Izvekov set12(class_template_templates<tt2>()); 357bd851eecSMatheus Izvekov set12(class_template_templates<tt1, tt1, tt1>()); 358bd851eecSMatheus Izvekov } 359bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: no matching function for call to 'set12' 360bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: candidate function not viable: no known conversion from 'class_template_templates<template tt2, template (no argument)>' to 'class_template_templates<template tt1, template tt1>' for 1st argument 361bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: no matching function for call to 'set12' 362bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: candidate function not viable: no known conversion from 'class_template_templates<[2 * ...], template tt1>' to 'class_template_templates<[2 * ...], template (no argument)>' for 1st argument 363bd851eecSMatheus Izvekov // CHECK-NOELIDE-NOTREE: no matching function for call to 'set12' 364bd851eecSMatheus Izvekov // CHECK-NOELIDE-NOTREE: candidate function not viable: no known conversion from 'class_template_templates<template tt2, template (no argument)>' to 'class_template_templates<template tt1, template tt1>' for 1st argument 365bd851eecSMatheus Izvekov // CHECK-NOELIDE-NOTREE: no matching function for call to 'set12' 366bd851eecSMatheus Izvekov // CHECK-NOELIDE-NOTREE: candidate function not viable: no known conversion from 'class_template_templates<template tt1, template tt1, template tt1>' to 'class_template_templates<template tt1, template tt1, template (no argument)>' for 1st argument 367bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: no matching function for call to 'set12' 368bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: candidate function not viable: no known conversion from argument type to parameter type for 1st argument 369bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: class_template_templates< 370bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: [template tt2 != template tt1], 371bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: [template (no argument) != template tt1]> 372bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: no matching function for call to 'set12' 373bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: candidate function not viable: no known conversion from argument type to parameter type for 1st argument 374bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: class_template_templates< 375bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: [2 * ...], 376bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: [template tt1 != template (no argument)]> 377bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: no matching function for call to 'set12' 378bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: candidate function not viable: no known conversion from argument type to parameter type for 1st argument 379bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: class_template_templates< 380bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: [template tt2 != template tt1], 381bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: [template (no argument) != template tt1]> 382bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: no matching function for call to 'set12' 383bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: candidate function not viable: no known conversion from argument type to parameter type for 1st argument 384bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: class_template_templates< 385bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: template tt1, 386bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: template tt1, 387bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: [template tt1 != template (no argument)]> 388bd851eecSMatheus Izvekov 389bd851eecSMatheus Izvekov double a13, b13, c13, d13; 390bd851eecSMatheus Izvekov template<double* ...A> class class_ptrs {}; 391bd851eecSMatheus Izvekov void set13(class_ptrs<&a13, &b13>) {} 392bd851eecSMatheus Izvekov void test13() { 393bd851eecSMatheus Izvekov set13(class_ptrs<&c13>()); 394bd851eecSMatheus Izvekov set13(class_ptrs<&a13, &b13, &d13>()); 395bd851eecSMatheus Izvekov } 396bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: no matching function for call to 'set13' 397bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: candidate function not viable: no known conversion from 'class_ptrs<&c13, (no argument)>' to 'class_ptrs<&a13, &b13>' for 1st argument 398bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: no matching function for call to 'set13' 399bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: candidate function not viable: no known conversion from 'class_ptrs<[2 * ...], &d13>' to 'class_ptrs<[2 * ...], (no argument)>' for 1st argument 400bd851eecSMatheus Izvekov // CHECK-NOELIDE-NOTREE: no matching function for call to 'set13' 401bd851eecSMatheus Izvekov // CHECK-NOELIDE-NOTREE: candidate function not viable: no known conversion from 'class_ptrs<&c13, (no argument)>' to 'class_ptrs<&a13, &b13>' for 1st argument 402bd851eecSMatheus Izvekov // CHECK-NOELIDE-NOTREE: no matching function for call to 'set13' 403bd851eecSMatheus Izvekov // CHECK-NOELIDE-NOTREE: candidate function not viable: no known conversion from 'class_ptrs<&a13, &b13, &d13>' to 'class_ptrs<&a13, &b13, (no argument)>' for 1st argument 404bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: no matching function for call to 'set13' 405bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: candidate function not viable: no known conversion from argument type to parameter type for 1st argument 406bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: class_ptrs< 407bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: [&c13 != &a13], 408bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: [(no argument) != &b13]> 409bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: no matching function for call to 'set13' 410bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: candidate function not viable: no known conversion from argument type to parameter type for 1st argument 411bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: class_ptrs< 412bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: [2 * ...], 413bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: [&d13 != (no argument)]> 414bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: no matching function for call to 'set13' 415bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: candidate function not viable: no known conversion from argument type to parameter type for 1st argument 416bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: class_ptrs< 417bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: [&c13 != &a13], 418bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: [(no argument) != &b13]> 419bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: no matching function for call to 'set13' 420bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: candidate function not viable: no known conversion from argument type to parameter type for 1st argument 421bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: class_ptrs< 422bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: &a13, 423bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: &b13, 424bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: [&d13 != (no argument)]> 425bd851eecSMatheus Izvekov 426bd851eecSMatheus Izvekov template<typename T> struct s14 {}; 427bd851eecSMatheus Izvekov template<typename T> using a14 = s14<T>; 428bd851eecSMatheus Izvekov typedef a14<int> b14; 429bd851eecSMatheus Izvekov template<typename T> using c14 = b14; 430bd851eecSMatheus Izvekov int f14(c14<int>); 431bd851eecSMatheus Izvekov int k14 = f14(a14<char>()); 432bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: no matching function for call to 'f14' 433bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: candidate function not viable: no known conversion from 'a14<char>' to 'a14<int>' for 1st argument 434bd851eecSMatheus Izvekov // CHECK-NOELIDE-NOTREE: no matching function for call to 'f14' 435bd851eecSMatheus Izvekov // CHECK-NOELIDE-NOTREE: candidate function not viable: no known conversion from 'a14<char>' to 'a14<int>' for 1st argument 436bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: no matching function for call to 'f14' 437bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: candidate function not viable: no known conversion from argument type to parameter type for 1st argument 438bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: a14< 439bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: [char != int]> 440bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: no matching function for call to 'f14' 441bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: candidate function not viable: no known conversion from argument type to parameter type for 1st argument 442bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: a14< 443bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: [char != int]> 444bd851eecSMatheus Izvekov 445bd851eecSMatheus Izvekov void set15(vector<vector<int>>) {} 446bd851eecSMatheus Izvekov void test15() { 447bd851eecSMatheus Izvekov set15(vector<vector<int>>()); 448bd851eecSMatheus Izvekov } 449bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE-NOT: set15 450bd851eecSMatheus Izvekov // CHECK-NOELIDE-NOTREE-NOT: set15 451bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE-NOT: set15 452bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE-NOT: set15 453bd851eecSMatheus Izvekov // no error here 454bd851eecSMatheus Izvekov 455bd851eecSMatheus Izvekov void set16(vector<const vector<int>>) {} 456bd851eecSMatheus Izvekov void test16() { 457bd851eecSMatheus Izvekov set16(vector<const vector<const int>>()); 458bd851eecSMatheus Izvekov } 459bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: no matching function for call to 'set16' 460bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: candidate function not viable: no known conversion from 'vector<const vector<const int>>' to 'vector<const vector<int>>' for 1st argument 461bd851eecSMatheus Izvekov // CHECK-NOELIDE-NOTREE: no matching function for call to 'set16' 462bd851eecSMatheus Izvekov // CHECK-NOELIDE-NOTREE: candidate function not viable: no known conversion from 'vector<const vector<const int>>' to 'vector<const vector<int>>' for 1st argument 463bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: no matching function for call to 'set16' 464bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: candidate function not viable: no known conversion from argument type to parameter type for 1st argument 465bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: vector< 466bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: const vector< 467bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: [const != (no qualifiers)] int>> 468bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: no matching function for call to 'set16' 469bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: candidate function not viable: no known conversion from argument type to parameter type for 1st argument 470bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: vector< 471bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: const vector< 472bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: [const != (no qualifiers)] int>> 473bd851eecSMatheus Izvekov 474bd851eecSMatheus Izvekov void set17(vector<vector<int>>) {} 475bd851eecSMatheus Izvekov void test17() { 476bd851eecSMatheus Izvekov set17(vector<const vector<int>>()); 477bd851eecSMatheus Izvekov } 478bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: no matching function for call to 'set17' 479bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: candidate function not viable: no known conversion from 'vector<const vector<...>>' to 'vector<vector<...>>' for 1st argument 480bd851eecSMatheus Izvekov // CHECK-NOELIDE-NOTREE: no matching function for call to 'set17' 481bd851eecSMatheus Izvekov // CHECK-NOELIDE-NOTREE: candidate function not viable: no known conversion from 'vector<const vector<int>>' to 'vector<vector<int>>' for 1st argument 482bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: no matching function for call to 'set17' 483bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: candidate function not viable: no known conversion from argument type to parameter type for 1st argument 484bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: vector< 485bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: [const != (no qualifiers)] vector<...>> 486bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: no matching function for call to 'set17' 487bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: candidate function not viable: no known conversion from argument type to parameter type for 1st argument 488bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: vector< 489bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: [const != (no qualifiers)] vector< 490bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: int>> 491bd851eecSMatheus Izvekov 492bd851eecSMatheus Izvekov void set18(vector<const vector<int>>) {} 493bd851eecSMatheus Izvekov void test18() { 494bd851eecSMatheus Izvekov set18(vector<vector<int>>()); 495bd851eecSMatheus Izvekov } 496bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: no matching function for call to 'set18' 497bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: candidate function not viable: no known conversion from 'vector<vector<...>>' to 'vector<const vector<...>>' for 1st argument 498bd851eecSMatheus Izvekov // CHECK-NOELIDE-NOTREE: no matching function for call to 'set18' 499bd851eecSMatheus Izvekov // CHECK-NOELIDE-NOTREE: candidate function not viable: no known conversion from 'vector<vector<int>>' to 'vector<const vector<int>>' for 1st argument 500bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: no matching function for call to 'set18' 501bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: candidate function not viable: no known conversion from argument type to parameter type for 1st argument 502bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: vector< 503bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: [(no qualifiers) != const] vector<...>> 504bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: no matching function for call to 'set18' 505bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: candidate function not viable: no known conversion from argument type to parameter type for 1st argument 506bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: vector< 507bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: [(no qualifiers) != const] vector< 508bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: int>> 509bd851eecSMatheus Izvekov 510bd851eecSMatheus Izvekov void set19(vector<volatile vector<int>>) {} 511bd851eecSMatheus Izvekov void test19() { 512bd851eecSMatheus Izvekov set19(vector<const vector<int>>()); 513bd851eecSMatheus Izvekov } 514bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: no matching function for call to 'set19' 515bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: candidate function not viable: no known conversion from 'vector<const vector<...>>' to 'vector<volatile vector<...>>' for 1st argument 516bd851eecSMatheus Izvekov // CHECK-NOELIDE-NOTREE: no matching function for call to 'set19' 517bd851eecSMatheus Izvekov // CHECK-NOELIDE-NOTREE: candidate function not viable: no known conversion from 'vector<const vector<int>>' to 'vector<volatile vector<int>>' for 1st argument 518bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: no matching function for call to 'set19' 519bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: candidate function not viable: no known conversion from argument type to parameter type for 1st argument 520bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: vector< 521bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: [const != volatile] vector<...>> 522bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: no matching function for call to 'set19' 523bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: candidate function not viable: no known conversion from argument type to parameter type for 1st argument 524bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: vector< 525bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: [const != volatile] vector< 526bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: int>> 527bd851eecSMatheus Izvekov 528bd851eecSMatheus Izvekov void set20(vector<const volatile vector<int>>) {} 529bd851eecSMatheus Izvekov void test20() { 530bd851eecSMatheus Izvekov set20(vector<const vector<int>>()); 531bd851eecSMatheus Izvekov } 532bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: no matching function for call to 'set20' 533bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: candidate function not viable: no known conversion from 'vector<const vector<...>>' to 'vector<const volatile vector<...>>' for 1st argument 534bd851eecSMatheus Izvekov // CHECK-NOELIDE-NOTREE: no matching function for call to 'set20' 535bd851eecSMatheus Izvekov // CHECK-NOELIDE-NOTREE: candidate function not viable: no known conversion from 'vector<const vector<int>>' to 'vector<const volatile vector<int>>' for 1st argument 536bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: no matching function for call to 'set20' 537bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: candidate function not viable: no known conversion from argument type to parameter type for 1st argument 538bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: vector< 539bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: [const != const volatile] vector<...>> 540bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: no matching function for call to 'set20' 541bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: candidate function not viable: no known conversion from argument type to parameter type for 1st argument 542bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: vector< 543bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: [const != const volatile] vector< 544bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: int>> 545bd851eecSMatheus Izvekov 546bd851eecSMatheus Izvekov 547bd851eecSMatheus Izvekov // Checks that volatile does not show up in diagnostics. 548bd851eecSMatheus Izvekov template<typename T> struct S21 {}; 549bd851eecSMatheus Izvekov template<typename T> using U21 = volatile S21<T>; 550bd851eecSMatheus Izvekov int f21(vector<const U21<int>>); 551bd851eecSMatheus Izvekov int k21 = f21(vector<U21<int>>()); 552bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: no matching function for call to 'f21' 553bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: candidate function not viable: no known conversion from 'vector<U21<...>>' to 'vector<const U21<...>>' for 1st argument 554bd851eecSMatheus Izvekov // CHECK-NOELIDE-NOTREE: no matching function for call to 'f21' 555bd851eecSMatheus Izvekov // CHECK-NOELIDE-NOTREE: candidate function not viable: no known conversion from 'vector<U21<int>>' to 'vector<const U21<int>>' for 1st argument 556bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: no matching function for call to 'f21' 557bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: candidate function not viable: no known conversion from argument type to parameter type for 1st argument 558bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: vector< 559bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: [(no qualifiers) != const] U21<...>> 560bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: no matching function for call to 'f21' 561bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: candidate function not viable: no known conversion from argument type to parameter type for 1st argument 562bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: vector< 563bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: [(no qualifiers) != const] U21< 564bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: int>> 565bd851eecSMatheus Izvekov 566bd851eecSMatheus Izvekov // Checks that volatile does not show up in diagnostics. 567bd851eecSMatheus Izvekov template<typename T> struct S22 {}; 568bd851eecSMatheus Izvekov template<typename T> using U22 = volatile S22<T>; 569bd851eecSMatheus Izvekov int f22(vector<volatile const U22<int>>); 570bd851eecSMatheus Izvekov int k22 = f22(vector<volatile U22<int>>()); 571bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: no matching function for call to 'f22' 572bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: candidate function not viable: no known conversion from 'vector<U22<...>>' to 'vector<const U22<...>>' for 1st argument 573bd851eecSMatheus Izvekov // CHECK-NOELIDE-NOTREE: no matching function for call to 'f22' 574bd851eecSMatheus Izvekov // CHECK-NOELIDE-NOTREE: candidate function not viable: no known conversion from 'vector<U22<int>>' to 'vector<const U22<int>>' for 1st argument 575bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: no matching function for call to 'f22' 576bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: candidate function not viable: no known conversion from argument type to parameter type for 1st argument 577bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: vector< 578bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: [(no qualifiers) != const] U22<...>> 579bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: no matching function for call to 'f22' 580bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: candidate function not viable: no known conversion from argument type to parameter type for 1st argument 581bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: vector< 582bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: [(no qualifiers) != const] U22< 583bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: int>> 584bd851eecSMatheus Izvekov 585bd851eecSMatheus Izvekov // Testing qualifiers and typedefs. 586bd851eecSMatheus Izvekov template <class T> struct D23{}; 587bd851eecSMatheus Izvekov template <class T> using C23 = D23<T>; 588bd851eecSMatheus Izvekov typedef const C23<int> B23; 589bd851eecSMatheus Izvekov template<class ...T> using A23 = B23; 590bd851eecSMatheus Izvekov 591bd851eecSMatheus Izvekov void foo23(D23<A23<>> b) {} 592bd851eecSMatheus Izvekov void test23() { 593bd851eecSMatheus Izvekov foo23(D23<D23<char>>()); 594bd851eecSMatheus Izvekov foo23(C23<char>()); 595bd851eecSMatheus Izvekov } 596bd851eecSMatheus Izvekov 597bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: no matching function for call to 'foo23' 598bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: candidate function not viable: no known conversion from 'D23<D23<char>>' to 'D23<const D23<int>>' for 1st argument 599bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: no matching function for call to 'foo23' 600bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: candidate function not viable: no known conversion from 'D23<char>' to 'D23<A23<>>' for 1st argument 601bd851eecSMatheus Izvekov // CHECK-NOELIDE-NOTREE: no matching function for call to 'foo23' 602bd851eecSMatheus Izvekov // CHECK-NOELIDE-NOTREE: candidate function not viable: no known conversion from 'D23<D23<char>>' to 'D23<const D23<int>>' for 1st argument 603bd851eecSMatheus Izvekov // CHECK-NOELIDE-NOTREE: no matching function for call to 'foo23' 604bd851eecSMatheus Izvekov // CHECK-NOELIDE-NOTREE: candidate function not viable: no known conversion from 'D23<char>' to 'D23<A23<>>' for 1st argument 605bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: no matching function for call to 'foo23' 606bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: candidate function not viable: no known conversion from argument type to parameter type for 1st argument 607bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: D23< 608bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: [(no qualifiers) != const] D23< 609bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: [char != int]>> 610bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: no matching function for call to 'foo23' 611bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: candidate function not viable: no known conversion from argument type to parameter type for 1st argument 612bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: D23< 613bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: [char != A23<>]> 614bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: no matching function for call to 'foo23' 615bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: candidate function not viable: no known conversion from argument type to parameter type for 1st argument 616bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: D23< 617bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: [(no qualifiers) != const] D23< 618bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: [char != int]>> 619bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: no matching function for call to 'foo23' 620bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: candidate function not viable: no known conversion from argument type to parameter type for 1st argument 621bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: D23< 622bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: [char != A23<>]> 623bd851eecSMatheus Izvekov 624bd851eecSMatheus Izvekov namespace PR14015 { 625bd851eecSMatheus Izvekov template <unsigned N> class Foo1 {}; 626bd851eecSMatheus Izvekov template <unsigned N = 2> class Foo2 {}; 627bd851eecSMatheus Izvekov template <unsigned ...N> class Foo3 {}; 628bd851eecSMatheus Izvekov 629bd851eecSMatheus Izvekov void Play1() { 630bd851eecSMatheus Izvekov Foo1<1> F1; 631bd851eecSMatheus Izvekov Foo1<2> F2, F3; 632bd851eecSMatheus Izvekov F2 = F1; 633bd851eecSMatheus Izvekov F1 = F2; 634bd851eecSMatheus Izvekov F2 = F3; 635bd851eecSMatheus Izvekov F3 = F2; 636bd851eecSMatheus Izvekov } 637bd851eecSMatheus Izvekov 638bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: no viable overloaded '=' 639bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: candidate function (the implicit copy assignment operator) not viable: no known conversion from 'Foo1<1>' to 'const Foo1<2>' for 1st argument 640bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: candidate function (the implicit move assignment operator) not viable: no known conversion from 'Foo1<1>' to 'Foo1<2>' for 1st argument 641bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: no viable overloaded '=' 642bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: candidate function (the implicit copy assignment operator) not viable: no known conversion from 'Foo1<2>' to 'const Foo1<1>' for 1st argument 643bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: candidate function (the implicit move assignment operator) not viable: no known conversion from 'Foo1<2>' to 'Foo1<1>' for 1st argument 644bd851eecSMatheus Izvekov // CHECK-NOELIDE-NOTREE: no viable overloaded '=' 645bd851eecSMatheus Izvekov // CHECK-NOELIDE-NOTREE: candidate function (the implicit copy assignment operator) not viable: no known conversion from 'Foo1<1>' to 'const Foo1<2>' for 1st argument 646bd851eecSMatheus Izvekov // CHECK-NOELIDE-NOTREE: candidate function (the implicit move assignment operator) not viable: no known conversion from 'Foo1<1>' to 'Foo1<2>' for 1st argument 647bd851eecSMatheus Izvekov // CHECK-NOELIDE-NOTREE: no viable overloaded '=' 648bd851eecSMatheus Izvekov // CHECK-NOELIDE-NOTREE: candidate function (the implicit copy assignment operator) not viable: no known conversion from 'Foo1<2>' to 'const Foo1<1>' for 1st argument 649bd851eecSMatheus Izvekov // CHECK-NOELIDE-NOTREE: candidate function (the implicit move assignment operator) not viable: no known conversion from 'Foo1<2>' to 'Foo1<1>' for 1st argument 650bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: no viable overloaded '=' 651bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: candidate function (the implicit copy assignment operator) not viable: no known conversion from argument type to parameter type for 1st argument 652bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: [(no qualifiers) != const] Foo1< 653bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: [1 != 2]> 654bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: candidate function (the implicit move assignment operator) not viable: no known conversion from argument type to parameter type for 1st argument 655bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: Foo1< 656bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: [1 != 2]> 657bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: no viable overloaded '=' 658bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: candidate function (the implicit copy assignment operator) not viable: no known conversion from argument type to parameter type for 1st argument 659bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: [(no qualifiers) != const] Foo1< 660bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: [2 != 1]> 661bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: candidate function (the implicit move assignment operator) not viable: no known conversion from argument type to parameter type for 1st argument 662bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: Foo1< 663bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: [2 != 1]> 664bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: no viable overloaded '=' 665bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: candidate function (the implicit copy assignment operator) not viable: no known conversion from argument type to parameter type for 1st argument 666bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: [(no qualifiers) != const] Foo1< 667bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: [1 != 2]> 668bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: candidate function (the implicit move assignment operator) not viable: no known conversion from argument type to parameter type for 1st argument 669bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: Foo1< 670bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: [1 != 2]> 671bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: no viable overloaded '=' 672bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: candidate function (the implicit copy assignment operator) not viable: no known conversion from argument type to parameter type for 1st argument 673bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: [(no qualifiers) != const] Foo1< 674bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: [2 != 1]> 675bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: candidate function (the implicit move assignment operator) not viable: no known conversion from argument type to parameter type for 1st argument 676bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: Foo1< 677bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: [2 != 1]> 678bd851eecSMatheus Izvekov 679bd851eecSMatheus Izvekov void Play2() { 680bd851eecSMatheus Izvekov Foo2<1> F1; 681bd851eecSMatheus Izvekov Foo2<> F2, F3; 682bd851eecSMatheus Izvekov F2 = F1; 683bd851eecSMatheus Izvekov F1 = F2; 684bd851eecSMatheus Izvekov F2 = F3; 685bd851eecSMatheus Izvekov F3 = F2; 686bd851eecSMatheus Izvekov } 687bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: no viable overloaded '=' 688bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: candidate function (the implicit copy assignment operator) not viable: no known conversion from 'Foo2<1>' to 'const Foo2<2>' for 1st argument 689bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: candidate function (the implicit move assignment operator) not viable: no known conversion from 'Foo2<1>' to 'Foo2<2>' for 1st argument 690bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: no viable overloaded '=' 691bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: candidate function (the implicit copy assignment operator) not viable: no known conversion from 'Foo2<(default) 2>' to 'const Foo2<1>' for 1st argument 692bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: candidate function (the implicit move assignment operator) not viable: no known conversion from 'Foo2<(default) 2>' to 'Foo2<1>' for 1st argument 693bd851eecSMatheus Izvekov // CHECK-NOELIDE-NOTREE: no viable overloaded '=' 694bd851eecSMatheus Izvekov // CHECK-NOELIDE-NOTREE: candidate function (the implicit copy assignment operator) not viable: no known conversion from 'Foo2<1>' to 'const Foo2<2>' for 1st argument 695bd851eecSMatheus Izvekov // CHECK-NOELIDE-NOTREE: candidate function (the implicit move assignment operator) not viable: no known conversion from 'Foo2<1>' to 'Foo2<2>' for 1st argument 696bd851eecSMatheus Izvekov // CHECK-NOELIDE-NOTREE: no viable overloaded '=' 697bd851eecSMatheus Izvekov // CHECK-NOELIDE-NOTREE: candidate function (the implicit copy assignment operator) not viable: no known conversion from 'Foo2<(default) 2>' to 'const Foo2<1>' for 1st argument 698bd851eecSMatheus Izvekov // CHECK-NOELIDE-NOTREE: candidate function (the implicit move assignment operator) not viable: no known conversion from 'Foo2<(default) 2>' to 'Foo2<1>' for 1st argument 699bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: no viable overloaded '=' 700bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: candidate function (the implicit copy assignment operator) not viable: no known conversion from argument type to parameter type for 1st argument 701bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: [(no qualifiers) != const] Foo2< 702bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: [1 != 2]> 703bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: candidate function (the implicit move assignment operator) not viable: no known conversion from argument type to parameter type for 1st argument 704bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: Foo2< 705bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: [1 != 2]> 706bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: no viable overloaded '=' 707bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: candidate function (the implicit copy assignment operator) not viable: no known conversion from argument type to parameter type for 1st argument 708bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: [(no qualifiers) != const] Foo2< 709bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: [(default) 2 != 1]> 710bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: candidate function (the implicit move assignment operator) not viable: no known conversion from argument type to parameter type for 1st argument 711bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: Foo2< 712bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: [(default) 2 != 1]> 713bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: no viable overloaded '=' 714bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: candidate function (the implicit copy assignment operator) not viable: no known conversion from argument type to parameter type for 1st argument 715bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: [(no qualifiers) != const] Foo2< 716bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: [1 != 2]> 717bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: candidate function (the implicit move assignment operator) not viable: no known conversion from argument type to parameter type for 1st argument 718bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: Foo2< 719bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: [1 != 2]> 720bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: no viable overloaded '=' 721bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: candidate function (the implicit copy assignment operator) not viable: no known conversion from argument type to parameter type for 1st argument 722bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: [(no qualifiers) != const] Foo2< 723bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: [(default) 2 != 1]> 724bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: candidate function (the implicit move assignment operator) not viable: no known conversion from argument type to parameter type for 1st argument 725bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: Foo2< 726bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: [(default) 2 != 1]> 727bd851eecSMatheus Izvekov 728bd851eecSMatheus Izvekov void Play3() { 729bd851eecSMatheus Izvekov Foo3<1> F1; 730bd851eecSMatheus Izvekov Foo3<2, 1> F2, F3; 731bd851eecSMatheus Izvekov F2 = F1; 732bd851eecSMatheus Izvekov F1 = F2; 733bd851eecSMatheus Izvekov F2 = F3; 734bd851eecSMatheus Izvekov F3 = F2; 735bd851eecSMatheus Izvekov } 736bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: no viable overloaded '=' 737bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: candidate function (the implicit copy assignment operator) not viable: no known conversion from 'Foo3<1, (no argument)>' to 'const Foo3<2, 1>' for 1st argument 738bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: candidate function (the implicit move assignment operator) not viable: no known conversion from 'Foo3<1, (no argument)>' to 'Foo3<2, 1>' for 1st argument 739bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: no viable overloaded '=' 740bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: candidate function (the implicit copy assignment operator) not viable: no known conversion from 'Foo3<2, 1>' to 'const Foo3<1, (no argument)>' for 1st argument 741bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: candidate function (the implicit move assignment operator) not viable: no known conversion from 'Foo3<2, 1>' to 'Foo3<1, (no argument)>' for 1st argument 742bd851eecSMatheus Izvekov // CHECK-NOELIDE-NOTREE: no viable overloaded '=' 743bd851eecSMatheus Izvekov // CHECK-NOELIDE-NOTREE: candidate function (the implicit copy assignment operator) not viable: no known conversion from 'Foo3<1, (no argument)>' to 'const Foo3<2, 1>' for 1st argument 744bd851eecSMatheus Izvekov // CHECK-NOELIDE-NOTREE: candidate function (the implicit move assignment operator) not viable: no known conversion from 'Foo3<1, (no argument)>' to 'Foo3<2, 1>' for 1st argument 745bd851eecSMatheus Izvekov // CHECK-NOELIDE-NOTREE: no viable overloaded '=' 746bd851eecSMatheus Izvekov // CHECK-NOELIDE-NOTREE: candidate function (the implicit copy assignment operator) not viable: no known conversion from 'Foo3<2, 1>' to 'const Foo3<1, (no argument)>' for 1st argument 747bd851eecSMatheus Izvekov // CHECK-NOELIDE-NOTREE: candidate function (the implicit move assignment operator) not viable: no known conversion from 'Foo3<2, 1>' to 'Foo3<1, (no argument)>' for 1st argument 748bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: no viable overloaded '=' 749bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: candidate function (the implicit copy assignment operator) not viable: no known conversion from argument type to parameter type for 1st argument 750bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: [(no qualifiers) != const] Foo3< 751bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: [1 != 2], 752bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: [(no argument) != 1]> 753bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: candidate function (the implicit move assignment operator) not viable: no known conversion from argument type to parameter type for 1st argument 754bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: Foo3< 755bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: [1 != 2], 756bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: [(no argument) != 1]> 757bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: no viable overloaded '=' 758bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: candidate function (the implicit copy assignment operator) not viable: no known conversion from argument type to parameter type for 1st argument 759bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: [(no qualifiers) != const] Foo3< 760bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: [2 != 1], 761bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: [1 != (no argument)]> 762bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: candidate function (the implicit move assignment operator) not viable: no known conversion from argument type to parameter type for 1st argument 763bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: Foo3< 764bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: [2 != 1], 765bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: [1 != (no argument)]> 766bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: no viable overloaded '=' 767bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: candidate function (the implicit copy assignment operator) not viable: no known conversion from argument type to parameter type for 1st argument 768bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: [(no qualifiers) != const] Foo3< 769bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: [1 != 2], 770bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: [(no argument) != 1]> 771bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: candidate function (the implicit move assignment operator) not viable: no known conversion from argument type to parameter type for 1st argument 772bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: Foo3< 773bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: [1 != 2], 774bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: [(no argument) != 1]> 775bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: no viable overloaded '=' 776bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: candidate function (the implicit copy assignment operator) not viable: no known conversion from argument type to parameter type for 1st argument 777bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: [(no qualifiers) != const] Foo3< 778bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: [2 != 1], 779bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: [1 != (no argument)]> 780bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: candidate function (the implicit move assignment operator) not viable: no known conversion from argument type to parameter type for 1st argument 781bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: Foo3< 782bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: [2 != 1], 783bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: [1 != (no argument)]> 784bd851eecSMatheus Izvekov } 785bd851eecSMatheus Izvekov 786bd851eecSMatheus Izvekov namespace PR14342 { 787bd851eecSMatheus Izvekov template<typename T, short a> struct X {}; 788bd851eecSMatheus Izvekov X<int, (signed char)-1> x = X<long, -1>(); 789bd851eecSMatheus Izvekov X<int, 3UL> y = X<int, 2>(); 790bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: error: no viable conversion from 'X<long, [...]>' to 'X<int, [...]>' 791bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: error: no viable conversion from 'X<[...], 2>' to 'X<[...], 3>' 792bd851eecSMatheus Izvekov } 793bd851eecSMatheus Izvekov 794bd851eecSMatheus Izvekov namespace PR14489 { 795bd851eecSMatheus Izvekov // The important thing here is that the diagnostic diffs a template specialization 796bd851eecSMatheus Izvekov // with no arguments against itself. (We might need a different test if this 797bd851eecSMatheus Izvekov // diagnostic changes). 798bd851eecSMatheus Izvekov template<class ...V> 799bd851eecSMatheus Izvekov struct VariableList { 800bd851eecSMatheus Izvekov void ConnectAllToAll(VariableList<>& params = VariableList<>()) { 801bd851eecSMatheus Izvekov } 802bd851eecSMatheus Izvekov }; 803bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: non-const lvalue reference to type 'VariableList<>' cannot bind to a temporary of type 'VariableList<>' 804bd851eecSMatheus Izvekov } 805bd851eecSMatheus Izvekov 806bd851eecSMatheus Izvekov namespace rdar12456626 { 807bd851eecSMatheus Izvekov struct IntWrapper { 808bd851eecSMatheus Izvekov typedef int type; 809bd851eecSMatheus Izvekov }; 810bd851eecSMatheus Izvekov 811bd851eecSMatheus Izvekov template<typename T, typename T::type V> 812bd851eecSMatheus Izvekov struct X { }; 813bd851eecSMatheus Izvekov 814bd851eecSMatheus Izvekov struct A { 815bd851eecSMatheus Izvekov virtual X<IntWrapper, 1> foo(); 816bd851eecSMatheus Izvekov }; 817bd851eecSMatheus Izvekov 818bd851eecSMatheus Izvekov struct B : A { 819bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: virtual function 'foo' has a different return type 820bd851eecSMatheus Izvekov virtual X<IntWrapper, 2> foo(); 821bd851eecSMatheus Izvekov }; 822bd851eecSMatheus Izvekov } 823bd851eecSMatheus Izvekov 824bd851eecSMatheus Izvekov namespace PR15023 { 825bd851eecSMatheus Izvekov // Don't crash when non-QualTypes are passed to a diff modifier. 826bd851eecSMatheus Izvekov template <typename... Args> 827bd851eecSMatheus Izvekov void func(void (*func)(Args...), Args...) { } 828bd851eecSMatheus Izvekov 829bd851eecSMatheus Izvekov void bar(int, int &) { 830bd851eecSMatheus Izvekov } 831bd851eecSMatheus Izvekov 832bd851eecSMatheus Izvekov void foo(int x) { 833bd851eecSMatheus Izvekov func(bar, 1, x) 834bd851eecSMatheus Izvekov } 835bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: no matching function for call to 'func' 836bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: candidate template ignored: deduced conflicting types for parameter 'Args' (<int, int &> vs. <int, int>) 837bd851eecSMatheus Izvekov } 838bd851eecSMatheus Izvekov 839bd851eecSMatheus Izvekov namespace rdar12931988 { 840bd851eecSMatheus Izvekov namespace A { 841bd851eecSMatheus Izvekov template<typename T> struct X { }; 842bd851eecSMatheus Izvekov } 843bd851eecSMatheus Izvekov 844bd851eecSMatheus Izvekov namespace B { 845bd851eecSMatheus Izvekov template<typename T> struct X { }; 846bd851eecSMatheus Izvekov } 847bd851eecSMatheus Izvekov 848bd851eecSMatheus Izvekov void foo(A::X<int> &ax, B::X<int> bx) { 849bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: no viable overloaded '=' 850bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: no known conversion from 'B::X<int>' to 'const X<int>' 851bd851eecSMatheus Izvekov ax = bx; 852bd851eecSMatheus Izvekov } 853bd851eecSMatheus Izvekov 854bd851eecSMatheus Izvekov template<template<typename> class> class Y {}; 855bd851eecSMatheus Izvekov 856bd851eecSMatheus Izvekov void bar(Y<A::X> ya, Y<B::X> yb) { 857bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: no viable overloaded '=' 858bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: no known conversion from 'Y<template rdar12931988::B::X>' to 'Y<template rdar12931988::A::X>' 859bd851eecSMatheus Izvekov ya = yb; 860bd851eecSMatheus Izvekov } 861bd851eecSMatheus Izvekov } 862bd851eecSMatheus Izvekov 863bd851eecSMatheus Izvekov namespace ValueDecl { 864bd851eecSMatheus Izvekov int int1, int2, default_int; 865bd851eecSMatheus Izvekov template <const int& T = default_int> 866bd851eecSMatheus Izvekov struct S {}; 867bd851eecSMatheus Izvekov 868bd851eecSMatheus Izvekov typedef S<int1> T1; 869bd851eecSMatheus Izvekov typedef S<int2> T2; 870bd851eecSMatheus Izvekov typedef S<> TD; 871bd851eecSMatheus Izvekov 872bd851eecSMatheus Izvekov void test() { 873bd851eecSMatheus Izvekov T1 t1; 874bd851eecSMatheus Izvekov T2 t2; 875bd851eecSMatheus Izvekov TD td; 876bd851eecSMatheus Izvekov 877bd851eecSMatheus Izvekov t1 = t2; 878bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: no viable overloaded '=' 879bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: no known conversion from 'S<int2>' to 'S<int1>' 880bd851eecSMatheus Izvekov 881bd851eecSMatheus Izvekov t2 = t1; 882bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: no viable overloaded '=' 883bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: no known conversion from 'S<int1>' to 'S<int2>' 884bd851eecSMatheus Izvekov 885bd851eecSMatheus Izvekov td = t1; 886bd851eecSMatheus Izvekov // TODO: Find out why (default) isn't printed on second template. 887bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: no viable overloaded '=' 888bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: no known conversion from 'S<int1>' to 'S<default_int>' 889bd851eecSMatheus Izvekov 890bd851eecSMatheus Izvekov t2 = td; 891bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: no viable overloaded '=' 892bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: no known conversion from 'S<(default) default_int>' to 'S<int2>' 893bd851eecSMatheus Izvekov 894bd851eecSMatheus Izvekov } 895bd851eecSMatheus Izvekov } 896bd851eecSMatheus Izvekov 897bd851eecSMatheus Izvekov namespace DependentDefault { 898bd851eecSMatheus Izvekov template <typename> struct Trait { 899bd851eecSMatheus Izvekov enum { V = 40 }; 900bd851eecSMatheus Izvekov typedef int Ty; 901bd851eecSMatheus Izvekov static int I; 902bd851eecSMatheus Izvekov }; 903bd851eecSMatheus Izvekov int other; 904bd851eecSMatheus Izvekov 905bd851eecSMatheus Izvekov template <typename T, int = Trait<T>::V > struct A {}; 906bd851eecSMatheus Izvekov template <typename T, typename = Trait<T>::Ty > struct B {}; 907bd851eecSMatheus Izvekov template <typename T, int& = Trait<T>::I > struct C {}; 908bd851eecSMatheus Izvekov 909bd851eecSMatheus Izvekov void test() { 910bd851eecSMatheus Izvekov 911bd851eecSMatheus Izvekov A<int> a1; 912bd851eecSMatheus Izvekov A<char> a2; 913bd851eecSMatheus Izvekov A<int, 10> a3; 914bd851eecSMatheus Izvekov a1 = a2; 915bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: no viable overloaded '=' 916bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: no known conversion from 'A<char, [...]>' to 'A<int, [...]>' 917bd851eecSMatheus Izvekov a3 = a1; 918bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: no viable overloaded '=' 919bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: no known conversion from 'A<[...], (default) Trait<T>::V aka 40>' to 'A<[...], 10>' 920bd851eecSMatheus Izvekov a2 = a3; 921bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: no viable overloaded '=' 922bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: no known conversion from 'A<int, 10>' to 'A<char, 40>' 923bd851eecSMatheus Izvekov 924bd851eecSMatheus Izvekov B<int> b1; 925bd851eecSMatheus Izvekov B<char> b2; 926bd851eecSMatheus Izvekov B<int, char> b3; 927bd851eecSMatheus Izvekov b1 = b2; 928bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: no viable overloaded '=' 929bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: no known conversion from 'B<char, [...]>' to 'B<int, [...]>' 930bd851eecSMatheus Izvekov b3 = b1; 931bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: no viable overloaded '=' 932bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: no known conversion from 'B<[...], (default) int>' to 'B<[...], char>' 933bd851eecSMatheus Izvekov b2 = b3; 934bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: no viable overloaded '=' 935bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: no known conversion from 'B<int, char>' to 'B<char, int>' 936bd851eecSMatheus Izvekov 937bd851eecSMatheus Izvekov C<int> c1; 938bd851eecSMatheus Izvekov C<char> c2; 939bd851eecSMatheus Izvekov C<int, other> c3; 940bd851eecSMatheus Izvekov c1 = c2; 941bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: no viable overloaded '=' 942bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: no known conversion from 'C<char, (default) I>' to 'C<int, I>' 943bd851eecSMatheus Izvekov c3 = c1; 944bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: no viable overloaded '=' 945bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: no known conversion from 'C<[...], (default) I>' to 'C<[...], other>' 946bd851eecSMatheus Izvekov c2 = c3; 947bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: no viable overloaded '=' 948bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: no known conversion from 'C<int, other>' to 'C<char, I>' 949bd851eecSMatheus Izvekov } 950bd851eecSMatheus Izvekov } 951bd851eecSMatheus Izvekov 952bd851eecSMatheus Izvekov namespace VariadicDefault { 953bd851eecSMatheus Izvekov int i1, i2, i3; 954bd851eecSMatheus Izvekov template <int = 5, int...> struct A {}; 955bd851eecSMatheus Izvekov template <int& = i1, int& ...> struct B {}; 956bd851eecSMatheus Izvekov template <typename = void, typename...> struct C {}; 957bd851eecSMatheus Izvekov 958bd851eecSMatheus Izvekov void test() { 959bd851eecSMatheus Izvekov A<> a1; 960bd851eecSMatheus Izvekov A<5, 6, 7> a2; 961bd851eecSMatheus Izvekov A<1, 2> a3; 962bd851eecSMatheus Izvekov a2 = a1; 963bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: no viable overloaded '=' 964bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: no known conversion from 'A<[...], (no argument), (no argument)>' to 'A<[...], 6, 7>' 965bd851eecSMatheus Izvekov a3 = a1; 966bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: no viable overloaded '=' 967bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: no known conversion from 'A<(default) 5, (no argument)>' to 'A<1, 2>' 968bd851eecSMatheus Izvekov 969bd851eecSMatheus Izvekov B<> b1; 970bd851eecSMatheus Izvekov B<i1, i2, i3> b2; 971bd851eecSMatheus Izvekov B<i2, i3> b3; 972bd851eecSMatheus Izvekov b2 = b1; 973bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: no viable overloaded '=' 974bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: no known conversion from 'B<[...], (no argument), (no argument)>' to 'B<[...], i2, i3>' 975bd851eecSMatheus Izvekov b3 = b1; 976bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: no viable overloaded '=' 977bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: no known conversion from 'B<(default) i1, (no argument)>' to 'B<i2, i3>' 978bd851eecSMatheus Izvekov 979bd851eecSMatheus Izvekov B<i1, i2, i3> b4 = b1; 980bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: no viable conversion from 'B<[...], (no argument), (no argument)>' to 'B<[...], i2, i3>' 981bd851eecSMatheus Izvekov B<i2, i3> b5 = b1; 982bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: no viable conversion from 'B<(default) i1, (no argument)>' to 'B<i2, i3>' 983bd851eecSMatheus Izvekov 984bd851eecSMatheus Izvekov C<> c1; 985bd851eecSMatheus Izvekov C<void, void> c2; 986bd851eecSMatheus Izvekov C<char, char> c3; 987bd851eecSMatheus Izvekov c2 = c1; 988bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: no viable overloaded '=' 989bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: no known conversion from 'C<[...], (no argument)>' to 'C<[...], void>' 990bd851eecSMatheus Izvekov c3 = c1; 991bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: no viable overloaded '=' 992bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: no known conversion from 'C<(default) void, (no argument)>' to 'C<char, char>' 993bd851eecSMatheus Izvekov } 994bd851eecSMatheus Izvekov } 995bd851eecSMatheus Izvekov 996bd851eecSMatheus Izvekov namespace PointerArguments { 997bd851eecSMatheus Izvekov template <int *p> class T {}; 998bd851eecSMatheus Izvekov template <int* ...> class U {}; 999bd851eecSMatheus Izvekov int a, b, c; 1000bd851eecSMatheus Izvekov int z[5]; 1001bd851eecSMatheus Izvekov void test() { 1002bd851eecSMatheus Izvekov T<&a> ta; 1003bd851eecSMatheus Izvekov T<z> tz; 1004bd851eecSMatheus Izvekov T<&b> tb(ta); 1005bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: no matching constructor for initialization of 'T<&b>' 1006bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: candidate constructor (the implicit copy constructor) not viable: no known conversion from 'T<&a>' to 'const T<&b>' for 1st argument 1007bd851eecSMatheus Izvekov T<&c> tc(tz); 1008bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: no matching constructor for initialization of 'T<&c>' 1009bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: candidate constructor (the implicit copy constructor) not viable: no known conversion from 'T<z>' to 'const T<&c>' for 1st argument 1010bd851eecSMatheus Izvekov 1011bd851eecSMatheus Izvekov U<&a, &a> uaa; 1012bd851eecSMatheus Izvekov U<&b> ub(uaa); 1013bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: no matching constructor for initialization of 'U<&b>' 1014bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: candidate constructor (the implicit copy constructor) not viable: no known conversion from 'U<&a, &a>' to 'const U<&b, (no argument)>' for 1st argument 1015bd851eecSMatheus Izvekov 1016bd851eecSMatheus Izvekov U<&b, &b, &b> ubbb(uaa); 1017bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: no matching constructor for initialization of 'U<&b, &b, &b>' 1018bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: candidate constructor (the implicit copy constructor) not viable: no known conversion from 'U<&a, &a, (no argument)>' to 'const U<&b, &b, &b>' for 1st argument 1019bd851eecSMatheus Izvekov 1020bd851eecSMatheus Izvekov } 1021bd851eecSMatheus Izvekov } 1022bd851eecSMatheus Izvekov 1023bd851eecSMatheus Izvekov namespace DependentInt { 1024bd851eecSMatheus Izvekov template<int Num> struct INT; 1025bd851eecSMatheus Izvekov 1026bd851eecSMatheus Izvekov template <class CLASS, class Int_wrapper = INT<CLASS::val> > 1027bd851eecSMatheus Izvekov struct C; 1028bd851eecSMatheus Izvekov 1029bd851eecSMatheus Izvekov struct N { 1030bd851eecSMatheus Izvekov static const int val = 1; 1031bd851eecSMatheus Izvekov }; 1032bd851eecSMatheus Izvekov 1033bd851eecSMatheus Izvekov template <class M_T> 1034bd851eecSMatheus Izvekov struct M {}; 1035bd851eecSMatheus Izvekov 1036bd851eecSMatheus Izvekov void test() { 1037bd851eecSMatheus Izvekov using T1 = M<C<int, INT<0>>>; 1038bd851eecSMatheus Izvekov using T2 = M<C<N>>; 1039bd851eecSMatheus Izvekov T2 p; 1040bd851eecSMatheus Izvekov T1 x = p; 1041bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: no viable conversion from 'M<C<N, INT<1>>>' to 'M<C<int, INT<0>>>' 1042bd851eecSMatheus Izvekov } 1043bd851eecSMatheus Izvekov } 1044bd851eecSMatheus Izvekov 1045bd851eecSMatheus Izvekov namespace PR17510 { 1046bd851eecSMatheus Izvekov class Atom; 1047bd851eecSMatheus Izvekov 1048bd851eecSMatheus Izvekov template <typename T> class allocator; 1049bd851eecSMatheus Izvekov template <typename T, typename A> class vector; 1050bd851eecSMatheus Izvekov 1051bd851eecSMatheus Izvekov typedef vector<const Atom *, allocator<const Atom *> > AtomVector; 1052bd851eecSMatheus Izvekov 1053bd851eecSMatheus Izvekov template <typename T, typename A = allocator<const Atom *> > class vector {}; 1054bd851eecSMatheus Izvekov 1055bd851eecSMatheus Izvekov void foo() { 1056bd851eecSMatheus Izvekov vector<Atom *> v; 1057bd851eecSMatheus Izvekov AtomVector v2(v); 1058bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: no known conversion from 'vector<Atom *, [...]>' to 'const vector<const PR17510::Atom *, [...]>' 1059bd851eecSMatheus Izvekov } 1060bd851eecSMatheus Izvekov } 1061bd851eecSMatheus Izvekov 1062bd851eecSMatheus Izvekov namespace PR15677 { 1063bd851eecSMatheus Izvekov template <bool> 1064bd851eecSMatheus Izvekov struct A{}; 1065bd851eecSMatheus Izvekov 1066bd851eecSMatheus Izvekov template <typename T> 1067bd851eecSMatheus Izvekov using B = A<T::value>; 1068bd851eecSMatheus Izvekov 1069bd851eecSMatheus Izvekov template <typename T> 1070bd851eecSMatheus Izvekov using B = A<!T::value>; 1071bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: type alias template redefinition with different types ('A<!T::value>' vs 'A<T::value>') 1072bd851eecSMatheus Izvekov 1073bd851eecSMatheus Izvekov template <int> 1074bd851eecSMatheus Izvekov struct C{}; 1075bd851eecSMatheus Izvekov 1076bd851eecSMatheus Izvekov template <typename T> 1077bd851eecSMatheus Izvekov using D = C<T::value>; 1078bd851eecSMatheus Izvekov 1079bd851eecSMatheus Izvekov template <typename T> 1080bd851eecSMatheus Izvekov using D = C<T::value + 1>; 1081bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: type alias template redefinition with different types ('C<T::value + 1>' vs 'C<T::value>') 1082bd851eecSMatheus Izvekov 1083bd851eecSMatheus Izvekov template <typename T> 1084bd851eecSMatheus Izvekov using E = C<T::value>; 1085bd851eecSMatheus Izvekov 1086bd851eecSMatheus Izvekov template <typename T> 1087bd851eecSMatheus Izvekov using E = C<42>; 1088bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: type alias template redefinition with different types ('C<42>' vs 'C<T::value>') 1089bd851eecSMatheus Izvekov 1090bd851eecSMatheus Izvekov template <typename T> 1091bd851eecSMatheus Izvekov using F = C<T::value>; 1092bd851eecSMatheus Izvekov 1093bd851eecSMatheus Izvekov template <typename T> 1094bd851eecSMatheus Izvekov using F = C<21 + 21>; 1095bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: type alias template redefinition with different types ('C<21 + 21 aka 42>' vs 'C<T::value>') 1096bd851eecSMatheus Izvekov } 1097bd851eecSMatheus Izvekov } 1098bd851eecSMatheus Izvekov 1099bd851eecSMatheus Izvekov namespace AddressOf { 1100bd851eecSMatheus Izvekov template <int*> 1101bd851eecSMatheus Izvekov struct S {}; 1102bd851eecSMatheus Izvekov 1103bd851eecSMatheus Izvekov template <class T> 1104bd851eecSMatheus Izvekov struct Wrapper {}; 1105bd851eecSMatheus Izvekov 1106bd851eecSMatheus Izvekov template <class T> 1107bd851eecSMatheus Izvekov Wrapper<T> MakeWrapper(); 1108bd851eecSMatheus Izvekov int global, global2; 1109bd851eecSMatheus Izvekov constexpr int * ptr = nullptr; 1110bd851eecSMatheus Izvekov Wrapper<S<ptr>> W = MakeWrapper<S<&global>>(); 1111bd851eecSMatheus Izvekov // Don't print an extra '&' for 'ptr' 1112bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: no viable conversion from 'Wrapper<S<&global>>' to 'Wrapper<S<ptr aka nullptr>>' 1113bd851eecSMatheus Izvekov 1114bd851eecSMatheus Izvekov // Handle parens correctly 1115bd851eecSMatheus Izvekov Wrapper<S<(&global2)>> W2 = MakeWrapper<S<&global>>(); 1116bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: no viable conversion from 'Wrapper<S<&global>>' to 'Wrapper<S<&global2>>' 1117bd851eecSMatheus Izvekov Wrapper<S<&global2>> W3 = MakeWrapper<S<(&global)>>(); 1118bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: no viable conversion from 'Wrapper<S<&global>>' to 'Wrapper<S<&global2>>' 1119bd851eecSMatheus Izvekov Wrapper<S<(&global2)>> W4 = MakeWrapper<S<(&global)>>(); 1120bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: no viable conversion from 'Wrapper<S<&global>>' to 'Wrapper<S<&global2>>' 1121bd851eecSMatheus Izvekov } 1122bd851eecSMatheus Izvekov 1123bd851eecSMatheus Izvekov namespace NullPtr { 1124bd851eecSMatheus Izvekov template <int*, int*> 1125bd851eecSMatheus Izvekov struct S {}; 1126bd851eecSMatheus Izvekov 1127bd851eecSMatheus Izvekov template <class T> 1128bd851eecSMatheus Izvekov struct Wrapper {}; 1129bd851eecSMatheus Izvekov 1130bd851eecSMatheus Izvekov template <class T> 1131bd851eecSMatheus Izvekov Wrapper<T> MakeWrapper(); 1132bd851eecSMatheus Izvekov int global, global2; 1133bd851eecSMatheus Izvekov constexpr int * ptr = nullptr; 1134bd851eecSMatheus Izvekov constexpr int * ptr2 = static_cast<int*>(0); 1135bd851eecSMatheus Izvekov 1136bd851eecSMatheus Izvekov S<&global> s1 = S<&global, ptr>(); 1137bd851eecSMatheus Izvekov S<&global, nullptr> s2 = S<&global, ptr>(); 1138bd851eecSMatheus Izvekov 1139bd851eecSMatheus Izvekov S<&global, nullptr> s3 = S<&global, &global>(); 1140bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: no viable conversion from 'S<[...], &global>' to 'S<[...], nullptr>' 1141bd851eecSMatheus Izvekov S<&global, ptr> s4 = S<&global, &global>(); 1142bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: no viable conversion from 'S<[...], &global>' to 'S<[...], ptr aka nullptr> 1143bd851eecSMatheus Izvekov 1144bd851eecSMatheus Izvekov Wrapper<S<&global, nullptr>> W1 = MakeWrapper<S<&global, ptr>>(); 1145bd851eecSMatheus Izvekov Wrapper<S<&global, static_cast<int*>(0)>> W2 = MakeWrapper<S<&global, ptr>>(); 1146bd851eecSMatheus Izvekov 1147bd851eecSMatheus Izvekov Wrapper<S<&global, nullptr>> W3 = MakeWrapper<S<&global, &global>>(); 1148bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: no viable conversion from 'Wrapper<S<[...], &global>>' to 'Wrapper<S<[...], nullptr>>' 1149bd851eecSMatheus Izvekov Wrapper<S<&global, ptr>> W4 = MakeWrapper<S<&global, &global>>(); 1150bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: no viable conversion from 'Wrapper<S<[...], &global>>' to 'Wrapper<S<[...], ptr aka nullptr>>' 1151bd851eecSMatheus Izvekov 1152bd851eecSMatheus Izvekov Wrapper<S<&global2, ptr>> W5 = MakeWrapper<S<&global, nullptr>>(); 1153bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: no viable conversion from 'Wrapper<S<&global, [...]>>' to 'Wrapper<S<&global2, [...]>>' 1154bd851eecSMatheus Izvekov Wrapper<S<&global2, nullptr>> W6 = MakeWrapper<S<&global, nullptr>>(); 1155bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: no viable conversion from 'Wrapper<S<&global, [...]>>' to 'Wrapper<S<&global2, [...]>>' 1156bd851eecSMatheus Izvekov Wrapper<S<&global2, ptr2>> W7 = MakeWrapper<S<&global, nullptr>>(); 1157bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: no viable conversion from 'Wrapper<S<&global, [...]>>' to 'Wrapper<S<&global2, [...]>>' 1158bd851eecSMatheus Izvekov Wrapper<S<&global2, nullptr>> W8 = MakeWrapper<S<&global, ptr2>>(); 1159bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: no viable conversion from 'Wrapper<S<&global, [...]>>' to 'Wrapper<S<&global2, [...]>>' 1160bd851eecSMatheus Izvekov Wrapper<S<&global2, ptr>> W9 = MakeWrapper<S<&global, ptr2>>(); 1161bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: no viable conversion from 'Wrapper<S<&global, [...]>>' to 'Wrapper<S<&global2, [...]>>' 1162bd851eecSMatheus Izvekov Wrapper<S<&global2, ptr2>> W10 = MakeWrapper<S<&global, ptr>>(); 1163bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: no viable conversion from 'Wrapper<S<&global, [...]>>' to 'Wrapper<S<&global2, [...]>>' 1164bd851eecSMatheus Izvekov Wrapper<S<&global2, static_cast<int *>(0)>> W11 = 1165bd851eecSMatheus Izvekov MakeWrapper<S<&global, nullptr>>(); 1166bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: no viable conversion from 'Wrapper<S<&global, [...]>>' to 'Wrapper<S<&global2, [...]>>' 1167bd851eecSMatheus Izvekov Wrapper<S<&global2, nullptr>> W12 = 1168bd851eecSMatheus Izvekov MakeWrapper<S<&global, static_cast<int *>(0)>>(); 1169bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: no viable conversion from 'Wrapper<S<&global, [...]>>' to 'Wrapper<S<&global2, [...]>>' 1170bd851eecSMatheus Izvekov 1171bd851eecSMatheus Izvekov Wrapper<S<&global, &global>> W13 = MakeWrapper<S<&global, ptr>>(); 1172bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: no viable conversion from 'Wrapper<S<[...], nullptr>>' to 'Wrapper<S<[...], &global>>' 1173bd851eecSMatheus Izvekov Wrapper<S<&global, ptr>> W14 = MakeWrapper<S<&global, &global>>(); 1174bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: no viable conversion from 'Wrapper<S<[...], &global>>' to 'Wrapper<S<[...], ptr aka nullptr>>' 1175bd851eecSMatheus Izvekov } 1176bd851eecSMatheus Izvekov 1177bd851eecSMatheus Izvekov namespace TemplateTemplateDefault { 1178bd851eecSMatheus Izvekov template <class> class A{}; 1179bd851eecSMatheus Izvekov template <class> class B{}; 1180bd851eecSMatheus Izvekov template <class> class C{}; 1181bd851eecSMatheus Izvekov template <template <class> class, template <class> class = A> 1182bd851eecSMatheus Izvekov class T {}; 1183bd851eecSMatheus Izvekov 1184bd851eecSMatheus Izvekov T<A> t1 = T<A, C>(); 1185bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: no viable conversion from 'T<[...], template C>' to 'T<[...], (default) template A>' 1186bd851eecSMatheus Izvekov T<A, C> t2 = T<A>(); 1187bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: no viable conversion from 'T<[...], (default) template A>' to 'T<[...], template C>' 1188bd851eecSMatheus Izvekov T<A> t3 = T<B>(); 1189bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: no viable conversion from 'T<template B>' to 'T<template A>' 1190bd851eecSMatheus Izvekov T<B, C> t4 = T<C, B>(); 1191bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: no viable conversion from 'T<template C, template B>' to 'T<template B, template C>' 1192bd851eecSMatheus Izvekov T<A, A> t5 = T<B>(); 1193bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: no viable conversion from 'T<template B, [...]>' to 'T<template A, [...]>' 1194bd851eecSMatheus Izvekov T<B> t6 = T<A, A>(); 1195bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: no viable conversion from 'T<template A, [...]>' to 'T<template B, [...]>' 1196bd851eecSMatheus Izvekov } 1197bd851eecSMatheus Izvekov 1198bd851eecSMatheus Izvekov namespace Bool { 1199bd851eecSMatheus Izvekov template <class> class A{}; 1200bd851eecSMatheus Izvekov A<bool> a1 = A<int>(); 1201bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: no viable conversion from 'A<int>' to 'A<bool>' 1202bd851eecSMatheus Izvekov A<int> a2 = A<bool>(); 1203bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: no viable conversion from 'A<bool>' to 'A<int>' 1204bd851eecSMatheus Izvekov } 1205bd851eecSMatheus Izvekov 1206bd851eecSMatheus Izvekov namespace TypeAlias { 1207bd851eecSMatheus Izvekov template <int, int = 0> class A {}; 1208bd851eecSMatheus Izvekov 1209bd851eecSMatheus Izvekov template <class T> using a = A<T::num, 0>; 1210bd851eecSMatheus Izvekov template <class T> using a = A<T::num>; 1211bd851eecSMatheus Izvekov 1212bd851eecSMatheus Izvekov template <class T> using A1 = A<T::num>; 1213bd851eecSMatheus Izvekov template <class T> using A1 = A<T::num + 0>; 1214bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: type alias template redefinition with different types ('A<T::num + 0>' vs 'A<T::num>') 1215bd851eecSMatheus Izvekov 1216bd851eecSMatheus Izvekov template <class T> using A2 = A<1 + T::num>; 1217bd851eecSMatheus Izvekov template <class T> using A2 = A<T::num + 1>; 1218bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: type alias template redefinition with different types ('A<T::num + 1>' vs 'A<1 + T::num>') 1219bd851eecSMatheus Izvekov 1220bd851eecSMatheus Izvekov template <class T> using A3 = A<(T::num)>; 1221bd851eecSMatheus Izvekov template <class T> using A3 = A<T::num>; 1222bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: error: type alias template redefinition with different types ('A<T::num>' vs 'A<(T::num)>') 1223bd851eecSMatheus Izvekov 1224bd851eecSMatheus Izvekov template <class T> using A4 = A<(T::num)>; 1225bd851eecSMatheus Izvekov template <class T> using A4 = A<((T::num))>; 1226bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: type alias template redefinition with different types ('A<((T::num))>' vs 'A<(T::num)>') 1227bd851eecSMatheus Izvekov 1228bd851eecSMatheus Izvekov template <class T> using A5 = A<T::num, 1>; 1229bd851eecSMatheus Izvekov template <class T> using A5 = A<T::num>; 1230bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: type alias template redefinition with different types ('A<[...], (default) 0>' vs 'A<[...], 1>') 1231bd851eecSMatheus Izvekov 1232bd851eecSMatheus Izvekov template <class T> using A6 = A<T::num + 5, 1>; 1233bd851eecSMatheus Izvekov template <class T> using A6 = A<T::num + 5>; 1234bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: type alias template redefinition with different types ('A<[...], (default) 0>' vs 'A<[...], 1>') 1235bd851eecSMatheus Izvekov 1236bd851eecSMatheus Izvekov template <class T> using A7 = A<T::num, 1>; 1237bd851eecSMatheus Izvekov template <class T> using A7 = A<(T::num)>; 1238bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: type alias template redefinition with different types ('A<(T::num), (default) 0>' vs 'A<T::num, 1>') 1239bd851eecSMatheus Izvekov } 1240bd851eecSMatheus Izvekov 1241bd851eecSMatheus Izvekov namespace TemplateArgumentImplicitConversion { 1242bd851eecSMatheus Izvekov template <int X> struct condition {}; 1243bd851eecSMatheus Izvekov 1244bd851eecSMatheus Izvekov struct is_const { 1245bd851eecSMatheus Izvekov constexpr operator int() const { return 10; } 1246bd851eecSMatheus Izvekov }; 1247bd851eecSMatheus Izvekov 1248bd851eecSMatheus Izvekov using T = condition<(is_const())>; 1249bd851eecSMatheus Izvekov void foo(const T &t) { 1250bd851eecSMatheus Izvekov T &t2 = t; 1251bd851eecSMatheus Izvekov } 1252bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: binding reference of type 'condition<...>' to value of type 'const condition<...>' drops 'const' qualifier 1253bd851eecSMatheus Izvekov } 1254bd851eecSMatheus Izvekov 1255bd851eecSMatheus Izvekov namespace BoolArgumentBitExtended { 1256bd851eecSMatheus Izvekov template <bool B> struct BoolT {}; 1257bd851eecSMatheus Izvekov 1258bd851eecSMatheus Izvekov template <typename T> void foo(T) {} 1259bd851eecSMatheus Izvekov 1260bd851eecSMatheus Izvekov void test() { 1261bd851eecSMatheus Izvekov BoolT<false> X; 1262bd851eecSMatheus Izvekov foo<BoolT<true>>(X); 1263bd851eecSMatheus Izvekov } 1264bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: no matching function for call to 'foo' 1265bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: candidate function template not viable: no known conversion from 'BoolT<false>' to 'BoolT<true>' for 1st argument 1266bd851eecSMatheus Izvekov } 1267bd851eecSMatheus Izvekov 1268bd851eecSMatheus Izvekov namespace DifferentIntegralTypes { 1269bd851eecSMatheus Izvekov template<typename T, T n> 1270bd851eecSMatheus Izvekov class A{}; 1271bd851eecSMatheus Izvekov void foo() { 1272bd851eecSMatheus Izvekov A<int, 1> a1 = A<long long, 1>(); 1273bd851eecSMatheus Izvekov A<unsigned int, 1> a2 = A<int, 5>(); 1274bd851eecSMatheus Izvekov A<bool, true> a3 = A<signed char, true>(); 1275bd851eecSMatheus Izvekov } 1276bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: error: no viable conversion from 'A<long long, (long long) 1>' to 'A<int, (int) 1>' 1277bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: error: no viable conversion from 'A<int, (int) 5>' to 'A<unsigned int, (unsigned int) 1>' 1278bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: error: no viable conversion from 'A<signed char, (signed char) 1>' to 'A<bool, (bool) true>' 1279bd851eecSMatheus Izvekov } 1280bd851eecSMatheus Izvekov 1281bd851eecSMatheus Izvekov namespace MixedDeclarationIntegerArgument { 1282bd851eecSMatheus Izvekov template<typename T, T n> class A{}; 1283bd851eecSMatheus Izvekov int x; 1284bd851eecSMatheus Izvekov int y[5]; 1285bd851eecSMatheus Izvekov 1286bd851eecSMatheus Izvekov A<int, 5> a1 = A<int&, x>(); 1287bd851eecSMatheus Izvekov A<int, 5 - 1> a2 = A<int*, &x>(); 1288bd851eecSMatheus Izvekov A<int, 5 + 1> a3 = A<int*, y>(); 1289bd851eecSMatheus Izvekov A<int, 0> a4 = A<int**, nullptr>(); 1290bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: error: no viable conversion from 'A<int &, x>' to 'A<int, 5>' 1291bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: error: no viable conversion from 'A<int *, &x>' to 'A<int, 5 - 1 aka 4>' 1292bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: error: no viable conversion from 'A<int *, y>' to 'A<int, 5 + 1 aka 6>' 1293bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: error: no viable conversion from 'A<int **, nullptr>' to 'A<int, 0>' 1294bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: error: no viable conversion 1295bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: A< 1296bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: [int & != int], 1297bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: [x != 5]> 1298bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: error: no viable conversion 1299bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: A< 1300bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: [int * != int], 1301bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: [&x != 5 - 1 aka 4]> 1302bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: error: no viable conversion 1303bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: A< 1304bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: [int * != int], 1305bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: [y != 5 + 1 aka 6]> 1306bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: error: no viable conversion 1307bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: A< 1308bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: [int ** != int], 1309bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: [nullptr != 0]> 1310bd851eecSMatheus Izvekov 1311bd851eecSMatheus Izvekov A<int&, x> a5 = A<int, 3>(); 1312bd851eecSMatheus Izvekov A<int*, &x> a6 = A<int, 3 - 1>(); 1313bd851eecSMatheus Izvekov A<int*, y> a7 = A<int, 3 + 1>(); 1314bd851eecSMatheus Izvekov A<int**, nullptr> a8 = A<int, 3>(); 1315bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: error: no viable conversion from 'A<int, 3>' to 'A<int &, x>' 1316bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: error: no viable conversion from 'A<int, 3 - 1 aka 2>' to 'A<int *, &x>' 1317bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: error: no viable conversion from 'A<int, 3 + 1 aka 4>' to 'A<int *, y>' 1318bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: error: no viable conversion from 'A<int, 3>' to 'A<int **, nullptr>' 1319bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: error: no viable conversion 1320bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: A< 1321bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: [int != int &], 1322bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: [3 != x]> 1323bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: error: no viable conversion 1324bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: A< 1325bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: [int != int *], 1326bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: [3 - 1 aka 2 != &x]> 1327bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: error: no viable conversion 1328bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: A< 1329bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: [int != int *], 1330bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: [3 + 1 aka 4 != y]> 1331bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: error: no viable conversion 1332bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: A< 1333bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: [int != int **], 1334bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: [3 != nullptr]> 1335bd851eecSMatheus Izvekov 1336bd851eecSMatheus Izvekov template<class T, T n = x> class B{} ; 1337bd851eecSMatheus Izvekov B<int, 5> b1 = B<int&>(); 1338bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: error: no viable conversion from 'B<int &, (default) x>' to 'B<int, 5>' 1339bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: error: no viable conversion 1340bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: B< 1341bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: [int & != int], 1342bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: [(default) x != 5]> 1343bd851eecSMatheus Izvekov 1344bd851eecSMatheus Izvekov B<int &> b2 = B<int, 2>(); 1345bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: error: no viable conversion from 'B<int, 2>' to 'B<int &, (default) x>' 1346bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: B< 1347bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: [int != int &], 1348bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: [2 != (default) x]> 1349bd851eecSMatheus Izvekov 1350bd851eecSMatheus Izvekov template<class T, T n = 11> class C {}; 1351bd851eecSMatheus Izvekov C<int> c1 = C<int&, x>(); 1352bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: error: no viable conversion from 'C<int &, x>' to 'C<int, (default) 11>' 1353bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: error: no viable conversion 1354bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: C< 1355bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: [int & != int], 1356bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: [x != (default) 11]> 1357bd851eecSMatheus Izvekov 1358bd851eecSMatheus Izvekov C<int &, x> c2 = C<int>(); 1359bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: error: no viable conversion from 'C<int, (default) 11>' to 'C<int &, x>' 1360bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: C< 1361bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: [int != int &], 1362bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: [(default) 11 != x]> 1363bd851eecSMatheus Izvekov } 1364bd851eecSMatheus Izvekov 1365bd851eecSMatheus Izvekov namespace default_args { 1366bd851eecSMatheus Izvekov template <int x, int y = 1+1, int z = 2> 1367bd851eecSMatheus Izvekov class A {}; 1368bd851eecSMatheus Izvekov 1369bd851eecSMatheus Izvekov void foo(A<0> &M) { 1370bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: no viable conversion from 'A<[...], (default) 1 + 1 aka 2, (default) 2>' to 'A<[...], 0, 0>' 1371bd851eecSMatheus Izvekov A<0, 0, 0> N = M; 1372bd851eecSMatheus Izvekov 1373bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: no viable conversion from 'A<[2 * ...], (default) 2>' to 'A<[2 * ...], 0>' 1374bd851eecSMatheus Izvekov A<0, 2, 0> N2 = M; 1375bd851eecSMatheus Izvekov } 1376bd851eecSMatheus Izvekov } 1377bd851eecSMatheus Izvekov 1378bd851eecSMatheus Izvekov namespace DefaultNonTypeArgWithDependentType { 1379bd851eecSMatheus Izvekov // We used to crash diffing integer template arguments when the argument type 1380bd851eecSMatheus Izvekov // is dependent and default arguments were used. 1381bd851eecSMatheus Izvekov template <typename SizeType = int, SizeType = 0> struct A {}; 1382bd851eecSMatheus Izvekov template <typename R = A<>> R bar(); 1383bd851eecSMatheus Izvekov A<> &foo() { return bar(); } 1384bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: error: non-const lvalue reference to type 'A<...>' cannot bind to a temporary of type 'A<...>' 1385bd851eecSMatheus Izvekov // CHECK-NOELIDE-NOTREE: error: non-const lvalue reference to type 'A<int, 0>' cannot bind to a temporary of type 'A<int, 0>' 1386bd851eecSMatheus Izvekov } 1387bd851eecSMatheus Izvekov 1388bd851eecSMatheus Izvekov namespace PR24587 { 1389bd851eecSMatheus Izvekov template <typename T, T v> 1390bd851eecSMatheus Izvekov struct integral_constant {}; 1391bd851eecSMatheus Izvekov 1392bd851eecSMatheus Izvekov auto false_ = integral_constant<bool, false> {}; 1393bd851eecSMatheus Izvekov 1394bd851eecSMatheus Izvekov template <typename T> 1395bd851eecSMatheus Izvekov void f(T, decltype(false_)); 1396bd851eecSMatheus Izvekov 1397bd851eecSMatheus Izvekov void run() { 1398bd851eecSMatheus Izvekov f(1, integral_constant<bool, true>{}); 1399bd851eecSMatheus Izvekov } 1400bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: error: no matching function for call to 'f' 1401bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: note: candidate function template not viable: no known conversion from 'integral_constant<[...], true>' to 'integral_constant<[...], false>' for 2nd argument 1402bd851eecSMatheus Izvekov } 1403bd851eecSMatheus Izvekov 1404bd851eecSMatheus Izvekov namespace ZeroArgs { 1405bd851eecSMatheus Izvekov template <int N = 0> class A {}; 1406bd851eecSMatheus Izvekov template <class T = A<>> class B {}; 1407bd851eecSMatheus Izvekov A<1> a1 = A<>(); 1408bd851eecSMatheus Izvekov A<> a2 = A<1>(); 1409bd851eecSMatheus Izvekov B<> b1 = B<int>(); 1410bd851eecSMatheus Izvekov B<int> b2 = B<>(); 1411bd851eecSMatheus Izvekov B<> b3 = B<const A<>>(); 1412bd851eecSMatheus Izvekov B<const A<>> b4 = B<>(); 1413bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: error: no viable conversion from 'A<(default) 0>' to 'A<1>' 1414bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: error: no viable conversion from 'A<1>' to 'A<(default) 0>' 1415bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: error: no viable conversion from 'B<int>' to 'B<(default) ZeroArgs::A<>>' 1416bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: error: no viable conversion from 'B<(default) ZeroArgs::A<>>' to 'B<int>' 1417bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: error: no viable conversion from 'B<const A<...>>' to 'B<A<...>>' 1418bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: error: no viable conversion from 'B<A<...>>' to 'B<const A<...>>' 1419bd851eecSMatheus Izvekov } 1420bd851eecSMatheus Izvekov 1421bd851eecSMatheus Izvekov namespace TypeAlias { 1422bd851eecSMatheus Izvekov 1423bd851eecSMatheus Izvekov template <typename T> class vector {}; 1424bd851eecSMatheus Izvekov 1425bd851eecSMatheus Izvekov template <int Dimension> class Point; 1426bd851eecSMatheus Izvekov template <int dimension, typename T> using Polygon = vector<Point<dimension>>; 1427bd851eecSMatheus Izvekov 1428bd851eecSMatheus Izvekov void foo(Polygon<3, float>); 1429bd851eecSMatheus Izvekov void bar() { foo(Polygon<2, float>()); } 1430bd851eecSMatheus Izvekov 1431bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: error: no matching function for call to 'foo' 1432bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: note: candidate function not viable: no known conversion from 'Polygon<2, [...]>' to 'Polygon<3, [...]>' for 1st argument 1433bd851eecSMatheus Izvekov 1434bd851eecSMatheus Izvekov enum class X { 1435bd851eecSMatheus Izvekov X1, 1436bd851eecSMatheus Izvekov X2, 1437bd851eecSMatheus Izvekov }; 1438bd851eecSMatheus Izvekov 1439bd851eecSMatheus Izvekov template<X x> struct EnumToType; 1440bd851eecSMatheus Izvekov 1441bd851eecSMatheus Izvekov template <> struct EnumToType<X::X1> { using type = int; }; 1442bd851eecSMatheus Izvekov 1443bd851eecSMatheus Izvekov template <> struct EnumToType<X::X2> { using type = double; }; 1444bd851eecSMatheus Izvekov 1445bd851eecSMatheus Izvekov 1446bd851eecSMatheus Izvekov template <X x> using VectorType = vector<typename EnumToType<x>::type>; 1447bd851eecSMatheus Izvekov 1448bd851eecSMatheus Izvekov template <X x> void D(const VectorType<x>&); 1449bd851eecSMatheus Izvekov 1450bd851eecSMatheus Izvekov void run() { 1451bd851eecSMatheus Izvekov D<X::X1>(VectorType<X::X2>()); 1452bd851eecSMatheus Izvekov } 1453bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: error: no matching function for call to 'D' 1454bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: note: candidate function template not viable: no known conversion from 'VectorType<X::X2>' to 'const VectorType<(X)0>' for 1st argument 1455bd851eecSMatheus Izvekov } 1456bd851eecSMatheus Izvekov 1457bd851eecSMatheus Izvekov namespace TypeAlias2 { 1458bd851eecSMatheus Izvekov template <typename T> 1459bd851eecSMatheus Izvekov class A {}; 1460bd851eecSMatheus Izvekov 1461bd851eecSMatheus Izvekov template <typename T> 1462bd851eecSMatheus Izvekov using A_reg = A<T>; 1463bd851eecSMatheus Izvekov void take_reg(A_reg<int>); 1464bd851eecSMatheus Izvekov 1465bd851eecSMatheus Izvekov template <typename T> 1466bd851eecSMatheus Izvekov using A_ptr = A<T> *; 1467bd851eecSMatheus Izvekov void take_ptr(A_ptr<int>); 1468bd851eecSMatheus Izvekov 1469bd851eecSMatheus Izvekov template <typename T> 1470bd851eecSMatheus Izvekov using A_ref = const A<T> &; 1471bd851eecSMatheus Izvekov void take_ref(A_ref<int>); 1472bd851eecSMatheus Izvekov 1473bd851eecSMatheus Izvekov void run(A_reg<float> reg, A_ptr<float> ptr, A_ref<float> ref) { 1474bd851eecSMatheus Izvekov take_reg(reg); 1475bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: error: no matching function for call to 'take_reg' 1476bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: note: candidate function not viable: no known conversion from 'A_reg<float>' to 'A_reg<int>' for 1st argument 1477bd851eecSMatheus Izvekov 1478bd851eecSMatheus Izvekov take_ptr(ptr); 1479bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: error: no matching function for call to 'take_ptr' 1480bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: note: candidate function not viable: no known conversion from 'A_ptr<float>' to 'A_ptr<int>' for 1st argument 1481bd851eecSMatheus Izvekov 1482bd851eecSMatheus Izvekov take_ref(ref); 1483bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: error: no matching function for call to 'take_ref' 1484bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: note: candidate function not viable: no known conversion from 'const A<float>' to 'const A<int>' for 1st argument 1485bd851eecSMatheus Izvekov } 1486bd851eecSMatheus Izvekov } 1487bd851eecSMatheus Izvekov 1488bd851eecSMatheus Izvekov namespace SubstTemplateTypeParmType { 1489bd851eecSMatheus Izvekov template <typename T> 1490bd851eecSMatheus Izvekov class Array {}; 1491bd851eecSMatheus Izvekov 1492bd851eecSMatheus Izvekov template <class T> 1493bd851eecSMatheus Izvekov class S {}; 1494bd851eecSMatheus Izvekov 1495bd851eecSMatheus Izvekov template <class T> 1496bd851eecSMatheus Izvekov Array<T> Make(); 1497bd851eecSMatheus Izvekov 1498bd851eecSMatheus Izvekov void Call() { 1499bd851eecSMatheus Izvekov Array<S<int>> v = Make<const S<int>>(); 1500bd851eecSMatheus Izvekov } 1501bd851eecSMatheus Izvekov } 1502bd851eecSMatheus Izvekov 1503bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: no viable conversion from 'Array<const S<...>>' to 'Array<S<...>>' 1504bd851eecSMatheus Izvekov // CHECK-NOELIDE-NOTREE: no viable conversion from 'Array<const S<int>>' to 'Array<S<int>>' 1505bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: no viable conversion 1506bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: Array< 1507bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: [const != (no qualifiers)] S<...>> 1508bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: no viable conversion 1509bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: Array< 1510bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: [const != (no qualifiers)] S< 1511bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: int>> 1512bd851eecSMatheus Izvekov } 1513bd851eecSMatheus Izvekov 1514bd851eecSMatheus Izvekov // CHECK-ELIDE-NOTREE: {{[0-9]*}} errors generated. 1515bd851eecSMatheus Izvekov // CHECK-NOELIDE-NOTREE: {{[0-9]*}} errors generated. 1516bd851eecSMatheus Izvekov // CHECK-ELIDE-TREE: {{[0-9]*}} errors generated. 1517bd851eecSMatheus Izvekov // CHECK-NOELIDE-TREE: {{[0-9]*}} errors generated. 1518bd851eecSMatheus Izvekov 1519bd851eecSMatheus Izvekov namespace pr30831 { 1520bd851eecSMatheus Izvekov template <typename T> struct A { static A<T> const a; }; 1521bd851eecSMatheus Izvekov template <typename T> A<T> A<T>::a = A<T>(); 1522bd851eecSMatheus Izvekov } 1523