X-Git-Url: http://deadsoftware.ru/gitweb?a=blobdiff_plain;f=src%2Ftest.c;h=d2501611eee396c8c7f2e4036d115937e967eec3;hb=ffca530414fc4c94c3d95b9bc52f4d0cee3326e9;hp=9fad93d4461223fcc752d5a79e48261711e9709d;hpb=d11b76dfc015306841ed4befae800ba1ed7c765b;p=dsw-obn.git diff --git a/src/test.c b/src/test.c index 9fad93d..d250161 100644 --- a/src/test.c +++ b/src/test.c @@ -4,41 +4,108 @@ #include "../include/oberon.h" +/* static char source_test[] = "(* Main module *)" "MODULE Test;" "IMPORT Out;" "" - "VAR" - " byte : BYTE;" - " short : SHORTINT;" - " int : INTEGER;" - " long : LONGINT;" - " real : REAL;" - " longreal : LONGREAL;" + "TYPE" + " R = LONGINT;" "" + "PROCEDURE Factorial(n : R) : R;" "BEGIN" - " Out.Open;" - " byte := 127;" - " int := 666 DIV 2;" - " long := int;" - " real := (4 / 1) - (4 / 3) + (4 / 5) - (4 / 7) + (4 / 9) - (4 / 11) + (4 / 13) - (4 / 15) + (4 / 17);" - " longreal := (4 / 1) - (4 / 3) + (4 / 5) - (4 / 7) + (4 / 9) - (4 / 11) + (4 / 13) - (4 / 15) + (4 / 17);" - " Out.Int(666, 0); Out.Ln;" - " Out.Int(byte, 0); Out.Ln;" - " Out.Real(real, 0); Out.Ln;" - " Out.LongReal(longreal, 0); Out.Ln;" + " 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;" + " Out.Int(Factorial(15), 0); Out.Ln;" + " Out.Int(Factorial(16), 0); Out.Ln;" + " Out.Int(Factorial(17), 0); Out.Ln;" + " Out.Int(Factorial(18), 0); Out.Ln;" + " Out.Int(Factorial(19), 0); Out.Ln;" + " Out.Int(Factorial(20), 0); Out.Ln;" "END Test." ; +*/ -// PROCEDURE Char* (ch : CHAR); -// PROCEDURE String* (str : ARRAY OF CHAR); +static char source_test[] = + "(* Main module *)" + "MODULE Test;" + "IMPORT Out;" + "" + "TYPE" + " R = LONGREAL;" + "" + "PROCEDURE Factorial(n : R) : R;" + "BEGIN" + " IF n <= 1 THEN" + " RETURN 1;" + " ELSE" + " RETURN n * Factorial(n - 1);" + " END;" + " RETURN 0; (* Детектор ретурнов - дерьмо *)" + "END Factorial;" + "" + "BEGIN" + " Out.Open();" + " Out.LongReal(Factorial(0), 0); Out.Ln;" + " Out.LongReal(Factorial(1), 0); Out.Ln;" + " Out.LongReal(Factorial(2), 0); Out.Ln;" + " Out.LongReal(Factorial(3), 0); Out.Ln;" + " Out.LongReal(Factorial(4), 0); Out.Ln;" + " Out.LongReal(Factorial(5), 0); Out.Ln;" + " Out.LongReal(Factorial(6), 0); Out.Ln;" + " Out.LongReal(Factorial(7), 0); Out.Ln;" + " Out.LongReal(Factorial(8), 0); Out.Ln;" + " Out.LongReal(Factorial(9), 0); Out.Ln;" + " Out.LongReal(Factorial(10), 0); Out.Ln;" + " Out.LongReal(Factorial(11), 0); Out.Ln;" + " Out.LongReal(Factorial(12), 0); Out.Ln;" + " Out.LongReal(Factorial(13), 0); Out.Ln;" + " Out.LongReal(Factorial(14), 0); Out.Ln;" + " Out.LongReal(Factorial(15), 0); Out.Ln;" + " Out.LongReal(Factorial(16), 0); Out.Ln;" + " Out.LongReal(Factorial(17), 0); Out.Ln;" + " Out.LongReal(Factorial(18), 0); Out.Ln;" + " Out.LongReal(Factorial(19), 0); Out.Ln;" + " Out.LongReal(Factorial(20), 0); Out.Ln;" + " Out.LongReal(Factorial(170), 0); Out.Ln;" + "END Test." +; static char source_out[] = "MODULE Out;" " 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;" ""