X-Git-Url: http://deadsoftware.ru/gitweb?a=blobdiff_plain;f=test.c;h=541b3a57f55dae71a8936e0c696f6ad506084340;hb=89dfaf94ddbbc501020554232ce026b6584e8045;hp=178327ecf317a2ad3298036bf70b59a620c1af39;hpb=342c8f1a44765e744c64e14a3b8f1aa4031c5f62;p=dsw-obn.git diff --git a/test.c b/test.c index 178327e..541b3a5 100644 --- a/test.c +++ b/test.c @@ -1,31 +1,67 @@ #include "oberon.h" #include "generator.h" + +#include #include -static const char source[] = +static char source_test[] = "MODULE Test;" - "" - "TYPE" - " MyInt = INTEGER;" - " MyRec = RECORD" - " a : MyInt;" - " END;" - " MyRecPtr = POINTER TO MyRec;" - "" + "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" + " Rider* = RECORD i*, j-, k : INTEGER; END;" + "VAR" + " i- : INTEGER;" + " a* : ARRAY 3 OF INTEGER;" + "" + "PROCEDURE Ln*;" + "END Ln;" + "" + "BEGIN;" + " 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;