X-Git-Url: https://deadsoftware.ru/gitweb?a=blobdiff_plain;f=src%2Ftest.c;h=a144f3616074e1f8891dbc30af0007420bad0ef9;hb=51a1ab2543ec5c221d4a3a9ab89968ae7dd39981;hp=2419c3b7c0045ea6906c517822afe5560bff59bc;hpb=9a82efe08fea56335f331158344b17e6d5280a85;p=dsw-obn.git diff --git a/src/test.c b/src/test.c index 2419c3b..a144f36 100644 --- a/src/test.c +++ b/src/test.c @@ -7,32 +7,64 @@ static char source_test[] = "(* Main module *)" "MODULE Test;" + "IMPORT Out;" + "" "TYPE" - " Packed = ARRAY 16, 32 OF RECORD a : INTEGER; r : RECORD x : INTEGER; END; END;" - " IArray = ARRAY 16, 32, 666 OF INTEGER;" - "VAR" - " k : POINTER TO Packed;" - " ii : POINTER TO IArray;" + " R = INTEGER;" + "" + "PROCEDURE Factorial(n : R) : R;" "BEGIN" - " NEW(k);" - " k[1, 2].a := 666;" - " k[5, 2].r.x := 456;" - " NEW(ii);" + " IF n <= 1 THEN" + " RETURN 1;" + " ELSE" + " RETURN n * Factorial(n - 1);" + " END;" + " RETURN 0; (* Детектор ретурнов - дерьмо *)" + "END Factorial;" + "" + "BEGIN" + " Out.Open();" + " Out.Int(Factorial(0), 0); Out.Ln;" + " Out.Int(Factorial(1), 0); Out.Ln;" + " Out.Int(Factorial(2), 0); Out.Ln;" + " Out.Int(Factorial(3), 0); Out.Ln;" + " Out.Int(Factorial(4), 0); Out.Ln;" + " Out.Int(Factorial(5), 0); Out.Ln;" + " Out.Int(Factorial(6), 0); Out.Ln;" + " Out.Int(Factorial(7), 0); Out.Ln;" + " Out.Int(Factorial(8), 0); Out.Ln;" + " Out.Int(Factorial(9), 0); Out.Ln;" + " Out.Int(Factorial(10), 0); Out.Ln;" + " Out.Int(Factorial(11), 0); Out.Ln;" + " Out.Int(Factorial(12), 0); Out.Ln;" + " Out.Int(Factorial(13), 0); Out.Ln;" + " Out.Int(Factorial(14), 0); 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." ;