Home | History | Annotate | Download | only in drs
      1 // RUN: %clang_cc1 -std=c++98 %s -verify -fexceptions -fcxx-exceptions -pedantic-errors
      2 // RUN: %clang_cc1 -std=c++11 %s -verify -fexceptions -fcxx-exceptions -pedantic-errors
      3 // RUN: %clang_cc1 -std=c++14 %s -verify -fexceptions -fcxx-exceptions -pedantic-errors
      4 // RUN: %clang_cc1 -std=c++1z %s -verify -fexceptions -fcxx-exceptions -pedantic-errors
      5 
      6 // FIXME: This is included to avoid a diagnostic with no source location
      7 // pointing at the implicit operator new. We can't match such a diagnostic
      8 // with -verify.
      9 __extension__ typedef __SIZE_TYPE__ size_t;
     10 void *operator new(size_t); // expected-error 0-1{{missing exception spec}} expected-note{{candidate}}
     11 
     12 namespace dr500 { // dr500: dup 372
     13   class D;
     14   class A {
     15     class B;
     16     class C;
     17     friend class D;
     18   };
     19   class A::B {};
     20   class A::C : public A::B {};
     21   class D : public A::B {};
     22 }
     23 
     24 namespace dr501 { // dr501: yes
     25   struct A {
     26     friend void f() {}
     27     void g() {
     28       void (*p)() = &f; // expected-error {{undeclared identifier}}
     29     }
     30   };
     31 }
     32 
     33 namespace dr502 { // dr502: yes
     34   struct Q {};
     35   template<typename T> struct A {
     36     enum E { e = 1 };
     37     void q1() { f(e); }
     38     void q2() { Q arr[sizeof(E)]; f(arr); }
     39     void q3() { Q arr[e]; f(arr); }
     40     void sanity() { Q arr[1]; f(arr); } // expected-error {{undeclared identifier 'f'}}
     41   };
     42   int f(A<int>::E);
     43   template<int N> int f(Q (&)[N]);
     44   template struct A<int>;
     45 }
     46 
     47 namespace dr505 { // dr505: yes
     48   const char *exts = "\e\(\{\[\%"; // expected-error 5{{use of non-standard escape}}
     49   const char *unknown = "\Q"; // expected-error {{unknown escape sequence}}
     50 }
     51 
     52 namespace dr506 { // dr506: yes
     53   struct NonPod { ~NonPod(); };
     54   void f(...);
     55   void g(NonPod np) { f(np); } // expected-error {{cannot pass}}
     56 }
     57 
     58 // FIXME: Add tests here once DR260 is resolved.
     59 // dr507: dup 260
     60 
     61 // dr508: na
     62 // dr509: na
     63 // dr510: na
     64 
     65 namespace dr512 { // dr512: yes
     66   struct A {
     67     A(int);
     68   };
     69   union U { A a; };
     70 #if __cplusplus < 201103L
     71   // expected-error@-2 {{has a non-trivial constructor}}
     72   // expected-note@-6 {{no default constructor}}
     73   // expected-note@-6 {{suppressed by user-declared constructor}}
     74 #endif
     75 }
     76 
     77 // dr513: na
     78 
     79 namespace dr514 { // dr514: yes
     80   namespace A { extern int x, y; }
     81   int A::x = y;
     82 }
     83 
     84 namespace dr515 { // dr515: sup 1017
     85   // FIXME: dr1017 reverses the wording of dr515, but the current draft has
     86   // dr515's wording, with a different fix for dr1017.
     87 
     88   struct X { int n; };
     89   template<typename T> struct Y : T {
     90     int f() { return X::n; }
     91   };
     92   int k = Y<X>().f();
     93 
     94   struct A { int a; };
     95   struct B { void f() { int k = sizeof(A::a); } };
     96 #if __cplusplus < 201103L
     97   // expected-error@-2 {{invalid use of non-static data member}}
     98 #endif
     99 }
    100 
    101 // dr516: na
    102 
    103 namespace dr517 { // dr517: no
    104   // This is NDR, but we should diagnose it anyway.
    105   template<typename T> struct S {};
    106   template<typename T> int v = 0; // expected-error 0-1{{extension}}
    107 
    108   template struct S<int*>;
    109   template int v<int*>;
    110 
    111   S<char&> s;
    112   int k = v<char&>;
    113 
    114   // FIXME: These are both ill-formed.
    115   template<typename T> struct S<T*> {};
    116   template<typename T> int v<T*> = 0; // expected-error 0-1{{extension}}
    117 
    118   // FIXME: These are both ill-formed.
    119   template<typename T> struct S<T&> {};
    120   template<typename T> int v<T&> = 0; // expected-error 0-1{{extension}}
    121 }
    122 
    123 namespace dr518 { // dr518: yes c++11
    124   enum E { e, };
    125 #if __cplusplus < 201103L
    126   // expected-error@-2 {{C++11 extension}}
    127 #endif
    128 }
    129 
    130 namespace dr519 { // dr519: yes
    131 // FIXME: Add a codegen test.
    132 #if __cplusplus >= 201103L
    133 #define fold(x) (__builtin_constant_p(x) ? (x) : (x))
    134   int test[fold((int*)(void*)0) ? -1 : 1];
    135 #undef fold
    136 #endif
    137 }
    138 
    139 // dr520: na
    140 
    141 // dr521: no
    142 // FIXME: The wording here is broken. It's not reasonable to expect a
    143 // diagnostic here. Once the relevant DR gets a number, mark this as a dup.
    144 
    145 namespace dr522 { // dr522: yes
    146   struct S {};
    147   template<typename T> void b1(volatile T &);
    148   template<typename T> void b2(volatile T * const *);
    149   template<typename T> void b2(volatile T * const S::*);
    150   template<typename T> void b2(volatile T * const S::* const *);
    151   template<typename T> void b2a(volatile T *S::* const *); // expected-note {{candidate template ignored: deduced type 'volatile int *dr522::S::*const *' of 1st parameter does not match adjusted type 'int *dr522::S::**' of argument}}
    152 
    153   template<typename T> struct Base {};
    154   struct Derived : Base<int> {};
    155   template<typename T> void b3(Base<T>);
    156   template<typename T> void b3(Base<T> *);
    157 
    158   void test(int n, const int cn, int **p, int *S::*pm) {
    159     int *a[3], *S::*am[3];
    160     const Derived cd = Derived();
    161     Derived d[3];
    162 
    163     b1(n);
    164     b1(cn);
    165     b2(p);
    166     b2(pm);
    167     b2(a);
    168     b2(am);
    169     b2a(am); // expected-error {{no matching function}}
    170     b3(d);
    171     b3(cd);
    172   }
    173 }
    174 
    175 namespace dr524 { // dr524: yes
    176   template<typename T> void f(T a, T b) { operator+(a, b); } // expected-error {{call}}
    177 
    178   struct S {};
    179   void operator+(S, S);
    180   template void f(S, S);
    181 
    182   namespace N { struct S {}; }
    183   void operator+(N::S, N::S); // expected-note {{should be declared}}
    184   template void f(N::S, N::S); // expected-note {{instantiation}}
    185 }
    186 
    187 namespace dr525 { // dr525: yes
    188   namespace before {
    189     // Note, the example was correct prior to the change; instantiation is
    190     // required for cases like this:
    191     template <class T> struct D { operator T*(); };
    192     void g(D<double> ppp) {
    193       delete ppp;
    194     }
    195   }
    196   namespace after {
    197     template <class T> struct D { typename T::error e; }; // expected-error {{prior to '::'}}
    198     void g(D<double> *ppp) {
    199       delete ppp; // expected-note {{instantiation of}}
    200     }
    201   }
    202 }
    203 
    204 namespace dr526 { // dr526: yes
    205   template<int> struct S {};
    206   template<int N> void f1(S<N> s);
    207   template<int N> void f2(S<(N)> s); // expected-note {{couldn't infer}}
    208   template<int N> void f3(S<+N> s); // expected-note {{couldn't infer}}
    209   template<int N> void g1(int (&)[N]);
    210   template<int N> void g2(int (&)[(N)]); // expected-note {{couldn't infer}}
    211   template<int N> void g3(int (&)[+N]); // expected-note {{couldn't infer}}
    212 
    213   void test(int (&a)[3], S<3> s) {
    214     f1(s);
    215     f2(s); // expected-error {{no matching}}
    216     f3(s); // expected-error {{no matching}}
    217     g1(a);
    218     g2(a); // expected-error {{no matching}}
    219     g3(a); // expected-error {{no matching}}
    220   }
    221 
    222   template<int N> struct X {
    223     typedef int type;
    224     X<N>::type v1;
    225     X<(N)>::type v2; // expected-error {{missing 'typename'}}
    226     X<+N>::type v3; // expected-error {{missing 'typename'}}
    227   };
    228 }
    229 
    230 namespace dr527 { // dr527: na
    231   // This DR is meaningless. It removes a required diagnostic from the case
    232   // where a not-externally-visible object is odr-used but not defined, which
    233   // requires a diagnostic for a different reason.
    234   extern struct { int x; } a; // FIXME: We should reject this, per dr389.
    235   static struct { int x; } b;
    236   extern "C" struct { int x; } c;
    237   namespace { extern struct { int x; } d; }
    238   typedef struct { int x; } *P;
    239   struct E { static P e; }; // FIXME: We should reject this, per dr389.
    240   namespace { struct F { static P f; }; }
    241 
    242   int ax = a.x, bx = b.x, cx = c.x, dx = d.x, ex = E::e->x, fx = F::f->x;
    243 }
    244 
    245 namespace dr530 { // dr530: yes
    246   template<int*> struct S { enum { N = 1 }; };
    247   template<void(*)()> struct T { enum { N = 1 }; };
    248   int n;
    249   void f();
    250   int a[S<&n>::N];
    251   int b[T<&f>::N];
    252 }
    253 
    254 namespace dr531 { // dr531: partial
    255   namespace good {
    256     template<typename T> struct A {
    257       void f(T) { T::error; }
    258       template<typename U> void g(T, U) { T::error; }
    259       struct B { typename T::error error; };
    260       template<typename U> struct C { typename T::error error; };
    261       static T n;
    262     };
    263     template<typename T> T A<T>::n = T::error;
    264 
    265     template<> void A<int>::f(int) {}
    266     template<> template<typename U> void A<int>::g(int, U) {}
    267     template<> struct A<int>::B {};
    268     template<> template<typename U> struct A<int>::C {};
    269     template<> int A<int>::n = 0;
    270 
    271     void use(A<int> a) {
    272       a.f(a.n);
    273       a.g(0, 0);
    274       A<int>::B b;
    275       A<int>::C<int> c;
    276     }
    277 
    278     template<> struct A<char> {
    279       void f(char);
    280       template<typename U> void g(char, U);
    281       struct B;
    282       template<typename U> struct C;
    283       static char n;
    284     };
    285 
    286     void A<char>::f(char) {}
    287     template<typename U> void A<char>::g(char, U) {}
    288     struct A<char>::B {};
    289     template<typename U> struct A<char>::C {};
    290     char A<char>::n = 0;
    291   }
    292 
    293   namespace bad {
    294     template<typename T> struct A {
    295       void f(T) { T::error; }
    296       template<typename U> void g(T, U) { T::error; }
    297       struct B { typename T::error error; };
    298       template<typename U> struct C { typename T::error error; }; // expected-note {{here}}
    299       static T n;
    300     };
    301     template<typename T> T A<T>::n = T::error;
    302 
    303     void A<int>::f(int) {} // expected-error {{requires 'template<>'}}
    304     template<typename U> void A<int>::g(int, U) {} // expected-error {{should be empty}}
    305     struct A<int>::B {}; // expected-error {{requires 'template<>'}}
    306     template<typename U> struct A<int>::C {}; // expected-error {{should be empty}} expected-error {{different kind of symbol}}
    307     int A<int>::n = 0; // expected-error {{requires 'template<>'}}
    308 
    309     template<> struct A<char> { // expected-note 2{{here}}
    310       void f(char);
    311       template<typename U> void g(char, U);
    312       struct B; // expected-note {{here}}
    313       template<typename U> struct C;
    314       static char n;
    315     };
    316 
    317     template<> void A<char>::f(char) {} // expected-error {{no function template matches}}
    318     // FIXME: This is ill-formed; -pedantic-errors should reject.
    319     template<> template<typename U> void A<char>::g(char, U) {} // expected-warning {{extraneous template parameter list}}
    320     template<> struct A<char>::B {}; // expected-error {{extraneous 'template<>'}} expected-error {{does not specialize}}
    321     // FIXME: This is ill-formed; -pedantic-errors should reject.
    322     template<> template<typename U> struct A<char>::C {}; // expected-warning {{extraneous template parameter list}}
    323     template<> char A<char>::n = 0; // expected-error {{extraneous 'template<>'}}
    324   }
    325 
    326   namespace nested {
    327     template<typename T> struct A {
    328       template<typename U> struct B;
    329     };
    330     template<> template<typename U> struct A<int>::B {
    331       void f();
    332       void g();
    333       template<typename V> void h();
    334       template<typename V> void i();
    335     };
    336     template<> template<typename U> void A<int>::B<U>::f() {}
    337     template<typename U> void A<int>::B<U>::g() {} // expected-error {{should be empty}}
    338 
    339     template<> template<typename U> template<typename V> void A<int>::B<U>::h() {}
    340     template<typename U> template<typename V> void A<int>::B<U>::i() {} // expected-error {{should be empty}}
    341 
    342     template<> template<> void A<int>::B<int>::f() {}
    343     template<> template<> template<typename V> void A<int>::B<int>::h() {}
    344     template<> template<> template<> void A<int>::B<int>::h<int>() {}
    345 
    346     template<> void A<int>::B<char>::f() {} // expected-error {{requires 'template<>'}}
    347     template<> template<typename V> void A<int>::B<char>::h() {} // expected-error {{should be empty}}
    348   }
    349 }
    350 
    351 // PR8130
    352 namespace dr532 { // dr532: 3.5
    353   struct A { };
    354 
    355   template<class T> struct B {
    356     template<class R> int &operator*(R&);
    357   };
    358 
    359   template<class T, class R> float &operator*(T&, R&);
    360   void test() {
    361     A a;
    362     B<A> b;
    363     int &ir = b * a;
    364   }
    365 }
    366 
    367 // dr533: na
    368 
    369 namespace dr534 { // dr534: yes
    370   struct S {};
    371   template<typename T> void operator+(S, T);
    372   template<typename T> void operator+<T*>(S, T*) {} // expected-error {{function template partial spec}}
    373 }
    374 
    375 namespace dr535 { // dr535: yes
    376   class X { private: X(const X&); };
    377   struct A {
    378     X x;
    379     template<typename T> A(T&);
    380   };
    381   struct B : A {
    382     X y;
    383     B(volatile A&);
    384   };
    385 
    386   extern A a1;
    387   A a2(a1); // ok, uses constructor template
    388 
    389   extern volatile B b1;
    390   B b2(b1); // ok, uses converting constructor
    391 
    392   void f() { throw a1; }
    393 
    394 #if __cplusplus >= 201103L
    395   struct C {
    396     constexpr C() : n(0) {}
    397     template<typename T> constexpr C(T&t) : n(t.n == 0 ? throw 0 : 0) {}
    398     int n;
    399   };
    400   constexpr C c() { return C(); }
    401   // ok, copy is elided
    402   constexpr C x = c();
    403 #endif
    404 }
    405 
    406 // dr537: na
    407 // dr538: na
    408 
    409 // dr539: yes
    410 const dr539( // expected-error {{requires a type specifier}}
    411     const a) { // expected-error {{unknown type name 'a'}}
    412   const b; // expected-error {{requires a type specifier}}
    413   new const; // expected-error {{expected a type}}
    414   try {} catch (const n) {} // expected-error {{unknown type name 'n'}}
    415   try {} catch (const) {} // expected-error {{expected a type}}
    416   if (const n = 0) {} // expected-error {{requires a type specifier}}
    417   switch (const n = 0) {} // expected-error {{requires a type specifier}}
    418   while (const n = 0) {} // expected-error {{requires a type specifier}}
    419   for (const n = 0; // expected-error {{requires a type specifier}}
    420        const m = 0; ) {} // expected-error {{requires a type specifier}}
    421   sizeof(const); // expected-error {{requires a type specifier}}
    422   struct S {
    423     const n; // expected-error {{requires a type specifier}}
    424     operator const(); // expected-error {{expected a type}}
    425   };
    426 #if __cplusplus >= 201103L
    427   int arr[3];
    428   // FIXME: The extra braces here are to avoid the parser getting too
    429   // badly confused when recovering here. We should fix this recovery.
    430   { for (const n // expected-error {{unknown type name 'n'}} expected-note {{}}
    431          : arr) ; {} } // expected-error +{{}}
    432   (void) [](const) {}; // expected-error {{requires a type specifier}}
    433   (void) [](const n) {}; // expected-error {{unknown type name 'n'}}
    434   enum E : const {}; // expected-error {{expected a type}}
    435   using T = const; // expected-error {{expected a type}}
    436   auto f() -> const; // expected-error {{expected a type}}
    437 #endif
    438 }
    439 
    440 namespace dr540 { // dr540: yes
    441   typedef int &a;
    442   typedef const a &a; // expected-warning {{has no effect}}
    443   typedef const int &b;
    444   typedef b &b;
    445   typedef const a &c; // expected-note {{previous}} expected-warning {{has no effect}}
    446   typedef const b &c; // expected-error {{different}} expected-warning {{has no effect}}
    447 }
    448 
    449 namespace dr541 { // dr541: yes
    450   template<int> struct X { typedef int type; };
    451   template<typename T> struct S {
    452     int f(T);
    453 
    454     int g(int);
    455     T g(bool);
    456 
    457     int h();
    458     int h(T);
    459 
    460     void x() {
    461       // These are type-dependent expressions, even though we could
    462       // determine that all calls have type 'int'.
    463       X<sizeof(f(0))>::type a; // expected-error +{{}}
    464       X<sizeof(g(0))>::type b; // expected-error +{{}}
    465       X<sizeof(h(0))>::type b; // expected-error +{{}}
    466 
    467       typename X<sizeof(f(0))>::type a;
    468       typename X<sizeof(h(0))>::type b;
    469     }
    470   };
    471 }
    472 
    473 namespace dr542 { // dr542: yes
    474 #if __cplusplus >= 201103L
    475   struct A { A() = delete; int n; };
    476   A a[32] = {}; // ok, constructor not called
    477 
    478   struct B {
    479     int n;
    480   private:
    481     B() = default;
    482   };
    483   B b[32] = {}; // ok, constructor not called
    484 #endif
    485 }
    486 
    487 namespace dr543 { // dr543: yes
    488   // In C++98+DR543, this is valid because value-initialization doesn't call a
    489   // trivial default constructor, so we never notice that defining the
    490   // constructor would be ill-formed.
    491   //
    492   // In C++11+DR543, this is ill-formed, because the default constructor is
    493   // deleted, and value-initialization *does* call a deleted default
    494   // constructor, even if it is trivial.
    495   struct A {
    496     const int n;
    497   };
    498   A a = A();
    499 #if __cplusplus >= 201103L
    500   // expected-error@-2 {{deleted}}
    501   // expected-note@-5 {{would not be initialized}}
    502 #endif
    503 }
    504 
    505 namespace dr544 { // dr544: yes
    506   int *n;
    507 
    508   template<class T> struct A { int n; };
    509   template<class T> struct B : A<T> { int get(); };
    510   template<> int B<int>::get() { return n; }
    511   int k = B<int>().get();
    512 }
    513 
    514 namespace dr546 { // dr546: yes
    515   template<typename T> struct A { void f(); };
    516   template struct A<int>;
    517   template<typename T> void A<T>::f() { T::error; }
    518 }
    519 
    520 namespace dr547 { // dr547: yes
    521   template<typename T> struct X;
    522   template<typename T> struct X<T() const> {};
    523   template<typename T, typename C> X<T> f(T C::*) { return X<T>(); }
    524 
    525   struct S { void f() const; };
    526   X<void() const> x = f(&S::f);
    527 }
    528 
    529 namespace dr548 { // dr548: dup 482
    530   template<typename T> struct S {};
    531   template<typename T> void f() {}
    532   template struct dr548::S<int>;
    533   template void dr548::f<int>();
    534 }
    535 
    536 namespace dr551 { // dr551: yes c++11
    537   // FIXME: This obviously should apply in C++98 mode too.
    538   template<typename T> void f() {}
    539   template inline void f<int>();
    540 #if __cplusplus >= 201103L
    541   // expected-error@-2 {{cannot be 'inline'}}
    542 #endif
    543 
    544   template<typename T> inline void g() {}
    545   template inline void g<int>();
    546 #if __cplusplus >= 201103L
    547   // expected-error@-2 {{cannot be 'inline'}}
    548 #endif
    549 
    550   template<typename T> struct X {
    551     void f() {}
    552   };
    553   template inline void X<int>::f();
    554 #if __cplusplus >= 201103L
    555   // expected-error@-2 {{cannot be 'inline'}}
    556 #endif
    557 }
    558 
    559 namespace dr552 { // dr552: yes
    560   template<typename T, typename T::U> struct X {};
    561   struct Y { typedef int U; };
    562   X<Y, 0> x;
    563 }
    564 
    565 struct dr553_class {
    566   friend void *operator new(size_t, dr553_class);
    567 };
    568 namespace dr553 {
    569   dr553_class c;
    570   // Contrary to the apparent intention of the DR, operator new is not actually
    571   // looked up with a lookup mechanism that performs ADL; the standard says it
    572   // "is looked up in global scope", where it is not visible.
    573   void *p = new (c) int; // expected-error {{no matching function}}
    574 
    575   struct namespace_scope {
    576     friend void *operator new(size_t, namespace_scope); // expected-error {{cannot be declared inside a namespace}}
    577   };
    578 }
    579 
    580 // dr556: na
    581 
    582 namespace dr557 { // dr557: yes
    583   template<typename T> struct S {
    584     friend void f(S<T> *);
    585     friend void g(S<S<T> > *);
    586   };
    587   void x(S<int> *p, S<S<int> > *q) {
    588     f(p);
    589     g(q);
    590   }
    591 }
    592 
    593 namespace dr558 { // dr558: yes
    594   wchar_t a = L'\uD7FF';
    595   wchar_t b = L'\xD7FF';
    596   wchar_t c = L'\uD800'; // expected-error {{invalid universal character}}
    597   wchar_t d = L'\xD800';
    598   wchar_t e = L'\uDFFF'; // expected-error {{invalid universal character}}
    599   wchar_t f = L'\xDFFF';
    600   wchar_t g = L'\uE000';
    601   wchar_t h = L'\xE000';
    602 }
    603 
    604 template<typename> struct dr559 { typedef int T; dr559::T u; }; // dr559: yes
    605 
    606 namespace dr561 { // dr561: yes
    607   template<typename T> void f(int);
    608   template<typename T> void g(T t) {
    609     f<T>(t);
    610   }
    611   namespace {
    612     struct S {};
    613     template<typename T> static void f(S);
    614   }
    615   void h(S s) {
    616     g(s);
    617   }
    618 }
    619 
    620 namespace dr564 { // dr564: yes
    621   extern "C++" void f(int);
    622   void f(int); // ok
    623   extern "C++" { extern int n; }
    624   int n; // ok
    625 }
    626 
    627 namespace dr565 { // dr565: yes
    628   namespace N {
    629     template<typename T> int f(T); // expected-note {{target}}
    630   }
    631   using N::f; // expected-note {{using}}
    632   template<typename T> int f(T*);
    633   template<typename T> void f(T);
    634   template<typename T, int = 0> int f(T); // expected-error 0-1{{extension}}
    635   template<typename T> int f(T, int = 0);
    636   template<typename T> int f(T); // expected-error {{conflicts with}}
    637 }
    638 
    639 namespace dr566 { // dr566: yes
    640 #if __cplusplus >= 201103L
    641   int check[int(-3.99) == -3 ? 1 : -1];
    642 #endif
    643 }
    644 
    645 // dr567: na
    646 
    647 namespace dr568 { // dr568: yes c++11
    648   // FIXME: This is a DR issue against C++98, so should probably apply there
    649   // too.
    650   struct x { int y; };
    651   class trivial : x {
    652     x y;
    653   public:
    654     int n;
    655   };
    656   int check_trivial[__is_trivial(trivial) ? 1 : -1];
    657 
    658   struct std_layout {
    659     std_layout();
    660     std_layout(const std_layout &);
    661     ~std_layout();
    662   private:
    663     int n;
    664   };
    665   int check_std_layout[__is_standard_layout(std_layout) ? 1 : -1];
    666 
    667   struct aggregate {
    668     int x;
    669     int y;
    670     trivial t;
    671     std_layout sl;
    672   };
    673   aggregate aggr = {};
    674 
    675   void f(...);
    676   void g(trivial t) { f(t); }
    677 #if __cplusplus < 201103L
    678   // expected-error@-2 {{non-POD}}
    679 #endif
    680 
    681   void jump() {
    682     goto x;
    683 #if __cplusplus < 201103L
    684     // expected-error@-2 {{cannot jump}}
    685     // expected-note@+2 {{non-POD}}
    686 #endif
    687     trivial t;
    688   x: ;
    689   }
    690 }
    691 
    692 namespace dr569 { // dr569: yes c++11
    693   // FIXME: This is a DR issue against C++98, so should probably apply there
    694   // too.
    695   ;;;;;
    696 #if __cplusplus < 201103L
    697   // expected-error@-2 {{C++11 extension}}
    698 #endif
    699 }
    700 
    701 namespace dr570 { // dr570: dup 633
    702   int n;
    703   int &r = n; // expected-note {{previous}}
    704   int &r = n; // expected-error {{redefinition}}
    705 }
    706 
    707 namespace dr571 { // dr571 unknown
    708   // FIXME: Add a codegen test.
    709   typedef int &ir;
    710   int n;
    711   const ir r = n; // expected-warning {{has no effect}} FIXME: Test if this has internal linkage.
    712 }
    713 
    714 namespace dr572 { // dr572: yes
    715   enum E { a = 1, b = 2 };
    716   int check[a + b == 3 ? 1 : -1];
    717 }
    718 
    719 namespace dr573 { // dr573: no
    720   void *a;
    721   int *b = reinterpret_cast<int*>(a);
    722   void (*c)() = reinterpret_cast<void(*)()>(a);
    723   void *d = reinterpret_cast<void*>(c);
    724 #if __cplusplus < 201103L
    725   // expected-error@-3 {{extension}}
    726   // expected-error@-3 {{extension}}
    727 #endif
    728   void f() { delete a; } // expected-error {{cannot delete}}
    729   int n = d - a; // expected-error {{arithmetic on pointers to void}}
    730   // FIXME: This is ill-formed.
    731   template<void*> struct S;
    732   template<int*> struct T;
    733 }
    734 
    735 namespace dr574 { // dr574: yes
    736   struct A {
    737     A &operator=(const A&) const; // expected-note {{does not match because it is const}}
    738   };
    739   struct B {
    740     B &operator=(const B&) volatile; // expected-note {{nearly matches}}
    741   };
    742 #if __cplusplus >= 201103L
    743   struct C {
    744     C &operator=(const C&) &; // expected-note {{not viable}} expected-note {{nearly matches}} expected-note {{here}}
    745   };
    746   struct D {
    747     D &operator=(const D&) &&; // expected-note {{not viable}} expected-note {{nearly matches}} expected-note {{here}}
    748   };
    749   void test(C c, D d) {
    750     c = c;
    751     C() = c; // expected-error {{no viable}}
    752     d = d; // expected-error {{no viable}}
    753     D() = d;
    754   }
    755 #endif
    756   struct Test {
    757     friend A &A::operator=(const A&); // expected-error {{does not match}}
    758     friend B &B::operator=(const B&); // expected-error {{does not match}}
    759 #if __cplusplus >= 201103L
    760     // FIXME: We shouldn't produce the 'cannot overload' diagnostics here.
    761     friend C &C::operator=(const C&); // expected-error {{does not match}} expected-error {{cannot overload}}
    762     friend D &D::operator=(const D&); // expected-error {{does not match}} expected-error {{cannot overload}}
    763 #endif
    764   };
    765 }
    766 
    767 namespace dr575 { // dr575: yes
    768   template<typename T, typename U = typename T::type> void a(T); void a(...); // expected-error 0-1{{extension}}
    769   template<typename T, typename T::type U = 0> void b(T); void b(...); // expected-error 0-1{{extension}}
    770   template<typename T, int U = T::value> void c(T); void c(...); // expected-error 0-1{{extension}}
    771   template<typename T> void d(T, int = T::value); void d(...); // expected-error {{cannot be used prior to '::'}}
    772   void x() {
    773     a(0);
    774     b(0);
    775     c(0);
    776     d(0); // expected-note {{in instantiation of default function argument}}
    777   }
    778 
    779   template<typename T = int&> void f(T* = 0); // expected-error 0-1{{extension}}
    780   template<typename T = int> void f(T = 0); // expected-error 0-1{{extension}}
    781   void g() { f<>(); }
    782 
    783   template<typename T> T &h(T *);
    784   template<typename T> T *h(T *);
    785   void *p = h((void*)0);
    786 }
    787 
    788 namespace dr576 { // dr576: yes
    789   typedef void f() {} // expected-error {{function definition declared 'typedef'}}
    790   void f(typedef int n); // expected-error {{invalid storage class}}
    791   void f(char c) { typedef int n; }
    792 }
    793 
    794 namespace dr577 { // dr577: yes
    795   typedef void V;
    796   typedef const void CV;
    797   void a(void);
    798   void b(const void); // expected-error {{qualifiers}}
    799   void c(V);
    800   void d(CV); // expected-error {{qualifiers}}
    801   void (*e)(void) = c;
    802   void (*f)(const void); // expected-error {{qualifiers}}
    803   void (*g)(V) = a;
    804   void (*h)(CV); // expected-error {{qualifiers}}
    805   template<typename T> void i(T); // expected-note 2{{requires 1 arg}}
    806   template<typename T> void j(void (*)(T)); // expected-note 2{{argument may not have 'void' type}}
    807   void k() {
    808     a();
    809     c();
    810     i<void>(); // expected-error {{no match}}
    811     i<const void>(); // expected-error {{no match}}
    812     j<void>(0); // expected-error {{no match}}
    813     j<const void>(0); // expected-error {{no match}}
    814   }
    815 }
    816 
    817 namespace dr580 { // dr580: partial
    818   class C;
    819   struct A { static C c; };
    820   struct B { static C c; };
    821   class C {
    822     C(); // expected-note {{here}}
    823     ~C(); // expected-note {{here}}
    824 
    825     typedef int I; // expected-note 2{{here}}
    826     template<int> struct X;
    827     template<int> friend struct Y;
    828     template<int> void f();
    829     template<int> friend void g();
    830     friend struct A;
    831   };
    832 
    833   template<C::I> struct C::X {};
    834   template<C::I> struct Y {};
    835   template<C::I> struct Z {}; // expected-error {{private}}
    836 
    837   struct C2 {
    838     class X {
    839       struct A;
    840       typedef int I;
    841       friend struct A;
    842     };
    843     class Y {
    844       template<X::I> struct A {}; // FIXME: We incorrectly accept this
    845                                   // because we think C2::Y::A<...> might
    846                                   // instantiate to C2::X::A
    847     };
    848   };
    849 
    850   template<C::I> void C::f() {}
    851   template<C::I> void g() {}
    852   template<C::I> void h() {} // expected-error {{private}}
    853 
    854   C A::c;
    855   C B::c; // expected-error 2{{private}}
    856 }
    857 
    858 // dr582: na
    859 
    860 namespace dr583 { // dr583: no
    861   // see n3624
    862   int *p;
    863   // FIXME: These are all ill-formed.
    864   bool b1 = p < 0;
    865   bool b2 = p > 0;
    866   bool b3 = p <= 0;
    867   bool b4 = p >= 0;
    868 }
    869 
    870 // dr584: na
    871 
    872 namespace dr585 { // dr585: yes
    873   template<typename> struct T;
    874   struct A {
    875     friend T; // expected-error {{requires a type specifier}} expected-error {{can only be classes or functions}}
    876     // FIXME: It's not clear whether the standard allows this or what it means,
    877     // but the DR585 writeup suggests it as an alternative.
    878     template<typename U> friend T<U>; // expected-error {{must use an elaborated type}}
    879   };
    880   template<template<typename> class T> struct B {
    881     friend T; // expected-error {{requires a type specifier}} expected-error {{can only be classes or functions}}
    882     template<typename U> friend T<U>; // expected-error {{must use an elaborated type}}
    883   };
    884 }
    885 
    886 // dr586: na
    887 
    888 namespace dr587 { // dr587: yes
    889   template<typename T> void f(bool b, const T x, T y) {
    890     const T *p = &(b ? x : y);
    891   }
    892   struct S {};
    893   template void f(bool, const int, int);
    894   template void f(bool, const S, S);
    895 }
    896 
    897 namespace dr588 { // dr588: yes
    898   struct A { int n; }; // expected-note {{ambiguous}}
    899   template<typename T> int f() {
    900     struct S : A, T { int f() { return n; } } s;
    901     int a = s.f();
    902     int b = s.n; // expected-error {{found in multiple}}
    903   }
    904   struct B { int n; }; // expected-note {{ambiguous}}
    905   int k = f<B>(); // expected-note {{here}}
    906 }
    907 
    908 namespace dr589 { // dr589: yes
    909   struct B { };
    910   struct D : B { };
    911   D f();
    912   extern const B &b;
    913   bool a;
    914   const B *p = &(a ? f() : b); // expected-error {{temporary}}
    915   const B *q = &(a ? D() : b); // expected-error {{temporary}}
    916 }
    917 
    918 namespace dr590 { // dr590: yes
    919   template<typename T> struct A {
    920     struct B {
    921       struct C {
    922         A<T>::B::C f(A<T>::B::C); // ok, no 'typename' required.
    923       };
    924     };
    925   };
    926   template<typename T> typename A<T>::B::C A<T>::B::C::f(A<T>::B::C) {}
    927 }
    928 
    929 namespace dr591 { // dr591: no
    930   template<typename T> struct A {
    931     typedef int M;
    932     struct B {
    933       typedef void M;
    934       struct C;
    935     };
    936   };
    937 
    938   template<typename T> struct A<T>::B::C : A<T> {
    939     // FIXME: Should find member of non-dependent base class A<T>.
    940     M m; // expected-error {{incomplete type 'M' (aka 'void'}}
    941   };
    942 }
    943 
    944 // dr592: na
    945 // dr593 needs an IRGen test.
    946 // dr594: na
    947 
    948 namespace dr595 { // dr595: dup 1330
    949   template<class T> struct X {
    950     void f() throw(T) {}
    951   };
    952   struct S {
    953     X<S> xs;
    954   };
    955 }
    956 
    957 // dr597: na
    958 
    959 namespace dr598 { // dr598: yes
    960   namespace N {
    961     void f(int);
    962     void f(char);
    963     // Not found by ADL.
    964     void g(void (*)(int));
    965     void h(void (*)(int));
    966 
    967     namespace M {
    968       struct S {};
    969       int &h(void (*)(S));
    970     }
    971     void i(M::S);
    972     void i();
    973   }
    974   int &g(void(*)(char));
    975   int &r = g(N::f);
    976   int &s = h(N::f); // expected-error {{undeclared}}
    977   int &t = h(N::i);
    978 }
    979 
    980 namespace dr599 { // dr599: partial
    981   typedef int Fn();
    982   struct S { operator void*(); };
    983   struct T { operator Fn*(); };
    984   struct U { operator int*(); operator void*(); }; // expected-note 2{{conversion}}
    985   struct V { operator int*(); operator Fn*(); };
    986   void f(void *p, void (*q)(), S s, T t, U u, V v) {
    987     delete p; // expected-error {{cannot delete}}
    988     delete q; // expected-error {{cannot delete}}
    989     delete s; // expected-error {{cannot delete}}
    990     delete t; // expected-error {{cannot delete}}
    991     // FIXME: This is valid, but is rejected due to a non-conforming GNU
    992     // extension allowing deletion of pointers to void.
    993     delete u; // expected-error {{ambiguous}}
    994     delete v;
    995   }
    996 }
    997