summaryrefslogtreecommitdiff
path: root/testsuite/tests/cpranal
diff options
context:
space:
mode:
Diffstat (limited to 'testsuite/tests/cpranal')
-rw-r--r--testsuite/tests/cpranal/Makefile3
-rw-r--r--testsuite/tests/cpranal/should_compile/Cpr001.hs16
-rw-r--r--testsuite/tests/cpranal/should_compile/Cpr001_imp.hs55
-rw-r--r--testsuite/tests/cpranal/should_compile/Makefile3
-rw-r--r--testsuite/tests/cpranal/should_compile/all.T10
5 files changed, 87 insertions, 0 deletions
diff --git a/testsuite/tests/cpranal/Makefile b/testsuite/tests/cpranal/Makefile
new file mode 100644
index 0000000000..9a36a1c5fe
--- /dev/null
+++ b/testsuite/tests/cpranal/Makefile
@@ -0,0 +1,3 @@
+TOP=../..
+include $(TOP)/mk/boilerplate.mk
+include $(TOP)/mk/test.mk
diff --git a/testsuite/tests/cpranal/should_compile/Cpr001.hs b/testsuite/tests/cpranal/should_compile/Cpr001.hs
new file mode 100644
index 0000000000..0871205bb7
--- /dev/null
+++ b/testsuite/tests/cpranal/should_compile/Cpr001.hs
@@ -0,0 +1,16 @@
+module Cpr001
+ (intpInstr) where
+
+import Cpr001_imp
+
+-- -------------------------------------------------------------------
+
+intpInstr :: Instr -> MST ()
+
+intpInstr (SysCall "exit")
+ = setMTerminated
+
+intpInstr (SysCall call)
+ = setMSvc call
+
+-- -------------------------------------------------------------------
diff --git a/testsuite/tests/cpranal/should_compile/Cpr001_imp.hs b/testsuite/tests/cpranal/should_compile/Cpr001_imp.hs
new file mode 100644
index 0000000000..5b2586127b
--- /dev/null
+++ b/testsuite/tests/cpranal/should_compile/Cpr001_imp.hs
@@ -0,0 +1,55 @@
+-- $Id: Cpr001_imp.hs,v 1.1 2001/08/22 12:21:15 simonmar Exp $
+
+module Cpr001_imp where
+
+data MS = MS { instr :: String
+ , pc :: Int
+ , mem :: String
+ , stack :: String
+ , frames :: [String]
+ , status :: Maybe String
+ }
+
+
+newtype StateTrans s a = ST ( s -> (s, Maybe a))
+
+-- state monad with error handling
+-- in case of an error, the state remains
+-- as it is and Nothing is returned as value
+-- else execution continues
+
+instance Monad (StateTrans s) where
+ (ST p) >>= k
+ = ST (\s0 -> let
+ (s1, r0) = p s0
+ in
+ case r0 of
+ Just v -> let
+ (ST q) = k v
+ in
+ q s1
+ Nothing -> (s1, Nothing)
+ )
+ return v
+ = ST (\s -> (s, Just v))
+
+
+-- machine state transitions
+
+type MachineStateTrans = StateTrans MS
+
+type MST = MachineStateTrans
+
+{-# NOINLINE setMTerminated #-}
+setMTerminated
+ = ST (\ms -> (ms { status = Just "Terminated" }, Just ()))
+
+setMSvc call
+ = ST (\ms -> (ms { status = Just "Service" }, Just ()))
+
+-- -------------------------------------------------------------------
+
+data Instr
+ = LoadI Int -- load int const
+ | SysCall String -- system call (svc)
+
diff --git a/testsuite/tests/cpranal/should_compile/Makefile b/testsuite/tests/cpranal/should_compile/Makefile
new file mode 100644
index 0000000000..9101fbd40a
--- /dev/null
+++ b/testsuite/tests/cpranal/should_compile/Makefile
@@ -0,0 +1,3 @@
+TOP=../../..
+include $(TOP)/mk/boilerplate.mk
+include $(TOP)/mk/test.mk
diff --git a/testsuite/tests/cpranal/should_compile/all.T b/testsuite/tests/cpranal/should_compile/all.T
new file mode 100644
index 0000000000..99ffed997f
--- /dev/null
+++ b/testsuite/tests/cpranal/should_compile/all.T
@@ -0,0 +1,10 @@
+# Just do the opt way...
+def f( opts ):
+ opts.only_ways = ['optasm']
+
+setTestOpts(f)
+
+test('Cpr001',
+ extra_clean(['Cpr001_imp.hi', 'Cpr001_imp.o', 'Cpr001_imp.comp.stderr']),
+ multimod_compile,
+ ['Cpr001', '-v0'])