DEADSOFTWARE

Исправлен экспорт полей и экспорт для "только чтения"
[dsw-obn.git] / test.c
diff --git a/test.c b/test.c
index 6b6d335760a57a4fd9e5ca68af3c95b849c96d38..541b3a57f55dae71a8936e0c696f6ad506084340 100644 (file)
--- a/test.c
+++ b/test.c
@@ -1,37 +1,67 @@
 #include "oberon.h"
 #include "generator.h"
+
+#include <string.h>
 #include <assert.h>
 
-static const char source[] =
+static char source_test[] =
        "MODULE Test;"
+       "IMPORT I := Imported;"
+       "VAR"
+       "  x, y : I.Rider;"
+       "PROCEDURE Proc(x, y, z : INTEGER);"
+       "BEGIN"
+       "  x := 1;"
+       "END Proc;"
+       "BEGIN;"
+       "  y.i := 1;"
+       "  I.a[0] := 1;"
+       "END Test."
+;
+
+static char source_imported[] =
+       "MODULE Imported;"
        "TYPE"
-       "       Callback = PROCEDURE() : INTEGER;"
-       ""
+       "       Rider* = RECORD i*, j-, k : INTEGER; END;"
        "VAR"
-       "       cb : Callback;"
-       "       i : INTEGER;"
+       "       i- : INTEGER;"
+       "       a* : ARRAY 3 OF INTEGER;"
        ""
-       "PROCEDURE RelBack;"
-       "BEGIN"
-       "       i := 666;"
-       "END RelBack;"
+       "PROCEDURE Ln*;"
+       "END Ln;"
        ""
        "BEGIN;"
-       "       i := ABS(-1);"
-       "       i := cb();"
-       "       RelBack;"
-       "END Test."
+       "       i := 1;"
+       "       a[0] := 555;"
+       "END Imported."
 ;
 
 static oberon_context_t * ctx;
 static oberon_module_t * mod;
 
+static const char *
+import_module(const char * name)
+{
+       if(strcmp(name, "Test") == 0)
+       {
+               return source_test;
+       }
+       else if(strcmp(name, "Imported") == 0)
+       {
+               return source_imported;
+       }
+       else
+       {
+               return NULL;
+       }
+}
+
 int
 main(int argc, char ** argv)
 {
-       ctx = oberon_create_context();
-       mod = oberon_compile_module(ctx, source);
-       //mod -> begin();
+       ctx = oberon_create_context(import_module);
+       mod = oberon_compile_module(ctx, source_test);
+       oberon_generate_code(ctx);
        oberon_generator_dump(ctx, "dump.txt");
        oberon_destroy_context(ctx);
        return 0;