index 7c8e6720506e4c8113282b94656fdaf20d44baca..297da8de9a9c9d21c05fe7db43989753f35613cb 100644 (file)
--- a/test.c
+++ b/test.c
#include "oberon.h"
+#include "generator.h"
+
+#include <string.h>
#include <assert.h>
-static const char source[] =
+static char source_test[] =
"MODULE Test;"
- "CONST"
- " con = 3;"
- ""
+ "IMPORT I := Imported;"
"TYPE"
- " MyInt = INTEGER;"
- " MyArr = ARRAY con OF MyInt;"
+ " Callback = PROCEDURE() : INTEGER;"
""
"VAR"
- " k : INTEGER;"
+ " cb : Callback;"
" i : INTEGER;"
- " b : BOOLEAN;"
- " arr : MyArr;"
+ " r : I.Rider;"
""
- "PROCEDURE Tier;"
+ "PROCEDURE RelBack;"
"BEGIN"
- " k := 314 + con;"
- "END Tier;"
+ " i := 666;"
+ "END RelBack;"
""
- "PROCEDURE Tier2(x : INTEGER; y : INTEGER);"
- "BEGIN"
- " k := x + y;"
- "END Tier2;"
+ "BEGIN;"
+ " i := ABS(-1);"
+ " i := cb();"
+ " RelBack;"
+ " I.Ln;"
+ "END Test."
+;
+
+static char source_imported[] =
+ "MODULE Imported;"
+ "TYPE"
+ " Rider = RECORD i : INTEGER; END;"
""
- "PROCEDURE Tier3(x : INTEGER) : INTEGER;"
- "BEGIN"
- " RETURN x * x * x;"
- "END Tier3;"
+ "PROCEDURE Ln;"
+ "END Ln;"
""
- "BEGIN"
- " k := 1;"
- " i := k;"
- " b := (TRUE # FALSE);"
- " Tier();"
- " Tier2(21, 13);"
- " k := Tier3(2);"
-// " arr[0] := 1;"
- "END Test."
+ "BEGIN;"
+ "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;
}