X-Git-Url: http://deadsoftware.ru/gitweb?a=blobdiff_plain;f=src%2Ftest.c;h=dab2914ca12507682c8a29122dd5498aebb221b1;hb=3edc4e955c943735543e2c94ecd28f94d75b32fb;hp=2c5fb0462c6cb482a0d66fbd593af3fa4f85f5d8;hpb=25b73915e7fe0ae7dc51cf6f4a012f021257a35d;p=dsw-obn.git diff --git a/src/test.c b/src/test.c index 2c5fb04..dab2914 100644 --- a/src/test.c +++ b/src/test.c @@ -8,36 +8,48 @@ static char source_test[] = "(* Main module *)" "MODULE Test;" "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;" "" "VAR" - " byte : BYTE;" - " short : SHORTINT;" - " int : INTEGER;" - " long : LONGINT;" - " real : REAL;" - " longreal : LONGREAL;" + " r1 : R1;" + " r2 : R2;" + " y1 : Y1;" "" "BEGIN" + " NEW(r1);" + " NEW(r2);" + " NEW(y1);" + " r1 := r2;" " Out.Open;" - " byte := 127;" - " int := 666;" - " long := int;" - " real := int;" - " longreal := int;" - " Out.Int(666, 0); Out.Ln;" - " Out.Int(byte, 0); Out.Ln;" - " Out.LongReal(real, 0); Out.Ln;" + " 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." ; -// PROCEDURE Char* (ch : CHAR); -// PROCEDURE String* (str : ARRAY OF CHAR); - 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;" ""