X-Git-Url: http://deadsoftware.ru/gitweb?a=blobdiff_plain;f=src%2Ftest.c;h=5939fb6d50dd5dafe933c31cdab8e73a27d37b0d;hb=eaa8fd70cad0ba4e5ce8ab219d6964b47f647ec6;hp=0c80e4b7284e5cf5227ab29dfcbac7d87bb81631;hpb=3b56d873cc052fcbe8914dba3b9ae9ea220a801e;p=dsw-obn.git diff --git a/src/test.c b/src/test.c index 0c80e4b..5939fb6 100644 --- a/src/test.c +++ b/src/test.c @@ -7,32 +7,54 @@ static char source_test[] = "(* Main module *)" "MODULE Test;" + "IMPORT Out;" + "TYPE" + " P = PROCEDURE;" + " F = PROCEDURE (x : INTEGER) : INTEGER;" + "" "VAR" - " x : INTEGER;" - " z : BOOLEAN;" + " p : P;" + " f : F;" + " i : INTEGER;" + "" + "PROCEDURE Pow(x : INTEGER) : INTEGER;" + "BEGIN" + " RETURN x * x;" + "END Pow;" "" - "PROCEDURE Tier(x : INTEGER);" - "END Tier;" + "PROCEDURE Do;" + "END Do;" "" "BEGIN;" - " x := x + 1;" - " z := TRUE;" - " Tier(666);" + " p := Do;" + " f := Pow;" + " i := f(7);" + " p;" + " Out.Open;" + " Out.Int(i, 0); Out.Ln;" + " Out.Int(666, 0); Out.Ln;" "END Test." ; +// PROCEDURE Char* (ch : CHAR); +// PROCEDURE String* (str : ARRAY OF CHAR); +// PROCEDURE Int* (i, n : LONGINT); // Должно быть в таком виде +// PROCEDURE LongReal* (x : LONGREAL; n : INTEGER); + 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 : INTEGER);" + " END Int;" + "" + " PROCEDURE Real*(x : REAL; n : INTEGER);" + " END Real;" + "" + " PROCEDURE Ln*;" + " END Ln;" + "" "END Out." ;