diff options
| author | Lorry Tar Creator <lorry-tar-importer@baserock.org> | 2009-08-18 20:56:02 +0000 |
|---|---|---|
| committer | Lorry <lorry@roadtrain.codethink.co.uk> | 2012-09-25 16:59:08 +0000 |
| commit | 9f8a09ed743cedd9547bf0661d518647966ab114 (patch) | |
| tree | 9c7803d3b27a8ec22e91792ac7f7932efa128b20 /Examples/test-suite/cpp_enum.i | |
| download | swig-tarball-master.tar.gz | |
Imported from /srv/lorry/lorry-area/swig-tarball/swig-1.3.40.tar.gz.HEADswig-1.3.40master
Diffstat (limited to 'Examples/test-suite/cpp_enum.i')
| -rw-r--r-- | Examples/test-suite/cpp_enum.i | 43 |
1 files changed, 43 insertions, 0 deletions
diff --git a/Examples/test-suite/cpp_enum.i b/Examples/test-suite/cpp_enum.i new file mode 100644 index 0000000..e6eef6d --- /dev/null +++ b/Examples/test-suite/cpp_enum.i @@ -0,0 +1,43 @@ +/* +The primary purpose of this testcase is to ensure that enums used along with the 'enum' keyword compile under c++. +*/ + +%module cpp_enum + +%inline %{ + +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; +} + +%} |
