DEADSOFTWARE

Добавлены фунции вывода для компилируемой программы
[dsw-obn.git] / test.c
diff --git a/test.c b/test.c
index f1b175cf476d22f404de648888f0d39e45c9de81..c3a4b1467f51256bbec89e210374cb69d90a44d8 100644 (file)
--- a/test.c
+++ b/test.c
@@ -7,34 +7,26 @@
 static char source_test[] =
        "(* Main module *)"
        "MODULE Test;"
-       "IMPORT I := Imported;"
-       "VAR"
-       "  x, y : I.Rider;"
-       "PROCEDURE Proc(x, y, z : INTEGER);"
-       "BEGIN"
-       "  x := 1;"
-       "END Proc;"
+       "IMPORT Out;"
        "BEGIN;"
-       "  y.i := 1;"
-       "  I.a[0] := 1;"
+       "  Out.Open;"
+       "  Out.Int(666, 0);"
+       "  Out.Ln;"
        "END Test."
 ;
 
-static char source_imported[] =
-       "MODULE Imported;"
-       "TYPE"
-       "       Rider* = RECORD i*, j-, k : INTEGER; END;"
+static char source_out[] =
+       "MODULE Out;"
        "VAR"
-       "       i- : INTEGER;"
-       "       a* : ARRAY 3 OF INTEGER;"
-       ""
-       "PROCEDURE Ln*;"
-       "END Ln;"
-       ""
-       "BEGIN;"
-       "       i := 1;"
-       "       a[0] := 555;"
-       "END Imported."
+       "  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;"
+       "END Out."
 ;
 
 static oberon_context_t * ctx;
@@ -47,9 +39,9 @@ import_module(const char * name)
        {
                return source_test;
        }
-       else if(strcmp(name, "Imported") == 0)
+       else if(strcmp(name, "Out") == 0)
        {
-               return source_imported;
+               return source_out;
        }
        else
        {
@@ -57,13 +49,56 @@ import_module(const char * name)
        }
 }
 
+typedef void (*TOutOpen)();
+static TOutOpen * OutOpenPtr;
+void ImplOutOpen()
+{
+}
+
+typedef void (*TOutInt)(int, int);
+static TOutInt * OutIntPtr;
+void ImplOutInt(int i, int n)
+{
+       printf("%i", i);
+}
+
+typedef void (*TOutLn)();
+static TOutLn * OutLnPtr;
+void ImplOutLn()
+{
+       printf("\n");
+}
+
+void init_system_modules()
+{
+       OutOpenPtr = oberon_generator_get_var(ctx, "Out_Open");
+       *OutOpenPtr = ImplOutOpen;
+       OutIntPtr = oberon_generator_get_var(ctx, "Out_Int");
+       *OutIntPtr = ImplOutInt;
+       OutLnPtr = oberon_generator_get_var(ctx, "Out_Ln");
+       *OutLnPtr = ImplOutLn;
+}
+
+void start_module()
+{
+       void (*begin)() = oberon_generator_get_procedure(ctx, "Test_BEGIN");
+       begin();
+}
+
 int
 main(int argc, char ** argv)
 {
        ctx = oberon_create_context(import_module);
        mod = oberon_compile_module(ctx, source_test);
+
        oberon_generate_code(ctx);
+
+       init_system_modules();
+
        oberon_generator_dump(ctx, "dump.txt");
+
+       start_module();
+
        oberon_destroy_context(ctx);
        return 0;
 }