DEADSOFTWARE

Добавлены строки
[dsw-obn.git] / src / test.c
index 69cfc99dc7468b5600745cbd73e54dc02cea8b64..cacf00d30d71189e19360a4b2467ba052f037858 100644 (file)
@@ -4,29 +4,78 @@
 
 #include "../include/oberon.h"
 
+/*
 static char source_test[] =
        "(* Main module *)"
        "MODULE Test;"
+       "IMPORT Out;"
        "VAR"
-       "  l : POINTER TO ARRAY 16 OF BOOLEAN;"
+       "  msg : ARRAY 20 OF CHAR;"
        "BEGIN"
-       "  NEW(l);"
-       "  l[0] := l[5];"
+       "  msg := ''"
+       "END Test."
+;
+*/
+
+static char source_test[] =
+       "(* Main module *)"
+       "MODULE Test;"
+       "IMPORT Out;"
+       "CONST"
+       "  helloworld = 'Hello World!';"
+       "  null = 0X;"
+       "  space = 020X;"
+       "  bang = 021X;"
+       "  h = 048X;"
+       "  e = 045X;"
+       "  l = 04CX;"
+       "  o = 04FX;"
+       "  w = 057X;"
+       "  r = 052X;"
+       "  d = 044X;"
+       ""
+       "TYPE"
+       "  Ident = ARRAY 20 OF CHAR;"
+       "  PrintString = PROCEDURE (str : ARRAY OF CHAR);"
+       ""
+       "VAR"
+       "  msg   : Ident;"
+       "  print : PrintString;"
+       ""
+       "BEGIN"
+       "  msg := helloworld;"
+       "  print := Out.String;"
+       "  Out.Open;"
+       "  print(msg);"
+       "  Out.Ln;"
+       "  print(\"It's works!\");"
+       "  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."
 ;