| /* |
| The primary purpose of this testcase is to ensure that enums used along with the 'enum' keyword compile under c++. |
| */ |
| |
| %module cpp_enum |
| |
| %inline %{ |
| |
| #if __GNUC__ >= 5 || (__GNUC__ == 4 && __GNUC_MINOR__ >= 8) |
| /* for anonymous enums */ |
| /* dereferencing type-punned pointer will break strict-aliasing rules [-Werror=strict-aliasing] */ |
| #pragma GCC diagnostic ignored "-Wstrict-aliasing" |
| #endif |
| |
| enum SOME_ENUM {ENUM_ONE, ENUM_TWO}; |
| |
| struct StructWithEnums { |
| StructWithEnums() : some_enum(ENUM_ONE) {}; |
| enum SOME_ENUM some_enum; |
| void enum_test1(enum SOME_ENUM param1, enum SOME_ENUM* param2, enum SOME_ENUM& param3) {}; |
| void enum_test2(SOME_ENUM param1, SOME_ENUM* param2, SOME_ENUM& param3) {}; |
| |
| SOME_ENUM enum_test3() { return ENUM_ONE; }; |
| enum SOME_ENUM enum_test4() { return ENUM_TWO; }; |
| |
| SOME_ENUM* enum_test5() { return &some_enum; }; |
| enum SOME_ENUM* enum_test6() { return &some_enum; }; |
| |
| SOME_ENUM& enum_test7() { return some_enum; }; |
| enum SOME_ENUM& enum_test8() { return some_enum; }; |
| }; |
| |
| struct Foo |
| { |
| enum {Hi, Hello } hola; |
| |
| Foo() |
| : hola(Hello) |
| { |
| } |
| }; |
| |
| extern "C" |
| { |
| enum {Hi, Hello } hi; |
| } |
| |
| %} |
| |
| // Using true and false in enums is legal in C++. Quoting the standard: |
| // [dcl.enum] |
| // ... The constant-expression shall be of integral or enumeration type. |
| // [basic.fundamental] |
| // ... Types bool, char, wchar_t, and the signed and unsigned integer |
| // types are collectively called integral types. |
| // So this shouldn't lead to a warning, at least in C++ mode. |
| %inline %{ |
| typedef enum { PLAY = true, STOP = false } play_state; |
| %} |
| |