DEADSOFTWARE

Теперь возможен вызов процедур-переменных из полей записей
[dsw-obn.git] / src / test.c
index 5939fb6d50dd5dafe933c31cdab8e73a27d37b0d..3305807bbb3fa1c87b0cbd508aaec7e6787ebbfb 100644 (file)
@@ -9,49 +9,58 @@ static char source_test[] =
        "MODULE Test;"
        "IMPORT Out;"
        "TYPE"
-       "  P = PROCEDURE;"
-       "  F = PROCEDURE (x : INTEGER) : INTEGER;"
+       "  Callback = PROCEDURE;"
+       "  Callfront = PROCEDURE(x : LONGINT) : LONGINT;"
+       "  RecDesc = RECORD"
+       "    cb : Callback;"
+       "    cf : Callfront;"
+       "  END;"
        ""
        "VAR"
-       "  p : P;"
-       "  f : F;"
-       "  i : INTEGER;"
+       "  r : RecDesc;"
+       "  i : LONGINT;"
        ""
-       "PROCEDURE Pow(x : INTEGER) : INTEGER;"
+       "PROCEDURE Stuff;"
        "BEGIN"
-       "  RETURN x * x;"
-       "END Pow;"
+       "  Out.Int(0123456789, 0); Out.Ln;"
+       "END Stuff;"
        ""
-       "PROCEDURE Do;"
-       "END Do;"
+       "PROCEDURE Ffuts (x : LONGINT) : LONGINT;"
+       "BEGIN"
+       "  RETURN 9876543210 + x;"
+       "END Ffuts;"
        ""
-       "BEGIN;"
-       "  p := Do;"
-       "  f := Pow;"
-       "  i := f(7);"
-       "  p;"
+       "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;"
-       "  Out.Int(666, 0); Out.Ln;"
        "END Test."
 ;
 
 // PROCEDURE Char* (ch : CHAR);
 // PROCEDURE String* (str : ARRAY OF CHAR);
-// PROCEDURE Int* (i, n : LONGINT); // Должно быть в таком виде
-// PROCEDURE LongReal* (x : LONGREAL; n : INTEGER);
 
 static char source_out[] =
        "MODULE Out;"
        "  PROCEDURE Open*;"
        "  END Open;"
        ""
-       "  PROCEDURE Int*(i, n : INTEGER);"
+       "  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;"
        ""