X-Git-Url: https://deadsoftware.ru/gitweb?a=blobdiff_plain;f=src%2Ftest.c;h=024252a2def43abc44d82e38d95f1180f551caa2;hb=72048038b5be32cc940c8452541b8bb3e75958a9;hp=18417ba34fa6241d16ae44c53733960a57e2be91;hpb=7bb96abf74bcb31d9a3ecb820b0b6565813bf324;p=dsw-obn.git diff --git a/src/test.c b/src/test.c index 18417ba..024252a 100644 --- a/src/test.c +++ b/src/test.c @@ -7,43 +7,51 @@ static char source_test[] = "(* Main module *)" "MODULE Test;" + "IMPORT Out;" + "" "TYPE" - " P = PROCEDURE;" - " F = PROCEDURE (x : INTEGER) : INTEGER;" + " RecA = POINTER TO RecADesc;" + " RecADesc = RECORD END;" + "" + " RecB = POINTER TO RecBDesc;" + " RecBDesc = RECORD (RecADesc) END;" "" "VAR" - " p : P;" - " f : F;" - " i : INTEGER;" + " a : RecA;" + " b : RecB;" "" - "PROCEDURE Pow(x : INTEGER) : INTEGER;" "BEGIN" - " RETURN x * x;" - "END Pow;" - "" - "PROCEDURE Do;" - "END Do;" - "" - "BEGIN;" - " p := Do;" - " f := Pow;" - " i := f(7);" - " p;" + " NEW(a);" + " NEW(b);" + " Out.Open;" + " a := b;" + " IF a IS RecA THEN Out.String('Yes'); Out.Ln; END;" "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." ;