DEADSOFTWARE

Добавлена конструкция WITH
[dsw-obn.git] / src / test.c
index df0ff8041e00d95bae0f2b1827ac74da2fa4d8e3..dab2914ca12507682c8a29122dd5498aebb221b1 100644 (file)
@@ -7,29 +7,61 @@
 static char source_test[] =
        "(* Main module *)"
        "MODULE Test;"
+       "IMPORT Out;"
        "TYPE"
-       "  RecDesc = RECORD a : ARRAY 3, 5 OF INTEGER; END;"
+       "  R1 = POINTER TO R1Desc;"
+       "  R1Desc = RECORD a : INTEGER; END;"
+       "  R2 = POINTER TO R2Desc;"
+       "  R2Desc = RECORD (R1Desc) b : INTEGER; END;"
+       "  Y1 = POINTER TO Y1Desc;"
+       "  Y1Desc = RECORD END;"
        ""
        "VAR"
-       "  a, b : ARRAY 3, 6 OF RecDesc;"
+       "  r1 : R1;"
+       "  r2 : R2;"
+       "  y1 : Y1;"
        ""
        "BEGIN"
-       "  a := b;"
+       "  NEW(r1);"
+       "  NEW(r2);"
+       "  NEW(y1);"
+       "  r1 := r2;"
+       "  Out.Open;"
+       "  WITH r1 : R2 DO"
+       "    r1.b := 666;"
+       "    Out.String('R2 branch');"
+       "  | y1 : Y1 DO"
+       "    Out.String('Y1 branch');"
+       "  ELSE"
+       "    Out.String('Something else');"
+       "  END;"
+       "  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."
 ;