1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147
|
// RUN: %clang_cc1 -fcxx-exceptions -fexceptions -fsyntax-only -verify %s
struct A; // expected-note 4 {{forward declaration of 'A'}}
struct Abstract { virtual void f() = 0; }; // expected-note {{unimplemented pure virtual method 'f'}}
void trys() {
try {
} catch(int i) { // expected-note {{previous definition}}
int j = i;
int i; // expected-error {{redefinition of 'i'}}
} catch(float i) {
} catch(void v) { // expected-error {{cannot catch incomplete type 'void'}}
} catch(A a) { // expected-error {{cannot catch incomplete type 'A'}}
} catch(A *a) { // expected-error {{cannot catch pointer to incomplete type 'A'}}
} catch(A &a) { // expected-error {{cannot catch reference to incomplete type 'A'}}
} catch(Abstract) { // expected-error {{variable type 'Abstract' is an abstract class}}
} catch(...) {
int j = i; // expected-error {{use of undeclared identifier 'i'}}
}
try {
} catch(...) { // expected-error {{catch-all handler must come last}}
} catch(int) {
}
}
void throws() {
throw;
throw 0;
throw throw; // expected-error {{cannot throw object of incomplete type 'void'}}
throw (A*)0; // expected-error {{cannot throw pointer to object of incomplete type 'A'}}
}
void jumps() {
l1:
goto l5;
goto l4; // expected-error {{goto into protected scope}}
goto l3; // expected-error {{goto into protected scope}}
goto l2; // expected-error {{goto into protected scope}}
goto l1;
try { // expected-note 4 {{jump bypasses initialization of try block}}
l2:
goto l5;
goto l4; // expected-error {{goto into protected scope}}
goto l3; // expected-error {{goto into protected scope}}
goto l2;
goto l1;
} catch(int) { // expected-note 4 {{jump bypasses initialization of catch block}}
l3:
goto l5;
goto l4; // expected-error {{goto into protected scope}}
goto l3;
goto l2; // expected-error {{goto into protected scope}}
goto l1;
} catch(...) { // expected-note 4 {{jump bypasses initialization of catch block}}
l4:
goto l5;
goto l4;
goto l3; // expected-error {{goto into protected scope}}
goto l2; // expected-error {{goto into protected scope}}
goto l1;
}
l5:
goto l5;
goto l4; // expected-error {{goto into protected scope}}
goto l3; // expected-error {{goto into protected scope}}
goto l2; // expected-error {{goto into protected scope}}
goto l1;
}
struct BadReturn {
BadReturn() try {
} catch(...) {
// Try to hide
try {
} catch(...) {
{
if (0)
return; // expected-error {{return in the catch of a function try block of a constructor is illegal}}
}
}
}
BadReturn(int);
};
BadReturn::BadReturn(int) try {
} catch(...) {
// Try to hide
try {
} catch(int) {
return; // expected-error {{return in the catch of a function try block of a constructor is illegal}}
} catch(...) {
{
if (0)
return; // expected-error {{return in the catch of a function try block of a constructor is illegal}}
}
}
}
// Cannot throw an abstract type.
class foo {
public:
foo() {}
void bar () {
throw *this; // expected-error{{cannot throw an object of abstract type 'foo'}}
}
virtual void test () = 0; // expected-note{{unimplemented pure virtual method 'test'}}
};
namespace PR6831 {
namespace NA { struct S; }
namespace NB { struct S; }
void f() {
using namespace NA;
using namespace NB;
try {
} catch (int S) {
}
}
}
namespace Decay {
struct A {
void f() throw (A[10]);
};
template<typename T> struct B {
void f() throw (B[10]);
};
template struct B<int>;
void f() throw (int[10], int(*)());
void f() throw (int*, int());
template<typename T> struct C {
void f() throw (T); // expected-error {{pointer to incomplete type 'Decay::E' is not allowed in exception specification}}
};
struct D {
C<D[10]> c;
};
struct E; // expected-note {{forward declaration}}
C<E[10]> e; // expected-note {{in instantiation of}}
}
void rval_ref() throw (int &&); // expected-error {{rvalue reference type 'int &&' is not allowed in exception specification}} expected-warning {{C++11}}
|