X-Git-Url: http://deadsoftware.ru/gitweb?a=blobdiff_plain;f=src%2Ftest.c;h=ad95a34cf1f36fc78a7ed440cff0f1cbfccdd7ea;hb=8b545fd0349be12160b9f50c1f4b6f072eac436f;hp=2b9fd062da0926c61a72b7d0842b9fd02f1eebf0;hpb=961fbb99dcba21ccb737db16c0cdb28d757a2de7;p=dsw-obn.git diff --git a/src/test.c b/src/test.c index 2b9fd06..ad95a34 100644 --- a/src/test.c +++ b/src/test.c @@ -7,42 +7,56 @@ static char source_test[] = "(* Main module *)" "MODULE Test;" - "TYPE" - " Arr = ARRAY 32, 768 OF INTEGER;" - " RecDesc = RECORD x, y, z : INTEGER; END;" + "IMPORT Out;" "" - "VAR" - " z : Arr;" - " r : RecDesc;" + "VAR i : INTEGER;" "" - "PROCEDURE TestRecordCopy(rrr : RecDesc);" - "END TestRecordCopy;" - "" - "PROCEDURE TestArrayCopy(aaa : Arr);" - "END TestArrayCopy;" - "" - "PROCEDURE TestOpenArrayCopy(ppp : ARRAY OF ARRAY OF INTEGER);" - "END TestOpenArrayCopy;" + "PROCEDURE X(VAR x : INTEGER; y : INTEGER);" + " VAR" + " q, w, r : INTEGER;" + " PROCEDURE Y;" + " VAR levY : INTEGER;" + " BEGIN" + " x := 3345;" + " q := 666;" + " END Y;" + "BEGIN" + " x := 54646;" + " q := 1;" + " Y;" + " Out.String('Pos Y: q = '); Out.Int(q, 0); Out.Ln;" + "END X;" "" "BEGIN;" - " TestRecordCopy(r);" - " TestArrayCopy(z);" - " TestOpenArrayCopy(z);" + " i := 1;" + " X(i, i);" + " Out.Int(i, 0); 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." ;