X-Git-Url: http://deadsoftware.ru/gitweb?a=blobdiff_plain;f=src%2Ftest.c;h=024252a2def43abc44d82e38d95f1180f551caa2;hb=72048038b5be32cc940c8452541b8bb3e75958a9;hp=3305807bbb3fa1c87b0cbd508aaec7e6787ebbfb;hpb=c055d16f1d6ca38c5c2171dbafd1a25305fb909c;p=dsw-obn.git diff --git a/src/test.c b/src/test.c index 3305807..024252a 100644 --- a/src/test.c +++ b/src/test.c @@ -8,50 +8,38 @@ static char source_test[] = "(* Main module *)" "MODULE Test;" "IMPORT Out;" + "" "TYPE" - " Callback = PROCEDURE;" - " Callfront = PROCEDURE(x : LONGINT) : LONGINT;" - " RecDesc = RECORD" - " cb : Callback;" - " cf : Callfront;" - " END;" + " RecA = POINTER TO RecADesc;" + " RecADesc = RECORD END;" "" - "VAR" - " r : RecDesc;" - " i : LONGINT;" + " RecB = POINTER TO RecBDesc;" + " RecBDesc = RECORD (RecADesc) END;" "" - "PROCEDURE Stuff;" - "BEGIN" - " Out.Int(0123456789, 0); Out.Ln;" - "END Stuff;" - "" - "PROCEDURE Ffuts (x : LONGINT) : LONGINT;" - "BEGIN" - " RETURN 9876543210 + x;" - "END Ffuts;" + "VAR" + " a : RecA;" + " b : RecB;" "" "BEGIN" + " NEW(a);" + " NEW(b);" " 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;" + " a := b;" + " IF a IS RecA THEN Out.String('Yes'); Out.Ln; END;" "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;" ""