diff --git a/src/test.c b/src/test.c
index 1c3c8e39347533eb9db1d0b2e289f0348f77b693..d2950b968189c70a5f4b743c5131cd9682498959 100644 (file)
--- a/src/test.c
+++ b/src/test.c
"(* Main module *)"
"MODULE Test;"
"IMPORT Out;"
- "TYPE Ar = ARRAY OF ARRAY OF INTEGER;"
- "VAR a : POINTER TO Ar;"
+ "CONST"
+ " null = 0X;"
+ " space = 020X;"
+ " bang = 021X;"
+ " h = 048X;"
+ " e = 045X;"
+ " l = 04CX;"
+ " o = 04FX;"
+ " w = 057X;"
+ " r = 052X;"
+ " d = 044X;"
""
- "PROCEDURE Ax(VAR x : POINTER TO Ar);"
- "BEGIN"
- " x[0, 0] := 777;"
- "END Ax;"
+ "TYPE"
+ " Ident = ARRAY 20 OF CHAR;"
+ " PrintString = PROCEDURE (str : ARRAY OF CHAR);"
+ ""
+ "VAR"
+ " hello : Ident;"
+ " print : PrintString;"
""
- "BEGIN;"
- " NEW(a, 2, 2);"
- " a[0, 0] := 666;"
+ "BEGIN"
+ " print := Out.String;"
+ " hello[0] := h;"
+ " hello[1] := e;"
+ " hello[2] := l;"
+ " hello[3] := l;"
+ " hello[4] := o;"
+ " hello[5] := space;"
+ " hello[6] := w;"
+ " hello[7] := o;"
+ " hello[8] := r;"
+ " hello[9] := l;"
+ " hello[10] := d;"
+ " hello[11] := bang;"
+ " hello[12] := null;"
" Out.Open;"
- " Out.Int(a[0, 0], 0);"
+ " print(hello);"
" Out.Ln;"
- ""
- " Ax(a);"
-// " Out.Int(a[0, 0], 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 Char* (ch : CHAR);"
+ " END Char;"
+ ""
+ " PROCEDURE String* (str : ARRAY OF CHAR);"
+ " END String;"
+ ""
+ " 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."
;
oberon_generate_code(ctx);
- init_system_modules();
+// init_system_modules();
- oberon_generator_dump(ctx, "dump.txt");
+// oberon_generator_dump(ctx, "dump.txt");
- start_module();
+// start_module();
oberon_destroy_context(ctx);
return 0;