DEADSOFTWARE

JVM: Реализован доступ к локальным переменным ровнем выше из локальных процедур
[dsw-obn.git] / src / test.c
index 2b9fd062da0926c61a72b7d0842b9fd02f1eebf0..ad95a34cf1f36fc78a7ed440cff0f1cbfccdd7ea 100644 (file)
@@ -7,42 +7,56 @@
 static char source_test[] =
        "(* Main module *)"
        "MODULE Test;"
-       "TYPE"
-       "  Arr = ARRAY 32, 768 OF INTEGER;"
-       "  RecDesc = RECORD x, y, z : INTEGER; END;"
+       "IMPORT Out;"
        ""
-       "VAR"
-       "  z : Arr;"
-       "  r : RecDesc;"
+       "VAR i : INTEGER;"
        ""
-       "PROCEDURE TestRecordCopy(rrr : RecDesc);"
-       "END TestRecordCopy;"
-       ""
-       "PROCEDURE TestArrayCopy(aaa : Arr);"
-       "END TestArrayCopy;"
-       ""
-       "PROCEDURE TestOpenArrayCopy(ppp : ARRAY OF ARRAY OF INTEGER);"
-       "END TestOpenArrayCopy;"
+       "PROCEDURE X(VAR x : INTEGER; y : INTEGER);"
+       "  VAR"
+       "    q, w, r : INTEGER;"
+       "  PROCEDURE Y;"
+       "    VAR levY : INTEGER;"
+       "  BEGIN"
+       "    x := 3345;"
+       "    q := 666;"
+       "  END Y;"
+       "BEGIN"
+       "  x := 54646;"
+       "  q := 1;"
+       "  Y;"
+       "  Out.String('Pos Y: q = '); Out.Int(q, 0); Out.Ln;"
+       "END X;"
        ""
        "BEGIN;"
-       "  TestRecordCopy(r);"
-       "  TestArrayCopy(z);"
-       "  TestOpenArrayCopy(z);"
+       "  i := 1;"
+       "  X(i, i);"
+       "  Out.Int(i, 0); Out.Ln;"
        "END Test."
 ;
 
 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."
 ;