DEADSOFTWARE

Теперь возможен вызов процедур-переменных из полей записей
[dsw-obn.git] / src / test.c
index 02912bbe97ae1e523f23c91eb2027900a8c15dee..3305807bbb3fa1c87b0cbd508aaec7e6787ebbfb 100644 (file)
@@ -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."
 ;