X-Git-Url: http://deadsoftware.ru/gitweb?a=blobdiff_plain;f=src%2Ftest.c;h=3305807bbb3fa1c87b0cbd508aaec7e6787ebbfb;hb=c055d16f1d6ca38c5c2171dbafd1a25305fb909c;hp=02912bbe97ae1e523f23c91eb2027900a8c15dee;hpb=bd4b622f2ffd3fceefd9caeaff35662a13af201c;p=dsw-obn.git diff --git a/src/test.c b/src/test.c index 02912bb..3305807 100644 --- a/src/test.c +++ b/src/test.c @@ -7,34 +7,63 @@ static char source_test[] = "(* Main module *)" "MODULE Test;" + "IMPORT Out;" "TYPE" - " Rec = POINTER TO RecDesc;" - " RecDesc = RECORD x : INTEGER; END;" + " Callback = PROCEDURE;" + " Callfront = PROCEDURE(x : LONGINT) : LONGINT;" + " RecDesc = RECORD" + " cb : Callback;" + " cf : Callfront;" + " END;" + "" "VAR" - " g : ARRAY 4 OF INTEGER;" - " r : RECORD x : INTEGER; END;" - " a : POINTER TO ARRAY OF ARRAY OF Rec;" + " r : RecDesc;" + " i : LONGINT;" + "" + "PROCEDURE Stuff;" "BEGIN" - " NEW(a, 10, 10);" - " NEW(a[9, 9]);" - " a[9, 9].x := 666;" - " g[3] := 4;" - " r.x := 4546;" + " Out.Int(0123456789, 0); Out.Ln;" + "END Stuff;" + "" + "PROCEDURE Ffuts (x : LONGINT) : LONGINT;" + "BEGIN" + " RETURN 9876543210 + x;" + "END Ffuts;" + "" + "BEGIN" + " Out.Open;" + " Out.Int(1, 0); Out.Ln;" + " r.cb := Stuff;" + " Out.Int(2, 0); Out.Ln;" + " r.cb();" + " Out.Int(3, 0); Out.Ln;" + " r.cf := Ffuts;" + " Out.Int(4, 0); Out.Ln;" + " i := r.cf(0123456789);" + " Out.Int(i, 0); Out.Ln;" "END Test." ; +// PROCEDURE Char* (ch : CHAR); +// PROCEDURE String* (str : ARRAY OF CHAR); + 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 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." ;