1 // RUN: %clang_cc1 -std=c++98 -triple x86_64-unknown-unknown %s -verify -fexceptions -fcxx-exceptions -pedantic-errors
2 // RUN: %clang_cc1 -std=c++11 -triple x86_64-unknown-unknown %s -verify -fexceptions -fcxx-exceptions -pedantic-errors
3 // RUN: %clang_cc1 -std=c++14 -triple x86_64-unknown-unknown %s -verify -fexceptions -fcxx-exceptions -pedantic-errors
4 // RUN: %clang_cc1 -std=c++1z -triple x86_64-unknown-unknown %s -verify -fexceptions -fcxx-exceptions -pedantic-errors
5 
6 #if __cplusplus < 201103L
7 // expected-no-diagnostics
8 #endif
9 
10 namespace dr1684 { // dr1684: 3.6
11 #if __cplusplus >= 201103L
12   struct NonLiteral { // expected-note {{because}}
13     NonLiteral();
fdr1684::NonLiteral14     constexpr int f() { return 0; } // expected-warning 0-1{{will not be implicitly 'const'}}
15   };
f(NonLiteral &)16   constexpr int f(NonLiteral &) { return 0; }
f(NonLiteral)17   constexpr int f(NonLiteral) { return 0; } // expected-error {{not a literal type}}
18 #endif
19 }
20 
21 namespace dr1631 {  // dr1631: 3.7
22 #if __cplusplus >= 201103L
23   // Incorrect overload resolution for single-element initializer-list
24 
25   struct A { int a[1]; };
26   struct B { B(int); };
27   void f(B, int);
28   void f(B, int, int = 0);
29   void f(int, A);
30 
test()31   void test() {
32     f({0}, {{1}}); // expected-warning {{braces around scalar init}}
33   }
34 
35   namespace with_error {
36     void f(B, int);           // TODO: expected- note {{candidate function}}
37     void f(int, A);           // expected-note {{candidate function}}
38     void f(int, A, int = 0);  // expected-note {{candidate function}}
39 
test()40     void test() {
41       f({0}, {{1}});        // expected-error{{call to 'f' is ambiguous}}
42     }
43   }
44 #endif
45 }
46 
47 namespace dr1645 { // dr1645: 3.9
48 #if __cplusplus >= 201103L
49   struct A { // expected-note 2{{candidate}}
50     constexpr A(int, float = 0); // expected-note 2{{candidate}}
51     explicit A(int, int = 0); // expected-note 2{{candidate}}
52     A(int, int, int = 0) = delete; // expected-note {{candidate}}
53   };
54 
55   struct B : A { // expected-note 2{{candidate}}
56     using A::A; // expected-note 7{{inherited here}}
57   };
58 
59   constexpr B a(0); // expected-error {{ambiguous}}
60   constexpr B b(0, 0); // expected-error {{ambiguous}}
61 #endif
62 }
63