X-Git-Url: https://deadsoftware.ru/gitweb?a=blobdiff_plain;f=src%2Ftest.c;h=d2950b968189c70a5f4b743c5131cd9682498959;hb=ee7fd939ac99201466900fb3983aa90b980da5c3;hp=53be5869213c0d3ee4a5e3e7fcd30639cf82ea59;hpb=2a0d7e7fbb7dcccc65f98301a0627ee47c755f2f;p=dsw-obn.git diff --git a/src/test.c b/src/test.c index 53be586..d2950b9 100644 --- a/src/test.c +++ b/src/test.c @@ -7,31 +7,74 @@ static char source_test[] = "(* Main module *)" "MODULE Test;" - "VAR" - " x : INTEGER;" - " z : BOOLEAN;" + "IMPORT Out;" + "CONST" + " null = 0X;" + " space = 020X;" + " bang = 021X;" + " h = 048X;" + " e = 045X;" + " l = 04CX;" + " o = 04FX;" + " w = 057X;" + " r = 052X;" + " d = 044X;" + "" + "TYPE" + " Ident = ARRAY 20 OF CHAR;" + " PrintString = PROCEDURE (str : ARRAY OF CHAR);" "" - "PROCEDURE Tier(a, b :INTEGER);" - "END Tier;" + "VAR" + " hello : Ident;" + " print : PrintString;" "" - "BEGIN;" - " x := x + 1;" - " z := TRUE;" + "BEGIN" + " print := Out.String;" + " hello[0] := h;" + " hello[1] := e;" + " hello[2] := l;" + " hello[3] := l;" + " hello[4] := o;" + " hello[5] := space;" + " hello[6] := w;" + " hello[7] := o;" + " hello[8] := r;" + " hello[9] := l;" + " hello[10] := d;" + " hello[11] := bang;" + " hello[12] := null;" + " Out.Open;" + " print(hello);" + " 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 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." ;