| // RUN: %clang_cc1 -fsyntax-only -verify -pedantic -fcxx-exceptions %s |
| // RUN: %clang_cc1 -fsyntax-only -verify -pedantic -fcxx-exceptions -std=c++98 %s |
| // RUN: %clang_cc1 -fsyntax-only -verify -pedantic -fcxx-exceptions -std=c++11 %s |
| |
| class C; |
| class C { |
| public: |
| protected: |
| typedef int A,B; |
| static int sf(), u; |
| |
| struct S {}; |
| enum {}; // expected-warning{{declaration does not declare anything}} |
| int; // expected-warning {{declaration does not declare anything}} |
| int : 1, : 2; |
| |
| public: |
| void m0() {}; // ok, one extra ';' is permitted |
| void m1() {} |
| ; // ok, one extra ';' is permitted |
| void m() { |
| int l = 2; |
| };; // expected-warning{{extra ';' after member function definition}} |
| |
| template<typename T> void mt(T) { } |
| ; |
| ; // expected-warning{{extra ';' inside a class}} |
| |
| virtual int vf() const volatile = 0; |
| |
| virtual int vf0() = 0l; // expected-error {{does not look like a pure-specifier}} |
| virtual int vf1() = 1; // expected-error {{does not look like a pure-specifier}} |
| virtual int vf2() = 00; // expected-error {{does not look like a pure-specifier}} |
| virtual int vf3() = 0x0; // expected-error {{does not look like a pure-specifier}} |
| virtual int vf4() = 0.0; // expected-error {{does not look like a pure-specifier}} |
| virtual int vf5(){0}; // expected-error +{{}} expected-warning {{unused}} |
| virtual int vf5a(){0;}; // function definition, expected-warning {{unused}} |
| virtual int vf6()(0); // expected-error +{{}} expected-note +{{}} |
| virtual int vf7() = { 0 }; // expected-error {{does not look like a pure-specifier}} |
| virtual int PR45267() = \ |
| 0; // ok, despite escaped newline |
| |
| private: |
| int x,f(),y,g(); |
| inline int h(); |
| static const int sci = 10; |
| mutable int mi; |
| }; |
| void glo() |
| { |
| struct local {}; |
| } |
| |
| // PR3177 |
| typedef union { |
| __extension__ union { |
| int a; |
| float b; |
| } y; |
| } bug3177; |
| |
| // check that we don't consume the token after the access specifier |
| // when it's not a colon |
| class D { |
| public // expected-error{{expected ':'}} |
| int i; |
| }; |
| |
| // consume the token after the access specifier if it's a semicolon |
| // that was meant to be a colon |
| class E { |
| public; // expected-error{{expected ':'}} |
| int i; |
| }; |
| |
| class F { |
| int F1 { return 1; } |
| #if __cplusplus <= 199711L |
| // expected-error@-2 {{function definition does not declare parameters}} |
| #else |
| // expected-error@-4 {{expected expression}} |
| // expected-error@-5 {{expected}} |
| // expected-note@-6 {{to match this '{'}} |
| // expected-error@-7 {{expected ';' after class}} |
| #endif |
| |
| void F2 {} |
| #if __cplusplus <= 199711L |
| // expected-error@-2 {{function definition does not declare parameters}} |
| #else |
| // expected-error@-4 {{variable has incomplete type 'void'}} |
| // expected-error@-5 {{expected ';' after top level declarator}} |
| #endif |
| |
| typedef int F3() { return 0; } // expected-error{{function definition declared 'typedef'}} |
| typedef void F4() {} // expected-error{{function definition declared 'typedef'}} |
| }; |
| #if __cplusplus >= 201103L |
| // expected-error@-2 {{extraneous closing brace}} |
| #endif |
| |
| namespace ctor_error { |
| class Foo {}; |
| // By [class.qual]p2, this is a constructor declaration. |
| Foo::Foo (F) = F(); // expected-error{{does not match any declaration in 'ctor_error::Foo'}} |
| |
| class Ctor { // expected-note{{not complete until the closing '}'}} |
| Ctor(f)(int); // ok |
| Ctor(g(int)); // ok |
| Ctor(x[5]); // expected-error{{incomplete type}} |
| |
| Ctor(UnknownType *); // expected-error{{unknown type name 'UnknownType'}} |
| void operator+(UnknownType*); // expected-error{{unknown type name 'UnknownType'}} |
| }; |
| |
| Ctor::Ctor (x) = { 0 }; // \ |
| // expected-error{{qualified reference to 'Ctor' is a constructor name}} |
| |
| Ctor::Ctor(UnknownType *) {} // \ |
| // expected-error{{unknown type name 'UnknownType'}} |
| void Ctor::operator+(UnknownType*) {} // \ |
| // expected-error{{unknown type name 'UnknownType'}} |
| } |
| |
| namespace nns_decl { |
| struct A { |
| struct B; |
| }; |
| namespace N { |
| union C; |
| } |
| struct A::B; // expected-error {{forward declaration of struct cannot have a nested name specifier}} |
| union N::C; // expected-error {{forward declaration of union cannot have a nested name specifier}} |
| } |
| |
| // PR13775: Don't assert here. |
| namespace PR13775 { |
| class bar |
| { |
| public: |
| void foo (); |
| void baz (); |
| }; |
| void bar::foo () |
| { |
| baz x(); // expected-error 3{{}} |
| } |
| } |
| |
| class pr16989 { |
| void tpl_mem(int *) { |
| return; |
| class C2 { |
| void f(); |
| }; |
| void C2::f() {} // expected-error{{function definition is not allowed here}} |
| }; |
| }; |
| |
| namespace CtorErrors { |
| struct A { |
| A(NonExistent); // expected-error {{unknown type name 'NonExistent'}} |
| }; |
| struct B { |
| B(NonExistent) : n(0) {} // expected-error {{unknown type name 'NonExistent'}} |
| int n; |
| }; |
| struct C { |
| C(NonExistent) try {} catch (...) {} // expected-error {{unknown type name 'NonExistent'}} |
| }; |
| struct D { |
| D(NonExistent) {} // expected-error {{unknown type name 'NonExistent'}} |
| }; |
| } |
| |
| namespace DtorErrors { |
| struct A { ~A(); int n; } a; |
| ~A::A() { n = 0; } // expected-error {{'~' in destructor name should be after nested name specifier}} expected-note {{previous}} |
| A::~A() {} // expected-error {{redefinition}} |
| |
| struct B { ~B(); } *b; |
| DtorErrors::~B::B() {} // expected-error {{'~' in destructor name should be after nested name specifier}} |
| |
| void f() { |
| a.~A::A(); // expected-error {{'~' in destructor name should be after nested name specifier}} |
| b->~DtorErrors::~B::B(); // expected-error {{'~' in destructor name should be after nested name specifier}} |
| } |
| |
| struct C; // expected-note {{forward decl}} |
| ~C::C() {} // expected-error {{incomplete}} expected-error {{'~' in destructor name should be after nested name specifier}} |
| |
| struct D { struct X {}; ~D() throw(X); }; |
| ~D::D() throw(X) {} // expected-error {{'~' in destructor name should be after nested name specifier}} |
| |
| ~Undeclared::Undeclared() {} // expected-error {{use of undeclared identifier 'Undeclared'}} expected-error {{'~' in destructor name should be after nested name specifier}} |
| ~Undeclared:: {} // expected-error {{expected identifier}} expected-error {{'~' in destructor name should be after nested name specifier}} |
| |
| struct S { |
| // For another struct's destructor, emit the same diagnostic like for |
| // A::~A() in addition to the "~ in the wrong place" one. |
| ~A::A() {} // expected-error {{'~' in destructor name should be after nested name specifier}} expected-error {{non-friend class member '~A' cannot have a qualified name}} |
| A::~A() {} // expected-error {{non-friend class member '~A' cannot have a qualified name}} |
| |
| // An inline destructor with a redundant class name should also get the |
| // same diagnostic as S::~S. |
| ~S::S() {} // expected-error {{'~' in destructor name should be after nested name specifier}} expected-error {{extra qualification on member '~S'}} |
| |
| // This just shouldn't crash. |
| int I; // expected-note {{declared here}} |
| ~I::I() {} // expected-error {{'I' is not a class, namespace, or enumeration}} expected-error {{'~' in destructor name should be after nested name specifier}} |
| }; |
| |
| struct T {}; |
| T t1 = t1.T::~T<int>; // expected-error {{destructor name 'T' does not refer to a template}} |
| // Emit the same diagnostic as for the previous case, plus something about ~. |
| T t2 = t2.~T::T<int>; // expected-error {{'~' in destructor name should be after nested name specifier}} expected-error {{destructor name 'T' does not refer to a template}} |
| } |
| |
| namespace BadFriend { |
| struct A { |
| friend int : 3; // expected-error {{friends can only be classes or functions}} |
| friend void f() = 123; // expected-error {{illegal initializer}} |
| friend virtual void f(); // expected-error {{'virtual' is invalid in friend declarations}} |
| friend void f() final; // expected-error {{'final' is invalid in friend declarations}} |
| friend void f() override; // expected-error {{'override' is invalid in friend declarations}} |
| }; |
| } |
| |
| class PR20760_a { |
| int a = ); // expected-error {{expected expression}} |
| #if __cplusplus <= 199711L |
| // expected-warning@-2 {{default member initializer for non-static data member is a C++11 extension}} |
| #endif |
| |
| int b = }; // expected-error {{expected expression}} |
| #if __cplusplus <= 199711L |
| // expected-warning@-2 {{default member initializer for non-static data member is a C++11 extension}} |
| #endif |
| |
| int c = ]; // expected-error {{expected expression}} |
| #if __cplusplus <= 199711L |
| // expected-warning@-2 {{default member initializer for non-static data member is a C++11 extension}} |
| #endif |
| |
| }; |
| class PR20760_b { |
| int d = d); // expected-error {{expected ';'}} |
| #if __cplusplus <= 199711L |
| // expected-warning@-2 {{default member initializer for non-static data member is a C++11 extension}} |
| #endif |
| |
| int e = d]; // expected-error {{expected ';'}} |
| #if __cplusplus <= 199711L |
| // expected-warning@-2 {{default member initializer for non-static data member is a C++11 extension}} |
| #endif |
| |
| int f = d // expected-error {{expected ';'}} |
| #if __cplusplus <= 199711L |
| // expected-warning@-2 {{default member initializer for non-static data member is a C++11 extension}} |
| #endif |
| |
| }; |
| |
| namespace PR20887 { |
| class X1 { a::operator=; }; // expected-error {{undeclared identifier 'a'}} |
| class X2 { a::a; }; // expected-error {{undeclared identifier 'a'}} |
| } |
| |
| class BadExceptionSpec { |
| void f() throw(int; // expected-error {{expected ')'}} expected-note {{to match}} |
| void g() throw( |
| int( |
| ; // expected-error {{unexpected ';' before ')'}} |
| )); |
| }; |
| |
| namespace PR41192 { |
| extern struct A a; |
| struct A {} ::PR41192::a; // ok, no missing ';' here expected-warning {{extra qualification}} |
| |
| #if __cplusplus >= 201103L |
| struct C; |
| struct D { static C c; }; |
| struct C {} decltype(D())::c; // expected-error {{'decltype' cannot be used to name a declaration}} |
| #endif |
| } |
| |
| namespace ArrayMemberAccess { |
| struct A { |
| int x; |
| template<typename T> int f() const; |
| }; |
| void f(const A (&a)[]) { |
| // OK: not a template-id. |
| bool cond = a->x < 10 && a->x > 0; |
| // OK: a template-id. |
| a->f<int>(); |
| } |
| } |
| |
| namespace UndeclaredBaseTemplate { |
| template<class> struct imp; |
| template<class T> struct is_member_function_pointer : undeclared<imp<T>::member> {}; // expected-error {{unknown template name 'undeclared'}} |
| } |
| |
| // PR11109 must appear at the end of the source file |
| class pr11109r3 { // expected-note{{to match this '{'}} |
| public // expected-error{{expected ':'}} expected-error{{expected '}'}} expected-error{{expected ';' after class}} |