X-Git-Url: https://deadsoftware.ru/gitweb?a=blobdiff_plain;f=src%2Ftest.c;h=dab2914ca12507682c8a29122dd5498aebb221b1;hb=3edc4e955c943735543e2c94ecd28f94d75b32fb;hp=d2501611eee396c8c7f2e4036d115937e967eec3;hpb=ffca530414fc4c94c3d95b9bc52f4d0cee3326e9;p=dsw-obn.git diff --git a/src/test.c b/src/test.c index d250161..dab2914 100644 --- a/src/test.c +++ b/src/test.c @@ -4,94 +4,38 @@ #include "../include/oberon.h" -/* static char source_test[] = "(* Main module *)" "MODULE Test;" "IMPORT Out;" - "" "TYPE" - " R = LONGINT;" + " R1 = POINTER TO R1Desc;" + " R1Desc = RECORD a : INTEGER; END;" + " R2 = POINTER TO R2Desc;" + " R2Desc = RECORD (R1Desc) b : INTEGER; END;" + " Y1 = POINTER TO Y1Desc;" + " Y1Desc = RECORD END;" "" - "PROCEDURE Factorial(n : R) : R;" - "BEGIN" - " IF n <= 1 THEN" - " RETURN 1;" - " ELSE" - " RETURN n * Factorial(n - 1);" - " END;" - " RETURN 0; (* Детектор ретурнов - дерьмо *)" - "END Factorial;" + "VAR" + " r1 : R1;" + " r2 : R2;" + " y1 : Y1;" "" "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." -; -*/ - -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;" + " NEW(r1);" + " NEW(r2);" + " NEW(y1);" + " r1 := r2;" + " Out.Open;" + " WITH r1 : R2 DO" + " r1.b := 666;" + " Out.String('R2 branch');" + " | y1 : Y1 DO" + " Out.String('Y1 branch');" " ELSE" - " RETURN n * Factorial(n - 1);" + " Out.String('Something else');" " 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;" + " Out.Ln;" "END Test." ;