X-Git-Url: https://deadsoftware.ru/gitweb?a=blobdiff_plain;f=src%2Ftest.c;h=dab2914ca12507682c8a29122dd5498aebb221b1;hb=3edc4e955c943735543e2c94ecd28f94d75b32fb;hp=0c80e4b7284e5cf5227ab29dfcbac7d87bb81631;hpb=3b56d873cc052fcbe8914dba3b9ae9ea220a801e;p=dsw-obn.git diff --git a/src/test.c b/src/test.c index 0c80e4b..dab2914 100644 --- a/src/test.c +++ b/src/test.c @@ -7,32 +7,61 @@ static char source_test[] = "(* Main module *)" "MODULE Test;" - "VAR" - " x : INTEGER;" - " z : BOOLEAN;" + "IMPORT Out;" + "TYPE" + " 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 Tier(x : INTEGER);" - "END Tier;" + "VAR" + " r1 : R1;" + " r2 : R2;" + " y1 : Y1;" "" - "BEGIN;" - " x := x + 1;" - " z := TRUE;" - " Tier(666);" + "BEGIN" + " 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" + " Out.String('Something else');" + " 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." ;