diff --git a/src/test.c b/src/test.c
index e042f242afaaf997b8244fff25c06bb5c068c181..3305807bbb3fa1c87b0cbd508aaec7e6787ebbfb 100644 (file)
--- a/src/test.c
+++ b/src/test.c
static char source_test[] =
"(* Main module *)"
"MODULE Test;"
+ "IMPORT Out;"
+ "TYPE"
+ " Callback = PROCEDURE;"
+ " Callfront = PROCEDURE(x : LONGINT) : LONGINT;"
+ " RecDesc = RECORD"
+ " cb : Callback;"
+ " cf : Callfront;"
+ " END;"
+ ""
"VAR"
- " x : INTEGER;"
+ " r : RecDesc;"
+ " i : LONGINT;"
+ ""
+ "PROCEDURE Stuff;"
+ "BEGIN"
+ " Out.Int(0123456789, 0); Out.Ln;"
+ "END Stuff;"
""
- "PROCEDURE Tier(x : INTEGER) : INTEGER;"
+ "PROCEDURE Ffuts (x : LONGINT) : LONGINT;"
"BEGIN"
- " RETURN x * x;"
- "END Tier;"
+ " RETURN 9876543210 + x;"
+ "END Ffuts;"
""
- "BEGIN;"
- " x := Tier(666);"
+ "BEGIN"
+ " Out.Open;"
+ " Out.Int(1, 0); Out.Ln;"
+ " r.cb := Stuff;"
+ " Out.Int(2, 0); Out.Ln;"
+ " r.cb();"
+ " Out.Int(3, 0); Out.Ln;"
+ " r.cf := Ffuts;"
+ " Out.Int(4, 0); Out.Ln;"
+ " i := r.cf(0123456789);"
+ " Out.Int(i, 0); Out.Ln;"
"END Test."
;
+// PROCEDURE Char* (ch : CHAR);
+// PROCEDURE String* (str : ARRAY OF CHAR);
+
static char source_out[] =
"MODULE Out;"
-// "(* Interface to outer program ;) *)"
-// "VAR"
-// " Open- : PROCEDURE;"
-// " Char- : PROCEDURE(ch : CHAR);"
-// " String- : PROCEDURE(str : ARRAY OF CHAR)"
-// " Int- : PROCEDURE(i, n : LONGINT);"
-// " Int- : PROCEDURE(i, n : INTEGER);"
-// " Real- : PROCEDURE(x : REAL; n : INTEGER);"
-// " LongReal- : PROCEDURE(x : LONGREAL; n : INTEGER);"
-// " Ln- : PROCEDURE;"
+ " PROCEDURE Open*;"
+ " END Open;"
+ ""
+ " PROCEDURE Int*(i, n : LONGINT);"
+ " END Int;"
+ ""
+ " PROCEDURE Real*(x : REAL; n : INTEGER);"
+ " END Real;"
+ ""
+ " PROCEDURE LongReal*(x : LONGREAL; n : INTEGER);"
+ " END LongReal;"
+ ""
+ " PROCEDURE Ln*;"
+ " END Ln;"
+ ""
"END Out."
;