summaryrefslogtreecommitdiff
path: root/Examples/test-suite/ocaml/unions_runme.ml
diff options
context:
space:
mode:
Diffstat (limited to 'Examples/test-suite/ocaml/unions_runme.ml')
-rw-r--r--Examples/test-suite/ocaml/unions_runme.ml28
1 files changed, 28 insertions, 0 deletions
diff --git a/Examples/test-suite/ocaml/unions_runme.ml b/Examples/test-suite/ocaml/unions_runme.ml
new file mode 100644
index 0000000..cbf1628
--- /dev/null
+++ b/Examples/test-suite/ocaml/unions_runme.ml
@@ -0,0 +1,28 @@
+(* Test the unions example... *)
+
+open Swig
+open Unions
+
+let a = new_SmallStruct C_void
+let b = new_BigStruct C_void
+let c = new_UnionTest C_void
+let d = new_EmbeddedUnionTest C_void
+
+let _ = (invoke a) "jill" (C_short 3)
+let _ = (invoke b) "jack" (C_char 'a') (* Int conversion *)
+let _ = (invoke b) "smallstruct" a (* Put a in b *)
+let _ = (invoke c) "bs" b
+
+let _ = if get_int ((invoke a) "jill" C_void) != 3 then
+ raise (Failure "jill value is not preserved")
+let _ = if get_int ((invoke b) "jack" C_void) != (int_of_char 'a') then
+ raise (Failure "jack value is not preserved")
+let _ = if get_int ((invoke ((invoke b) "smallstruct" C_void))
+ "jill" C_void) != 3 then
+ raise (Failure "jill value is not embedded in bigstruct")
+let _ = if get_int ((invoke ((invoke c) "bs" C_void))
+ "jack" C_void) != (int_of_char 'a') then
+ raise (Failure "union set of bigstruct did not take")
+let _ = if get_int ((invoke ((invoke c) "ss" C_void))
+ "jill" C_void) != (int_of_char 'a') then
+ raise (Failure "corresponding union values are not the same")