X-Git-Url: https://deadsoftware.ru/gitweb?a=blobdiff_plain;f=src%2Ftest.c;h=bcc8e86c8fe1c3a607d1d235ef29bd3d92c62820;hb=e9b64944925eadc5022edfee26281a4814fd9124;hp=1c3c8e39347533eb9db1d0b2e289f0348f77b693;hpb=9e6d0f74f74926a9c73d15418c2e9668689061f2;p=dsw-obn.git diff --git a/src/test.c b/src/test.c index 1c3c8e3..bcc8e86 100644 --- a/src/test.c +++ b/src/test.c @@ -8,39 +8,49 @@ static char source_test[] = "(* Main module *)" "MODULE Test;" "IMPORT Out;" - "TYPE Ar = ARRAY OF ARRAY OF INTEGER;" - "VAR a : POINTER TO Ar;" "" - "PROCEDURE Ax(VAR x : POINTER TO Ar);" - "BEGIN" - " x[0, 0] := 777;" - "END Ax;" - "" - "BEGIN;" - " NEW(a, 2, 2);" - " a[0, 0] := 666;" - " Out.Open;" - " Out.Int(a[0, 0], 0);" - " Out.Ln;" + "VAR" + " i : INTEGER;" "" - " Ax(a);" -// " Out.Int(a[0, 0], 0);" -// " Out.Ln;" + "BEGIN" + " i := 4;" + " Out.Open();" + " IF i = 0 THEN" + " Out.String('Branch 0'); Out.Ln;" + " ELSIF i = 1 THEN" + " Out.String('Branch 1'); Out.Ln;" + " ELSIF i = 2 THEN" + " Out.String('Branch 2'); Out.Ln;" + " ELSE" + " Out.String('Branch else'); Out.Ln;" + " END;" + " Out.String('end'); Out.Ln;" "END Test." ; 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." ; @@ -131,11 +141,11 @@ main(int argc, char ** argv) 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;