2009-12-17 04:47:15 +08:00
|
|
|
// RUN: %clang_cc1 -fsyntax-only -pedantic -std=c++98 -verify -triple x86_64-apple-darwin %s
|
2015-12-08 11:21:47 +08:00
|
|
|
// RUN: %clang_cc1 -fsyntax-only -pedantic -std=c++11 -verify -triple x86_64-apple-darwin %s
|
2010-06-22 22:26:35 +08:00
|
|
|
enum E { // expected-note{{previous definition is here}}
|
2008-12-12 15:27:10 +08:00
|
|
|
Val1,
|
|
|
|
Val2
|
|
|
|
};
|
|
|
|
|
2010-06-22 22:26:35 +08:00
|
|
|
enum E; // expected-warning{{redeclaration of already-defined enum 'E' is a GNU extension}}
|
|
|
|
|
2008-12-12 15:27:10 +08:00
|
|
|
int& enumerator_type(int);
|
|
|
|
float& enumerator_type(E);
|
|
|
|
|
|
|
|
void f() {
|
|
|
|
E e = Val1;
|
|
|
|
float& fr = enumerator_type(Val2);
|
|
|
|
}
|
2009-01-17 03:38:23 +08:00
|
|
|
|
|
|
|
// <rdar://problem/6502934>
|
|
|
|
typedef enum Foo {
|
2009-09-09 23:08:12 +08:00
|
|
|
A = 0,
|
|
|
|
B = 1
|
2009-01-17 03:38:23 +08:00
|
|
|
} Foo;
|
2009-09-09 23:08:12 +08:00
|
|
|
|
2009-01-17 03:38:23 +08:00
|
|
|
void bar() {
|
2009-09-09 23:08:12 +08:00
|
|
|
Foo myvar = A;
|
|
|
|
myvar = B;
|
2009-01-17 03:38:23 +08:00
|
|
|
}
|
2009-03-07 02:34:03 +08:00
|
|
|
|
|
|
|
/// PR3688
|
|
|
|
struct s1 {
|
2009-12-04 08:07:04 +08:00
|
|
|
enum e1 (*bar)(void); // expected-error{{ISO C++ forbids forward references to 'enum' types}}
|
2009-03-07 02:34:03 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
enum e1 { YES, NO };
|
|
|
|
|
|
|
|
static enum e1 badfunc(struct s1 *q) {
|
2009-12-04 08:07:04 +08:00
|
|
|
return q->bar();
|
2009-03-07 02:34:03 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
enum e2; // expected-error{{ISO C++ forbids forward references to 'enum' types}}
|
2009-12-09 17:09:27 +08:00
|
|
|
|
|
|
|
namespace test1 {
|
|
|
|
template <class A, class B> struct is_same { static const int value = -1; };
|
|
|
|
template <class A> struct is_same<A,A> { static const int value = 1; };
|
|
|
|
|
|
|
|
enum enum0 { v0 };
|
2009-12-17 04:30:08 +08:00
|
|
|
int test0[is_same<__typeof(+v0), int>::value];
|
2009-12-09 17:09:27 +08:00
|
|
|
|
|
|
|
enum enum1 { v1 = __INT_MAX__ };
|
2009-12-17 04:30:08 +08:00
|
|
|
int test1[is_same<__typeof(+v1), int>::value];
|
2009-12-09 17:09:27 +08:00
|
|
|
|
|
|
|
enum enum2 { v2 = __INT_MAX__ * 2U };
|
2009-12-17 04:30:08 +08:00
|
|
|
int test2[is_same<__typeof(+v2), unsigned int>::value];
|
2009-12-09 17:09:27 +08:00
|
|
|
|
2009-12-17 04:30:08 +08:00
|
|
|
enum enum3 { v3 = __LONG_MAX__ };
|
|
|
|
int test3[is_same<__typeof(+v3), long>::value];
|
2009-12-09 17:09:27 +08:00
|
|
|
|
2009-12-17 04:30:08 +08:00
|
|
|
enum enum4 { v4 = __LONG_MAX__ * 2UL };
|
|
|
|
int test4[is_same<__typeof(+v4), unsigned long>::value];
|
2009-12-09 17:09:27 +08:00
|
|
|
}
|
2010-01-19 14:06:57 +08:00
|
|
|
|
|
|
|
// PR6061
|
|
|
|
namespace PR6061 {
|
|
|
|
struct A { enum { id }; };
|
|
|
|
struct B { enum { id }; };
|
|
|
|
|
|
|
|
struct C : public A, public B
|
|
|
|
{
|
|
|
|
enum { id };
|
|
|
|
};
|
|
|
|
}
|
2010-02-03 08:27:59 +08:00
|
|
|
|
|
|
|
namespace Conditional {
|
|
|
|
enum a { A }; a x(const enum a x) { return 1?x:A; }
|
|
|
|
}
|
2010-05-24 05:53:47 +08:00
|
|
|
|
|
|
|
namespace PR7051 {
|
|
|
|
enum E { e0 };
|
|
|
|
void f() {
|
|
|
|
E e;
|
|
|
|
e = 1; // expected-error{{assigning to 'PR7051::E' from incompatible type 'int'}}
|
|
|
|
e |= 1; // expected-error{{assigning to 'PR7051::E' from incompatible type 'int'}}
|
|
|
|
}
|
|
|
|
}
|
2010-07-13 14:24:26 +08:00
|
|
|
|
|
|
|
// PR7466
|
|
|
|
enum { }; // expected-warning{{declaration does not declare anything}}
|
|
|
|
typedef enum { }; // expected-warning{{typedef requires a name}}
|
2010-08-19 12:39:37 +08:00
|
|
|
|
|
|
|
// PR7921
|
|
|
|
enum PR7921E {
|
2015-12-08 11:21:47 +08:00
|
|
|
PR7921V = (PR7921E)(123)
|
|
|
|
#if __cplusplus < 201103L
|
|
|
|
// expected-error@-2 {{expression is not an integral constant expression}}
|
|
|
|
#else
|
|
|
|
// expected-error@-4 {{must have integral or unscoped enumeration type}}
|
|
|
|
// FIXME: The above diagnostic isn't very good; we should instead complain about the type being incomplete.
|
|
|
|
#endif
|
2010-08-19 12:39:37 +08:00
|
|
|
};
|
2010-09-12 11:38:25 +08:00
|
|
|
|
|
|
|
void PR8089() {
|
|
|
|
enum E; // expected-error{{ISO C++ forbids forward references to 'enum' types}}
|
|
|
|
int a = (E)3; // expected-error{{cannot initialize a variable of type 'int' with an rvalue of type 'E'}}
|
|
|
|
}
|
2015-12-08 11:21:47 +08:00
|
|
|
|
|
|
|
// This is accepted as a GNU extension. In C++98, there was no provision for
|
|
|
|
// expressions with UB to be non-constant.
|
2018-10-19 05:26:01 +08:00
|
|
|
enum { overflow = 123456 * 234567 };
|
2015-12-08 11:21:47 +08:00
|
|
|
#if __cplusplus >= 201103L
|
|
|
|
// expected-warning@-2 {{not an integral constant expression}}
|
|
|
|
// expected-note@-3 {{value 28958703552 is outside the range of representable values}}
|
2018-10-19 05:26:01 +08:00
|
|
|
#else
|
|
|
|
// expected-warning@-5 {{overflow in expression; result is -1106067520 with type 'int'}}
|
2015-12-08 11:21:47 +08:00
|
|
|
#endif
|
2017-09-16 03:51:42 +08:00
|
|
|
|
|
|
|
// PR28903
|
|
|
|
struct PR28903 {
|
|
|
|
enum {
|
|
|
|
PR28903_A = (enum { // expected-error-re {{'PR28903::(anonymous enum at {{.*}})' cannot be defined in an enumeration}}
|
|
|
|
PR28903_B,
|
|
|
|
PR28903_C = PR28903_B
|
|
|
|
})
|
|
|
|
};
|
|
|
|
};
|