DEADSOFTWARE

Удалены бэкэнды dummy и libgccjit. Копилятор теперь ориенторован только для jvm и...
[dsw-obn.git] / src / test.c
index 8d2a44f52eaf937af51e28e19712cc92b0e1443a..9fad93d4461223fcc752d5a79e48261711e9709d 100644 (file)
@@ -7,32 +7,50 @@
 static char source_test[] =
        "(* Main module *)"
        "MODULE Test;"
-       "TYPE"
-       "  Rec = POINTER TO RecDesc;"
-       "  RecDesc = RECORD n, m, h : INTEGER END;"
+       "IMPORT Out;"
+       ""
        "VAR"
-       "  r : Rec;"
-       "  i : INTEGER;"
+       "  byte     : BYTE;"
+       "  short    : SHORTINT;"
+       "  int      : INTEGER;"
+       "  long     : LONGINT;"
+       "  real     : REAL;"
+       "  longreal : LONGREAL;"
        ""
-       "BEGIN;"
-       "  NEW(r);"
-       "  i := 666;"
-       "  r.n := r.m;"
+       "BEGIN"
+       "  Out.Open;"
+       "  byte := 127;"
+       "  int := 666 DIV 2;"
+       "  long := int;"
+       "  real := (4 / 1) - (4 / 3) + (4 / 5) - (4 / 7) + (4 / 9) - (4 / 11) + (4 / 13) - (4 / 15) + (4 / 17);"
+       "  longreal := (4 / 1) - (4 / 3) + (4 / 5) - (4 / 7) + (4 / 9) - (4 / 11) + (4 / 13) - (4 / 15) + (4 / 17);"
+       "  Out.Int(666, 0); Out.Ln;"
+       "  Out.Int(byte, 0); Out.Ln;"
+       "  Out.Real(real, 0); Out.Ln;"
+       "  Out.LongReal(longreal, 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."
 ;