X-Git-Url: https://gerrit.simantics.org/r/gitweb?a=blobdiff_plain;f=bundles%2Forg.simantics.scl.compiler%2Ftests%2Forg%2Fsimantics%2Fscl%2Fcompiler%2Ftests%2Fscl%2FSpecConstr1.scl;fp=bundles%2Forg.simantics.scl.compiler%2Ftests%2Forg%2Fsimantics%2Fscl%2Fcompiler%2Ftests%2Fscl%2FSpecConstr1.scl;h=4ff7d476fceec589b0dfb13a0a5cb94842794524;hb=969bd23cab98a79ca9101af33334000879fb60c5;hp=0000000000000000000000000000000000000000;hpb=866dba5cd5a3929bbeae85991796acb212338a08;p=simantics%2Fplatform.git diff --git a/bundles/org.simantics.scl.compiler/tests/org/simantics/scl/compiler/tests/scl/SpecConstr1.scl b/bundles/org.simantics.scl.compiler/tests/org/simantics/scl/compiler/tests/scl/SpecConstr1.scl new file mode 100644 index 000000000..4ff7d476f --- /dev/null +++ b/bundles/org.simantics.scl.compiler/tests/org/simantics/scl/compiler/tests/scl/SpecConstr1.scl @@ -0,0 +1,25 @@ +data Either a b = Left a | Right b + +data List a = Nil | Cons a (List a) + +data Nat = Zero | Succ Nat + +sum Zero a = a +sum a Zero = a +sum (Succ a) (Succ b) = Succ (Succ (sum a b)) + +sum_append xs ys + = go Zero (Left xs) + where + go z (Left xs) + = match xs with + Nil -> go z (Right ys) + Cons x xs' -> go (sum x z) (Left xs') + go z (Right ys) + = match ys with + Nil -> z + Cons y ys' -> go (sum y z) (Right ys') + +main = "Hello world!" +-- +Hello world! \ No newline at end of file