]> gerrit.simantics Code Review - simantics/platform.git/blobdiff - tests/org.simantics.scl.compiler.tests/src/org/simantics/scl/compiler/tests/scl/Serialization3.scl
Automatic execution of SCL tests in Maven
[simantics/platform.git] / tests / org.simantics.scl.compiler.tests / src / org / simantics / scl / compiler / tests / scl / Serialization3.scl
diff --git a/tests/org.simantics.scl.compiler.tests/src/org/simantics/scl/compiler/tests/scl/Serialization3.scl b/tests/org.simantics.scl.compiler.tests/src/org/simantics/scl/compiler/tests/scl/Serialization3.scl
new file mode 100644 (file)
index 0000000..d883dfe
--- /dev/null
@@ -0,0 +1,22 @@
+import "Prelude"
+import "Serialization" as Serialization
+
+rt :: Serialization.IO a => a -> a
+rt v = Serialization.readByteArray (Serialization.writeByteArray v)
+
+data FooBar a = Foo Integer | Bar a
+
+deriving instance (Show a) => Show (FooBar a)
+deriving instance (Serialization.IO a) => Serialization.IO (FooBar a)
+
+/*
+instance IO FooBar where
+    read s = match Serialization.read s :: Integer with
+             0 -> Foo (Serialization.read s)
+             1 -> Bar (Serialization.read s)
+    write s (Foo x) = do Serialization.write s (0 :: Integer) ; Serialization.write s x
+    write s (Bar x) = do Serialization.write s (1 :: Integer) ; Serialization.write s x
+*/
+main = show (rt (Foo 3 :: FooBar Double))
+--
+Foo 3
\ No newline at end of file