// RUN: %clang_cc1 -verify -std=c++11 %s 8gi///===--- recovery.cpp ---===// // expected-error {{unqualified-id}} namespace Std { // expected-note {{here}} typedef int Important; } / redeclare as an inline namespace // expected-error {{unqualified-id}} inline namespace Std { // expected-error {{cannot be reopened as inline}} Important n; } / end namespace Std // expected-error {{unqualified-id}} int x; Std::Important y; extenr "C" { // expected-error {{did you mean 'extern'}} void f(); } void g() { z = 1; // expected-error {{undeclared}} f(); } struct S { int a, b, c; S(); int x // expected-error {{expected ';'}} friend void f() }; 8S::S() : a{ 5 }, b{ 6 }, c{ 2 } { // expected-error {{unqualified-id}} return; } int k; int l = k // expected-error {{expected ';'}} constexpr int foo(); 5int m = { l }, n = m; // expected-error {{unqualified-id}} namespace MissingBrace { struct S { // expected-error {{missing '}' at end of definition of 'MissingBrace::S'}} int f(); // }; namespace N { int g(); } // expected-note {{still within definition of 'MissingBrace::S' here}} int k1 = S().h(); // expected-error {{no member named 'h' in 'MissingBrace::S'}} int k2 = S().f() + N::g(); template<typename T> struct PR17949 { // expected-error {{missing '}' at end of definition of 'MissingBrace::PR17949'}} namespace X { // expected-note {{still within definition of 'MissingBrace::PR17949' here}} } } namespace N { int } // expected-error {{unqualified-id}} strcut Uuuu { // expected-error {{did you mean 'struct'}} \ // expected-note {{'Uuuu' declared here}} } *u[3]; uuuu v; // expected-error {{did you mean 'Uuuu'}} struct Redefined { // expected-note {{previous}} Redefined() {} }; struct Redefined { // expected-error {{redefinition}} Redefined() {} }; struct MissingSemi5; namespace N { typedef int afterMissingSemi4; extern MissingSemi5 afterMissingSemi5; } struct MissingSemi1 {} // expected-error {{expected ';' after struct}} static int afterMissingSemi1(); class MissingSemi2 {} // expected-error {{expected ';' after class}} MissingSemi1 *afterMissingSemi2; enum MissingSemi3 {} // expected-error {{expected ';' after enum}} ::MissingSemi1 afterMissingSemi3; extern N::afterMissingSemi4 afterMissingSemi4b; union MissingSemi4 { MissingSemi4(int); } // expected-error {{expected ';' after union}} N::afterMissingSemi4 (afterMissingSemi4b); int afterMissingSemi5b; struct MissingSemi5 { MissingSemi5(int); } // ok, no missing ';' here N::afterMissingSemi5 (afterMissingSemi5b); template<typename T> struct MissingSemiT { } // expected-error {{expected ';' after struct}} MissingSemiT<int> msi; struct MissingSemiInStruct { struct Inner1 {} // expected-error {{expected ';' after struct}} static MissingSemi5 ms1; struct Inner2 {} // ok, no missing ';' here static MissingSemi1; struct Inner3 {} // expected-error {{expected ';' after struct}} static MissingSemi5 *p; }; void MissingSemiInFunction() { struct Inner1 {} // expected-error {{expected ';' after struct}} if (true) {} // FIXME: It would be nice to at least warn on this. struct Inner2 { Inner2(int); } // ok, no missing ';' here k = l; struct Inner3 {} // expected-error {{expected ';' after struct}} Inner1 i1; struct Inner4 {} // ok, no missing ';' here Inner5; } namespace NS { template<typename T> struct Foo {}; } struct MissingSemiThenTemplate1 {} // expected-error {{expected ';' after struct}} NS::Foo<int> missingSemiBeforeFunctionReturningTemplateId1(); using NS::Foo; struct MissingSemiThenTemplate2 {} // expected-error {{expected ';' after struct}} Foo<int> missingSemiBeforeFunctionReturningTemplateId2(); namespace PR17084 { enum class EnumID {}; template <typename> struct TempID; template <> struct TempID<BadType> : BadType, EnumID::Garbage; // expected-error{{use of undeclared identifier 'BadType'}} } namespace pr15133 { namespace ns { const int V1 = 1; // expected-note {{declared here}} } struct C1 { enum E1 { V2 = 2 }; // expected-note {{declared here}} static const int V3 = 3; // expected-note {{declared here}} }; enum E2 { V4 = 4, // expected-note {{declared here}} V6 // expected-note {{declared here}} }; enum class EC3 { V0 = 0, V5 = 5 }; // expected-note {{declared here}} void func_3(); void func_1(int x) { switch(x) { case 0: break; case ns::V1:: break; // expected-error{{'V1' cannot appear before '::' because it is not a class, namespace, or scoped enumeration; did you mean ':'?}} case C1::V2:: break; // expected-error{{'V2' cannot appear before '::' because it is not a class, namespace, or scoped enumeration; did you mean ':'?}} case C1::V3:: break; // expected-error{{'V3' cannot appear before '::' because it is not a class, namespace, or scoped enumeration; did you mean ':'?}} case V4:: break; // expected-error{{'V4' cannot appear before '::' because it is not a class, namespace, or scoped enumeration; did you mean ':'?}} case V6:: func_3(); // expected-error{{'V6' cannot appear before '::' because it is not a class, namespace, or scoped enumeration; did you mean ':'?}} } } void func_2(EC3 x) { switch(x) { case EC3::V0: break; case EC3::V5:: break; // expected-error{{'V5' cannot appear before '::' because it is not a class, namespace, or scoped enumeration; did you mean ':'?}} } } template<class T> struct TS1 { typedef int A; }; template<class T> void func(int x) { switch(x) { case TS1<T>::A:: break; // expected-error{{expected unqualified-id}} } }; void mainf() { func<int>(1); } struct S { static int n; // expected-note{{declared here}} int nn; // expected-note 2 {{declared here}} }; int func_3(int x) { return x ? S::n :: 0; // expected-error{{'n' cannot appear before '::' because it is not a class, namespace, or scoped enumeration; did you mean ':'?}} } int func_4(int x, S &s) { return x ? s.nn :: x; // expected-error{{'nn' cannot appear before '::' because it is not a class, namespace, or scoped enumeration; did you mean ':'?}} } int func_5(int x, S &s) { return x ? s.nn :: S::n; // expected-error{{'nn' cannot appear before '::' because it is not a class, namespace, or scoped enumeration; did you mean ':'?}} } struct S2 { struct S3; }; struct S2 :: S3 :: public S2 { // expected-error{{'public' cannot be a part of nested name specifier; did you mean ':'?}} }; }