summaryrefslogtreecommitdiff
path: root/Examples/test-suite/cpp_enum.i
diff options
context:
space:
mode:
authorLorry Tar Creator <lorry-tar-importer@baserock.org>2009-08-18 20:56:02 +0000
committerLorry <lorry@roadtrain.codethink.co.uk>2012-09-25 16:59:08 +0000
commit9f8a09ed743cedd9547bf0661d518647966ab114 (patch)
tree9c7803d3b27a8ec22e91792ac7f7932efa128b20 /Examples/test-suite/cpp_enum.i
downloadswig-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.i43
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;
+}
+
+%}