c_src: regenerate
[nit.git] / c_src / modelbuilder.sep.1.c
diff --git a/c_src/modelbuilder.sep.1.c b/c_src/modelbuilder.sep.1.c
deleted file mode 100644 (file)
index 4b1f57c..0000000
+++ /dev/null
@@ -1,3332 +0,0 @@
-#include "modelbuilder.sep.0.h"
-/* method modelbuilder#ToolContext#opt_path for (self: ToolContext): OptionArray */
-val* modelbuilder__ToolContext__opt_path(val* self) {
-val* var /* : OptionArray */;
-val* var1 /* : OptionArray */;
-var1 = self->attrs[COLOR_modelbuilder__ToolContext___64dopt_path].val; /* @opt_path on <self:ToolContext> */
-if (var1 == NULL) {
-fprintf(stderr, "Runtime error: %s", "Uninitialized attribute @opt_path");
-fprintf(stderr, " (%s:%d)\n", "src/modelbuilder.nit", 37);
-exit(1);
-}
-var = var1;
-RET_LABEL:;
-return var;
-}
-/* method modelbuilder#ToolContext#opt_path for (self: Object): OptionArray */
-val* VIRTUAL_modelbuilder__ToolContext__opt_path(val* self) {
-val* var /* : OptionArray */;
-val* var1 /* : OptionArray */;
-var1 = modelbuilder__ToolContext__opt_path(self);
-var = var1;
-RET_LABEL:;
-return var;
-}
-/* method modelbuilder#ToolContext#opt_path= for (self: ToolContext, OptionArray) */
-void modelbuilder__ToolContext__opt_path_61d(val* self, val* p0) {
-self->attrs[COLOR_modelbuilder__ToolContext___64dopt_path].val = p0; /* @opt_path on <self:ToolContext> */
-RET_LABEL:;
-}
-/* method modelbuilder#ToolContext#opt_path= for (self: Object, OptionArray) */
-void VIRTUAL_modelbuilder__ToolContext__opt_path_61d(val* self, val* p0) {
-modelbuilder__ToolContext__opt_path_61d(self, p0);
-RET_LABEL:;
-}
-/* method modelbuilder#ToolContext#opt_only_metamodel for (self: ToolContext): OptionBool */
-val* modelbuilder__ToolContext__opt_only_metamodel(val* self) {
-val* var /* : OptionBool */;
-val* var1 /* : OptionBool */;
-var1 = self->attrs[COLOR_modelbuilder__ToolContext___64dopt_only_metamodel].val; /* @opt_only_metamodel on <self:ToolContext> */
-if (var1 == NULL) {
-fprintf(stderr, "Runtime error: %s", "Uninitialized attribute @opt_only_metamodel");
-fprintf(stderr, " (%s:%d)\n", "src/modelbuilder.nit", 40);
-exit(1);
-}
-var = var1;
-RET_LABEL:;
-return var;
-}
-/* method modelbuilder#ToolContext#opt_only_metamodel for (self: Object): OptionBool */
-val* VIRTUAL_modelbuilder__ToolContext__opt_only_metamodel(val* self) {
-val* var /* : OptionBool */;
-val* var1 /* : OptionBool */;
-var1 = modelbuilder__ToolContext__opt_only_metamodel(self);
-var = var1;
-RET_LABEL:;
-return var;
-}
-/* method modelbuilder#ToolContext#opt_only_metamodel= for (self: ToolContext, OptionBool) */
-void modelbuilder__ToolContext__opt_only_metamodel_61d(val* self, val* p0) {
-self->attrs[COLOR_modelbuilder__ToolContext___64dopt_only_metamodel].val = p0; /* @opt_only_metamodel on <self:ToolContext> */
-RET_LABEL:;
-}
-/* method modelbuilder#ToolContext#opt_only_metamodel= for (self: Object, OptionBool) */
-void VIRTUAL_modelbuilder__ToolContext__opt_only_metamodel_61d(val* self, val* p0) {
-modelbuilder__ToolContext__opt_only_metamodel_61d(self, p0);
-RET_LABEL:;
-}
-/* method modelbuilder#ToolContext#opt_only_parse for (self: ToolContext): OptionBool */
-val* modelbuilder__ToolContext__opt_only_parse(val* self) {
-val* var /* : OptionBool */;
-val* var1 /* : OptionBool */;
-var1 = self->attrs[COLOR_modelbuilder__ToolContext___64dopt_only_parse].val; /* @opt_only_parse on <self:ToolContext> */
-if (var1 == NULL) {
-fprintf(stderr, "Runtime error: %s", "Uninitialized attribute @opt_only_parse");
-fprintf(stderr, " (%s:%d)\n", "src/modelbuilder.nit", 43);
-exit(1);
-}
-var = var1;
-RET_LABEL:;
-return var;
-}
-/* method modelbuilder#ToolContext#opt_only_parse for (self: Object): OptionBool */
-val* VIRTUAL_modelbuilder__ToolContext__opt_only_parse(val* self) {
-val* var /* : OptionBool */;
-val* var1 /* : OptionBool */;
-var1 = modelbuilder__ToolContext__opt_only_parse(self);
-var = var1;
-RET_LABEL:;
-return var;
-}
-/* method modelbuilder#ToolContext#opt_only_parse= for (self: ToolContext, OptionBool) */
-void modelbuilder__ToolContext__opt_only_parse_61d(val* self, val* p0) {
-self->attrs[COLOR_modelbuilder__ToolContext___64dopt_only_parse].val = p0; /* @opt_only_parse on <self:ToolContext> */
-RET_LABEL:;
-}
-/* method modelbuilder#ToolContext#opt_only_parse= for (self: Object, OptionBool) */
-void VIRTUAL_modelbuilder__ToolContext__opt_only_parse_61d(val* self, val* p0) {
-modelbuilder__ToolContext__opt_only_parse_61d(self, p0);
-RET_LABEL:;
-}
-/* method modelbuilder#ToolContext#init for (self: ToolContext) */
-void modelbuilder__ToolContext__init(val* self) {
-val* var /* : OptionContext */;
-val* var1 /* : OptionArray */;
-val* var2 /* : OptionBool */;
-val* var3 /* : OptionBool */;
-val* var4 /* : Array[Option] */;
-long var5 /* : Int */;
-val* var6 /* : NativeArray[Option] */;
-((void (*)(val*))(self->class->vft[COLOR_modelbuilder__ToolContext__init]))(self) /* init on <self:ToolContext>*/;
-var = ((val* (*)(val*))(self->class->vft[COLOR_toolcontext__ToolContext__option_context]))(self) /* option_context on <self:ToolContext>*/;
-var1 = ((val* (*)(val*))(self->class->vft[COLOR_modelbuilder__ToolContext__opt_path]))(self) /* opt_path on <self:ToolContext>*/;
-var2 = ((val* (*)(val*))(self->class->vft[COLOR_modelbuilder__ToolContext__opt_only_parse]))(self) /* opt_only_parse on <self:ToolContext>*/;
-var3 = ((val* (*)(val*))(self->class->vft[COLOR_modelbuilder__ToolContext__opt_only_metamodel]))(self) /* opt_only_metamodel on <self:ToolContext>*/;
-var4 = NEW_array__Array(&type_array__Arrayopts__Option);
-{ /* var4 = array_instance Array[Option] */
-var5 = 3;
-var6 = NEW_array__NativeArray(var5, &type_array__NativeArrayopts__Option);
-((struct instance_array__NativeArray*)var6)->values[0] = (val*) var1;
-((struct instance_array__NativeArray*)var6)->values[1] = (val*) var2;
-((struct instance_array__NativeArray*)var6)->values[2] = (val*) var3;
-((void (*)(val*, val*, long))(var4->class->vft[COLOR_array__Array__with_native]))(var4, var6, var5) /* with_native on <var4:Array[Option]>*/;
-CHECK_NEW_array__Array(var4);
-}
-((void (*)(val*, val*))(var->class->vft[COLOR_opts__OptionContext__add_option]))(var, var4) /* add_option on <var:OptionContext>*/;
-RET_LABEL:;
-}
-/* method modelbuilder#ToolContext#init for (self: Object) */
-void VIRTUAL_modelbuilder__ToolContext__init(val* self) {
-modelbuilder__ToolContext__init(self);
-RET_LABEL:;
-}
-/* method modelbuilder#ToolContext#modelbuilder for (self: ToolContext): ModelBuilder */
-val* modelbuilder__ToolContext__modelbuilder(val* self) {
-val* var /* : ModelBuilder */;
-val* var1 /* : nullable ModelBuilder */;
-var1 = ((val* (*)(val*))(self->class->vft[COLOR_modelbuilder__ToolContext__modelbuilder_real]))(self) /* modelbuilder_real on <self:ToolContext>*/;
-if (var1 == NULL) {
-fprintf(stderr, "Runtime error: %s", "Cast failed");
-fprintf(stderr, " (%s:%d)\n", "src/modelbuilder.nit", 52);
-exit(1);
-}
-var = var1;
-goto RET_LABEL;
-RET_LABEL:;
-return var;
-}
-/* method modelbuilder#ToolContext#modelbuilder for (self: Object): ModelBuilder */
-val* VIRTUAL_modelbuilder__ToolContext__modelbuilder(val* self) {
-val* var /* : ModelBuilder */;
-val* var1 /* : ModelBuilder */;
-var1 = modelbuilder__ToolContext__modelbuilder(self);
-var = var1;
-RET_LABEL:;
-return var;
-}
-/* method modelbuilder#ToolContext#modelbuilder_real for (self: ToolContext): nullable ModelBuilder */
-val* modelbuilder__ToolContext__modelbuilder_real(val* self) {
-val* var /* : nullable ModelBuilder */;
-val* var1 /* : nullable ModelBuilder */;
-var1 = self->attrs[COLOR_modelbuilder__ToolContext___64dmodelbuilder_real].val; /* @modelbuilder_real on <self:ToolContext> */
-var = var1;
-RET_LABEL:;
-return var;
-}
-/* method modelbuilder#ToolContext#modelbuilder_real for (self: Object): nullable ModelBuilder */
-val* VIRTUAL_modelbuilder__ToolContext__modelbuilder_real(val* self) {
-val* var /* : nullable ModelBuilder */;
-val* var1 /* : nullable ModelBuilder */;
-var1 = modelbuilder__ToolContext__modelbuilder_real(self);
-var = var1;
-RET_LABEL:;
-return var;
-}
-/* method modelbuilder#ToolContext#modelbuilder_real= for (self: ToolContext, nullable ModelBuilder) */
-void modelbuilder__ToolContext__modelbuilder_real_61d(val* self, val* p0) {
-self->attrs[COLOR_modelbuilder__ToolContext___64dmodelbuilder_real].val = p0; /* @modelbuilder_real on <self:ToolContext> */
-RET_LABEL:;
-}
-/* method modelbuilder#ToolContext#modelbuilder_real= for (self: Object, nullable ModelBuilder) */
-void VIRTUAL_modelbuilder__ToolContext__modelbuilder_real_61d(val* self, val* p0) {
-modelbuilder__ToolContext__modelbuilder_real_61d(self, p0);
-RET_LABEL:;
-}
-/* method modelbuilder#ModelBuilder#model for (self: ModelBuilder): Model */
-val* modelbuilder__ModelBuilder__model(val* self) {
-val* var /* : Model */;
-val* var1 /* : Model */;
-var1 = self->attrs[COLOR_modelbuilder__ModelBuilder___64dmodel].val; /* @model on <self:ModelBuilder> */
-if (var1 == NULL) {
-fprintf(stderr, "Runtime error: %s", "Uninitialized attribute @model");
-fprintf(stderr, " (%s:%d)\n", "src/modelbuilder.nit", 59);
-exit(1);
-}
-var = var1;
-RET_LABEL:;
-return var;
-}
-/* method modelbuilder#ModelBuilder#model for (self: Object): Model */
-val* VIRTUAL_modelbuilder__ModelBuilder__model(val* self) {
-val* var /* : Model */;
-val* var1 /* : Model */;
-var1 = modelbuilder__ModelBuilder__model(self);
-var = var1;
-RET_LABEL:;
-return var;
-}
-/* method modelbuilder#ModelBuilder#model= for (self: ModelBuilder, Model) */
-void modelbuilder__ModelBuilder__model_61d(val* self, val* p0) {
-self->attrs[COLOR_modelbuilder__ModelBuilder___64dmodel].val = p0; /* @model on <self:ModelBuilder> */
-RET_LABEL:;
-}
-/* method modelbuilder#ModelBuilder#model= for (self: Object, Model) */
-void VIRTUAL_modelbuilder__ModelBuilder__model_61d(val* self, val* p0) {
-modelbuilder__ModelBuilder__model_61d(self, p0);
-RET_LABEL:;
-}
-/* method modelbuilder#ModelBuilder#toolcontext for (self: ModelBuilder): ToolContext */
-val* modelbuilder__ModelBuilder__toolcontext(val* self) {
-val* var /* : ToolContext */;
-val* var1 /* : ToolContext */;
-var1 = self->attrs[COLOR_modelbuilder__ModelBuilder___64dtoolcontext].val; /* @toolcontext on <self:ModelBuilder> */
-if (var1 == NULL) {
-fprintf(stderr, "Runtime error: %s", "Uninitialized attribute @toolcontext");
-fprintf(stderr, " (%s:%d)\n", "src/modelbuilder.nit", 62);
-exit(1);
-}
-var = var1;
-RET_LABEL:;
-return var;
-}
-/* method modelbuilder#ModelBuilder#toolcontext for (self: Object): ToolContext */
-val* VIRTUAL_modelbuilder__ModelBuilder__toolcontext(val* self) {
-val* var /* : ToolContext */;
-val* var1 /* : ToolContext */;
-var1 = modelbuilder__ModelBuilder__toolcontext(self);
-var = var1;
-RET_LABEL:;
-return var;
-}
-/* method modelbuilder#ModelBuilder#toolcontext= for (self: ModelBuilder, ToolContext) */
-void modelbuilder__ModelBuilder__toolcontext_61d(val* self, val* p0) {
-self->attrs[COLOR_modelbuilder__ModelBuilder___64dtoolcontext].val = p0; /* @toolcontext on <self:ModelBuilder> */
-RET_LABEL:;
-}
-/* method modelbuilder#ModelBuilder#toolcontext= for (self: Object, ToolContext) */
-void VIRTUAL_modelbuilder__ModelBuilder__toolcontext_61d(val* self, val* p0) {
-modelbuilder__ModelBuilder__toolcontext_61d(self, p0);
-RET_LABEL:;
-}
-/* method modelbuilder#ModelBuilder#run_phases for (self: ModelBuilder) */
-void modelbuilder__ModelBuilder__run_phases(val* self) {
-val* var /* : Model */;
-val* var1 /* : Array[MModule] */;
-val* var2 /* : Array[nullable Object] */;
-val* var_mmodules /* var mmodules: Array[MModule] */;
-val* var3 /* : Model */;
-val* var4 /* : POSet[MModule] */;
-val* var5 /* : Array[AModule] */;
-val* var_nmodules /* var nmodules: Array[AModule] */;
-val* var6 /* : Iterator[nullable Object] */;
-short int var7 /* : Bool */;
-val* var8 /* : nullable Object */;
-val* var_mm /* var mm: MModule */;
-val* var9 /* : HashMap[MModule, AModule] */;
-val* var10 /* : nullable Object */;
-val* var11 /* : ToolContext */;
-val* var12 /* : ToolContext */;
-val* var13 /* : OptionBool */;
-val* var14 /* : nullable Object */;
-short int var15 /* : Bool */;
-val* var16 /* : ToolContext */;
-static val* varonce;
-val* var17 /* : String */;
-char* var18 /* : NativeString */;
-long var19 /* : Int */;
-val* var20 /* : String */;
-long var21 /* : Int */;
-long var22 /* : Int */;
-var = ((val* (*)(val*))(self->class->vft[COLOR_modelbuilder__ModelBuilder__model]))(self) /* model on <self:ModelBuilder>*/;
-var1 = ((val* (*)(val*))(var->class->vft[COLOR_model_base__Model__mmodules]))(var) /* mmodules on <var:Model>*/;
-var2 = ((val* (*)(val*))(var1->class->vft[COLOR_array__Collection__to_a]))(var1) /* to_a on <var1:Array[MModule]>*/;
-var_mmodules = var2;
-var3 = ((val* (*)(val*))(self->class->vft[COLOR_modelbuilder__ModelBuilder__model]))(self) /* model on <self:ModelBuilder>*/;
-var4 = ((val* (*)(val*))(var3->class->vft[COLOR_model_base__Model__mmodule_importation_hierarchy]))(var3) /* mmodule_importation_hierarchy on <var3:Model>*/;
-((void (*)(val*, val*))(var4->class->vft[COLOR_sorter__AbstractSorter__sort]))(var4, var_mmodules) /* sort on <var4:POSet[MModule]>*/;
-var5 = NEW_array__Array(&type_array__Arrayparser_nodes__AModule);
-((void (*)(val*))(var5->class->vft[COLOR_array__Array__init]))(var5) /* init on <var5:Array[AModule]>*/;
-CHECK_NEW_array__Array(var5);
-var_nmodules = var5;
-var6 = ((val* (*)(val*))(var_mmodules->class->vft[COLOR_abstract_collection__Collection__iterator]))(var_mmodules) /* iterator on <var_mmodules:Array[MModule]>*/;
-for(;;) {
-var7 = ((short int (*)(val*))(var6->class->vft[COLOR_abstract_collection__Iterator__is_ok]))(var6) /* is_ok on <var6:Iterator[nullable Object]>*/;
-if(!var7) break;
-var8 = ((val* (*)(val*))(var6->class->vft[COLOR_abstract_collection__Iterator__item]))(var6) /* item on <var6:Iterator[nullable Object]>*/;
-var_mm = var8;
-var9 = ((val* (*)(val*))(self->class->vft[COLOR_modelbuilder__ModelBuilder__mmodule2nmodule]))(self) /* mmodule2nmodule on <self:ModelBuilder>*/;
-var10 = ((val* (*)(val*, val*))(var9->class->vft[COLOR_abstract_collection__MapRead___91d_93d]))(var9, var_mm) /* [] on <var9:HashMap[MModule, AModule]>*/;
-((void (*)(val*, val*))(var_nmodules->class->vft[COLOR_abstract_collection__SimpleCollection__add]))(var_nmodules, var10) /* add on <var_nmodules:Array[AModule]>*/;
-CONTINUE_label: (void)0;
-((void (*)(val*))(var6->class->vft[COLOR_abstract_collection__Iterator__next]))(var6) /* next on <var6:Iterator[nullable Object]>*/;
-}
-BREAK_label: (void)0;
-var11 = ((val* (*)(val*))(self->class->vft[COLOR_modelbuilder__ModelBuilder__toolcontext]))(self) /* toolcontext on <self:ModelBuilder>*/;
-((void (*)(val*, val*))(var11->class->vft[COLOR_phase__ToolContext__run_phases]))(var11, var_nmodules) /* run_phases on <var11:ToolContext>*/;
-var12 = ((val* (*)(val*))(self->class->vft[COLOR_modelbuilder__ModelBuilder__toolcontext]))(self) /* toolcontext on <self:ModelBuilder>*/;
-var13 = ((val* (*)(val*))(var12->class->vft[COLOR_modelbuilder__ToolContext__opt_only_metamodel]))(var12) /* opt_only_metamodel on <var12:ToolContext>*/;
-var14 = ((val* (*)(val*))(var13->class->vft[COLOR_opts__Option__value]))(var13) /* value on <var13:OptionBool>*/;
-var15 = ((struct instance_kernel__Bool*)var14)->value; /* autounbox from nullable Object to Bool */;
-if (var15){
-var16 = ((val* (*)(val*))(self->class->vft[COLOR_modelbuilder__ModelBuilder__toolcontext]))(self) /* toolcontext on <self:ModelBuilder>*/;
-if (varonce) {
-var17 = varonce;
-} else {
-var18 = "*** ONLY METAMODEL";
-var19 = 18;
-var20 = string__NativeString__to_s_with_length(var18, var19);
-var17 = var20;
-varonce = var17;
-}
-var21 = 1;
-((void (*)(val*, val*, long))(var16->class->vft[COLOR_toolcontext__ToolContext__info]))(var16, var17, var21) /* info on <var16:ToolContext>*/;
-var22 = 0;
-((void (*)(val*, long))(self->class->vft[COLOR_kernel__Object__exit]))(self, var22) /* exit on <self:ModelBuilder>*/;
-} else {
-}
-RET_LABEL:;
-}
-/* method modelbuilder#ModelBuilder#run_phases for (self: Object) */
-void VIRTUAL_modelbuilder__ModelBuilder__run_phases(val* self) {
-modelbuilder__ModelBuilder__run_phases(self);
-RET_LABEL:;
-}
-/* method modelbuilder#ModelBuilder#init for (self: ModelBuilder, Model, ToolContext) */
-void modelbuilder__ModelBuilder__init(val* self, val* p0, val* p1) {
-val* var_model /* var model: Model */;
-val* var_toolcontext /* var toolcontext: ToolContext */;
-val* var /* : nullable ModelBuilder */;
-val* var1 /* : null */;
-short int var2 /* : Bool */;
-val* var3 /* : Array[String] */;
-val* var4 /* : OptionArray */;
-val* var5 /* : nullable Object */;
-static val* varonce;
-val* var6 /* : String */;
-char* var7 /* : NativeString */;
-long var8 /* : Int */;
-val* var9 /* : String */;
-val* var10 /* : String */;
-val* var_path_env /* var path_env: String */;
-short int var11 /* : Bool */;
-short int var12 /* : Bool */;
-val* var13 /* : Array[String] */;
-char var14 /* : Char */;
-val* var15 /* : Array[String] */;
-val* var16 /* : Pattern */;
-static val* varonce17;
-val* var18 /* : String */;
-char* var19 /* : NativeString */;
-long var20 /* : Int */;
-val* var21 /* : String */;
-val* var22 /* : String */;
-short int var23 /* : Bool */;
-short int var24 /* : Bool */;
-val* var25 /* : Array[Object] */;
-long var26 /* : Int */;
-val* var_ /* var : Array[Object] */;
-static val* varonce27;
-val* var28 /* : String */;
-char* var29 /* : NativeString */;
-long var30 /* : Int */;
-val* var31 /* : String */;
-static val* varonce32;
-val* var33 /* : String */;
-char* var34 /* : NativeString */;
-long var35 /* : Int */;
-val* var36 /* : String */;
-val* var37 /* : String */;
-val* var_libname /* var libname: String */;
-short int var38 /* : Bool */;
-val* var39 /* : Array[String] */;
-val* var40 /* : Array[Object] */;
-long var41 /* : Int */;
-val* var_42 /* var : Array[Object] */;
-static val* varonce43;
-val* var44 /* : String */;
-char* var45 /* : NativeString */;
-long var46 /* : Int */;
-val* var47 /* : String */;
-val* var48 /* : Sys */;
-val* var49 /* : String */;
-val* var50 /* : String */;
-static val* varonce51;
-val* var52 /* : String */;
-char* var53 /* : NativeString */;
-long var54 /* : Int */;
-val* var55 /* : String */;
-val* var56 /* : String */;
-val* var_libname57 /* var libname: String */;
-short int var58 /* : Bool */;
-val* var59 /* : Array[String] */;
-val* var60 /* : String */;
-var_model = p0;
-var_toolcontext = p1;
-((void (*)(val*, val*))(self->class->vft[COLOR_modelbuilder__ModelBuilder__model_61d]))(self, var_model) /* model= on <self:ModelBuilder>*/;
-((void (*)(val*, val*))(self->class->vft[COLOR_modelbuilder__ModelBuilder__toolcontext_61d]))(self, var_toolcontext) /* toolcontext= on <self:ModelBuilder>*/;
-var = ((val* (*)(val*))(var_toolcontext->class->vft[COLOR_modelbuilder__ToolContext__modelbuilder_real]))(var_toolcontext) /* modelbuilder_real on <var_toolcontext:ToolContext>*/;
-var1 = NULL;
-if (var == NULL) {
-var2 = 1; /* is null */
-} else {
-var2 = 0; /* arg is null but recv is not */
-}
-if (!var2) {
-fprintf(stderr, "Runtime error: %s", "Assert failed");
-fprintf(stderr, " (%s:%d)\n", "src/modelbuilder.nit", 88);
-exit(1);
-}
-((void (*)(val*, val*))(var_toolcontext->class->vft[COLOR_modelbuilder__ToolContext__modelbuilder_real_61d]))(var_toolcontext, self) /* modelbuilder_real= on <var_toolcontext:ToolContext>*/;
-var3 = ((val* (*)(val*))(self->class->vft[COLOR_modelbuilder__ModelBuilder__paths]))(self) /* paths on <self:ModelBuilder>*/;
-var4 = ((val* (*)(val*))(var_toolcontext->class->vft[COLOR_modelbuilder__ToolContext__opt_path]))(var_toolcontext) /* opt_path on <var_toolcontext:ToolContext>*/;
-var5 = ((val* (*)(val*))(var4->class->vft[COLOR_opts__Option__value]))(var4) /* value on <var4:OptionArray>*/;
-((void (*)(val*, val*))(var3->class->vft[COLOR_abstract_collection__Sequence__append]))(var3, var5) /* append on <var3:Array[String]>*/;
-if (varonce) {
-var6 = varonce;
-} else {
-var7 = "NIT_PATH";
-var8 = 8;
-var9 = string__NativeString__to_s_with_length(var7, var8);
-var6 = var9;
-varonce = var6;
-}
-var10 = ((val* (*)(val*))(var6->class->vft[COLOR_environ__String__environ]))(var6) /* environ on <var6:String>*/;
-var_path_env = var10;
-var11 = ((short int (*)(val*))(var_path_env->class->vft[COLOR_abstract_collection__Collection__is_empty]))(var_path_env) /* is_empty on <var_path_env:String>*/;
-var12 = !var11;
-if (var12){
-var13 = ((val* (*)(val*))(self->class->vft[COLOR_modelbuilder__ModelBuilder__paths]))(self) /* paths on <self:ModelBuilder>*/;
-var14 = ':';
-var16 = BOX_kernel__Char(var14); /* autobox from Char to Pattern */
-var15 = ((val* (*)(val*, val*))(var_path_env->class->vft[COLOR_string_search__String__split_with]))(var_path_env, var16) /* split_with on <var_path_env:String>*/;
-((void (*)(val*, val*))(var13->class->vft[COLOR_abstract_collection__Sequence__append]))(var13, var15) /* append on <var13:Array[String]>*/;
-} else {
-}
-if (varonce17) {
-var18 = varonce17;
-} else {
-var19 = "NIT_DIR";
-var20 = 7;
-var21 = string__NativeString__to_s_with_length(var19, var20);
-var18 = var21;
-varonce17 = var18;
-}
-var22 = ((val* (*)(val*))(var18->class->vft[COLOR_environ__String__environ]))(var18) /* environ on <var18:String>*/;
-var_path_env = var22;
-var23 = ((short int (*)(val*))(var_path_env->class->vft[COLOR_abstract_collection__Collection__is_empty]))(var_path_env) /* is_empty on <var_path_env:String>*/;
-var24 = !var23;
-if (var24){
-var25 = NEW_array__Array(&type_array__Arraykernel__Object);
-var26 = 3;
-((void (*)(val*, long))(var25->class->vft[COLOR_array__Array__with_capacity]))(var25, var26) /* with_capacity on <var25:Array[Object]>*/;
-CHECK_NEW_array__Array(var25);
-var_ = var25;
-if (varonce27) {
-var28 = varonce27;
-} else {
-var29 = "";
-var30 = 0;
-var31 = string__NativeString__to_s_with_length(var29, var30);
-var28 = var31;
-varonce27 = var28;
-}
-((void (*)(val*, val*))(var_->class->vft[COLOR_abstract_collection__SimpleCollection__add]))(var_, var28) /* add on <var_:Array[Object]>*/;
-((void (*)(val*, val*))(var_->class->vft[COLOR_abstract_collection__SimpleCollection__add]))(var_, var_path_env) /* add on <var_:Array[Object]>*/;
-if (varonce32) {
-var33 = varonce32;
-} else {
-var34 = "/lib";
-var35 = 4;
-var36 = string__NativeString__to_s_with_length(var34, var35);
-var33 = var36;
-varonce32 = var33;
-}
-((void (*)(val*, val*))(var_->class->vft[COLOR_abstract_collection__SimpleCollection__add]))(var_, var33) /* add on <var_:Array[Object]>*/;
-var37 = ((val* (*)(val*))(var_->class->vft[COLOR_string__Object__to_s]))(var_) /* to_s on <var_:Array[Object]>*/;
-var_libname = var37;
-var38 = ((short int (*)(val*))(var_libname->class->vft[COLOR_file__String__file_exists]))(var_libname) /* file_exists on <var_libname:String>*/;
-if (var38){
-var39 = ((val* (*)(val*))(self->class->vft[COLOR_modelbuilder__ModelBuilder__paths]))(self) /* paths on <self:ModelBuilder>*/;
-((void (*)(val*, val*))(var39->class->vft[COLOR_abstract_collection__SimpleCollection__add]))(var39, var_libname) /* add on <var39:Array[String]>*/;
-} else {
-}
-} else {
-}
-var40 = NEW_array__Array(&type_array__Arraykernel__Object);
-var41 = 3;
-((void (*)(val*, long))(var40->class->vft[COLOR_array__Array__with_capacity]))(var40, var41) /* with_capacity on <var40:Array[Object]>*/;
-CHECK_NEW_array__Array(var40);
-var_42 = var40;
-if (varonce43) {
-var44 = varonce43;
-} else {
-var45 = "";
-var46 = 0;
-var47 = string__NativeString__to_s_with_length(var45, var46);
-var44 = var47;
-varonce43 = var44;
-}
-((void (*)(val*, val*))(var_42->class->vft[COLOR_abstract_collection__SimpleCollection__add]))(var_42, var44) /* add on <var_42:Array[Object]>*/;
-var48 = ((val* (*)(val*))(self->class->vft[COLOR_kernel__Object__sys]))(self) /* sys on <self:ModelBuilder>*/;
-var49 = ((val* (*)(val*))(var48->class->vft[COLOR_string__Sys__program_name]))(var48) /* program_name on <var48:Sys>*/;
-var50 = ((val* (*)(val*))(var49->class->vft[COLOR_file__String__dirname]))(var49) /* dirname on <var49:String>*/;
-((void (*)(val*, val*))(var_42->class->vft[COLOR_abstract_collection__SimpleCollection__add]))(var_42, var50) /* add on <var_42:Array[Object]>*/;
-if (varonce51) {
-var52 = varonce51;
-} else {
-var53 = "/../lib";
-var54 = 7;
-var55 = string__NativeString__to_s_with_length(var53, var54);
-var52 = var55;
-varonce51 = var52;
-}
-((void (*)(val*, val*))(var_42->class->vft[COLOR_abstract_collection__SimpleCollection__add]))(var_42, var52) /* add on <var_42:Array[Object]>*/;
-var56 = ((val* (*)(val*))(var_42->class->vft[COLOR_string__Object__to_s]))(var_42) /* to_s on <var_42:Array[Object]>*/;
-var_libname57 = var56;
-var58 = ((short int (*)(val*))(var_libname57->class->vft[COLOR_file__String__file_exists]))(var_libname57) /* file_exists on <var_libname57:String>*/;
-if (var58){
-var59 = ((val* (*)(val*))(self->class->vft[COLOR_modelbuilder__ModelBuilder__paths]))(self) /* paths on <self:ModelBuilder>*/;
-var60 = ((val* (*)(val*))(var_libname57->class->vft[COLOR_file__String__simplify_path]))(var_libname57) /* simplify_path on <var_libname57:String>*/;
-((void (*)(val*, val*))(var59->class->vft[COLOR_abstract_collection__SimpleCollection__add]))(var59, var60) /* add on <var59:Array[String]>*/;
-} else {
-}
-RET_LABEL:;
-}
-/* method modelbuilder#ModelBuilder#init for (self: Object, Model, ToolContext) */
-void VIRTUAL_modelbuilder__ModelBuilder__init(val* self, val* p0, val* p1) {
-modelbuilder__ModelBuilder__init(self, p0, p1);
-RET_LABEL:;
-}
-/* method modelbuilder#ModelBuilder#parse for (self: ModelBuilder, Sequence[String]): Array[MModule] */
-val* modelbuilder__ModelBuilder__parse(val* self, val* p0) {
-val* var /* : Array[MModule] */;
-val* var_modules /* var modules: Sequence[String] */;
-long var1 /* : Int */;
-long var_time0 /* var time0: Int */;
-val* var2 /* : ToolContext */;
-static val* varonce;
-val* var3 /* : String */;
-char* var4 /* : NativeString */;
-long var5 /* : Int */;
-val* var6 /* : String */;
-long var7 /* : Int */;
-val* var8 /* : Array[MModule] */;
-val* var_mmodules /* var mmodules: Array[MModule] */;
-val* var9 /* : Iterator[nullable Object] */;
-short int var10 /* : Bool */;
-val* var11 /* : nullable Object */;
-val* var_a /* var a: String */;
-val* var12 /* : null */;
-val* var13 /* : nullable AModule */;
-val* var_nmodule /* var nmodule: nullable AModule */;
-val* var14 /* : null */;
-short int var15 /* : Bool */;
-val* var16 /* : nullable MModule */;
-long var17 /* : Int */;
-long var_time1 /* var time1: Int */;
-val* var18 /* : ToolContext */;
-static val* varonce19;
-val* var20 /* : String */;
-char* var21 /* : NativeString */;
-long var22 /* : Int */;
-val* var23 /* : String */;
-long var24 /* : Int */;
-long var26 /* : Int */;
-static val* varonce27;
-val* var28 /* : String */;
-char* var29 /* : NativeString */;
-long var30 /* : Int */;
-val* var31 /* : String */;
-val* var32 /* : Array[Object] */;
-long var33 /* : Int */;
-val* var34 /* : NativeArray[Object] */;
-val* var35 /* : Object */;
-val* var36 /* : String */;
-long var37 /* : Int */;
-val* var38 /* : ToolContext */;
-val* var39 /* : ToolContext */;
-val* var40 /* : OptionBool */;
-val* var41 /* : nullable Object */;
-short int var42 /* : Bool */;
-val* var43 /* : ToolContext */;
-static val* varonce44;
-val* var45 /* : String */;
-char* var46 /* : NativeString */;
-long var47 /* : Int */;
-val* var48 /* : String */;
-long var49 /* : Int */;
-long var50 /* : Int */;
-var_modules = p0;
-var1 = ((long (*)(val*))(self->class->vft[COLOR_time__Object__get_time]))(self) /* get_time on <self:ModelBuilder>*/;
-var_time0 = var1;
-var2 = ((val* (*)(val*))(self->class->vft[COLOR_modelbuilder__ModelBuilder__toolcontext]))(self) /* toolcontext on <self:ModelBuilder>*/;
-if (varonce) {
-var3 = varonce;
-} else {
-var4 = "*** PARSE ***";
-var5 = 13;
-var6 = string__NativeString__to_s_with_length(var4, var5);
-var3 = var6;
-varonce = var3;
-}
-var7 = 1;
-((void (*)(val*, val*, long))(var2->class->vft[COLOR_toolcontext__ToolContext__info]))(var2, var3, var7) /* info on <var2:ToolContext>*/;
-var8 = NEW_array__Array(&type_array__Arraymodel_base__MModule);
-((void (*)(val*))(var8->class->vft[COLOR_array__Array__init]))(var8) /* init on <var8:Array[MModule]>*/;
-CHECK_NEW_array__Array(var8);
-var_mmodules = var8;
-var9 = ((val* (*)(val*))(var_modules->class->vft[COLOR_abstract_collection__Collection__iterator]))(var_modules) /* iterator on <var_modules:Sequence[String]>*/;
-for(;;) {
-var10 = ((short int (*)(val*))(var9->class->vft[COLOR_abstract_collection__Iterator__is_ok]))(var9) /* is_ok on <var9:Iterator[nullable Object]>*/;
-if(!var10) break;
-var11 = ((val* (*)(val*))(var9->class->vft[COLOR_abstract_collection__Iterator__item]))(var9) /* item on <var9:Iterator[nullable Object]>*/;
-var_a = var11;
-var12 = NULL;
-var13 = ((val* (*)(val*, val*, val*))(self->class->vft[COLOR_modelbuilder__ModelBuilder__load_module]))(self, var12, var_a) /* load_module on <self:ModelBuilder>*/;
-var_nmodule = var13;
-var14 = NULL;
-if (var_nmodule == NULL) {
-var15 = 1; /* is null */
-} else {
-var15 = 0; /* arg is null but recv is not */
-}
-if (var15){
-goto CONTINUE_label;
-} else {
-}
-var16 = ((val* (*)(val*))(var_nmodule->class->vft[COLOR_modelbuilder__AModule__mmodule]))(var_nmodule) /* mmodule on <var_nmodule:nullable AModule(AModule)>*/;
-if (var16 == NULL) {
-fprintf(stderr, "Runtime error: %s", "Cast failed");
-fprintf(stderr, " (%s:%d)\n", "src/modelbuilder.nit", 125);
-exit(1);
-}
-((void (*)(val*, val*))(var_mmodules->class->vft[COLOR_abstract_collection__SimpleCollection__add]))(var_mmodules, var16) /* add on <var_mmodules:Array[MModule]>*/;
-CONTINUE_label: (void)0;
-((void (*)(val*))(var9->class->vft[COLOR_abstract_collection__Iterator__next]))(var9) /* next on <var9:Iterator[nullable Object]>*/;
-}
-BREAK_label: (void)0;
-var17 = ((long (*)(val*))(self->class->vft[COLOR_time__Object__get_time]))(self) /* get_time on <self:ModelBuilder>*/;
-var_time1 = var17;
-var18 = ((val* (*)(val*))(self->class->vft[COLOR_modelbuilder__ModelBuilder__toolcontext]))(self) /* toolcontext on <self:ModelBuilder>*/;
-if (varonce19) {
-var20 = varonce19;
-} else {
-var21 = "*** END PARSE: ";
-var22 = 15;
-var23 = string__NativeString__to_s_with_length(var21, var22);
-var20 = var23;
-varonce19 = var20;
-}
-{ /* Inline kernel#Int#- (var_time1,var_time0) */
-var26 = var_time1 - var_time0;
-var24 = var26;
-goto RET_LABEL25;
-RET_LABEL25:(void)0;
-}
-if (varonce27) {
-var28 = varonce27;
-} else {
-var29 = " ***";
-var30 = 4;
-var31 = string__NativeString__to_s_with_length(var29, var30);
-var28 = var31;
-varonce27 = var28;
-}
-var32 = NEW_array__Array(&type_array__Arraykernel__Object);
-{ /* var32 = array_instance Array[Object] */
-var33 = 3;
-var34 = NEW_array__NativeArray(var33, &type_array__NativeArraykernel__Object);
-((struct instance_array__NativeArray*)var34)->values[0] = (val*) var20;
-var35 = BOX_kernel__Int(var24); /* autobox from Int to Object */
-((struct instance_array__NativeArray*)var34)->values[1] = (val*) var35;
-((struct instance_array__NativeArray*)var34)->values[2] = (val*) var28;
-((void (*)(val*, val*, long))(var32->class->vft[COLOR_array__Array__with_native]))(var32, var34, var33) /* with_native on <var32:Array[Object]>*/;
-CHECK_NEW_array__Array(var32);
-}
-var36 = ((val* (*)(val*))(var32->class->vft[COLOR_string__Object__to_s]))(var32) /* to_s on <var32:Array[Object]>*/;
-var37 = 2;
-((void (*)(val*, val*, long))(var18->class->vft[COLOR_toolcontext__ToolContext__info]))(var18, var36, var37) /* info on <var18:ToolContext>*/;
-var38 = ((val* (*)(val*))(self->class->vft[COLOR_modelbuilder__ModelBuilder__toolcontext]))(self) /* toolcontext on <self:ModelBuilder>*/;
-((void (*)(val*))(var38->class->vft[COLOR_toolcontext__ToolContext__check_errors]))(var38) /* check_errors on <var38:ToolContext>*/;
-var39 = ((val* (*)(val*))(self->class->vft[COLOR_modelbuilder__ModelBuilder__toolcontext]))(self) /* toolcontext on <self:ModelBuilder>*/;
-var40 = ((val* (*)(val*))(var39->class->vft[COLOR_modelbuilder__ToolContext__opt_only_parse]))(var39) /* opt_only_parse on <var39:ToolContext>*/;
-var41 = ((val* (*)(val*))(var40->class->vft[COLOR_opts__Option__value]))(var40) /* value on <var40:OptionBool>*/;
-var42 = ((struct instance_kernel__Bool*)var41)->value; /* autounbox from nullable Object to Bool */;
-if (var42){
-var43 = ((val* (*)(val*))(self->class->vft[COLOR_modelbuilder__ModelBuilder__toolcontext]))(self) /* toolcontext on <self:ModelBuilder>*/;
-if (varonce44) {
-var45 = varonce44;
-} else {
-var46 = "*** ONLY PARSE...";
-var47 = 17;
-var48 = string__NativeString__to_s_with_length(var46, var47);
-var45 = var48;
-varonce44 = var45;
-}
-var49 = 1;
-((void (*)(val*, val*, long))(var43->class->vft[COLOR_toolcontext__ToolContext__info]))(var43, var45, var49) /* info on <var43:ToolContext>*/;
-var50 = 0;
-((void (*)(val*, long))(self->class->vft[COLOR_kernel__Object__exit]))(self, var50) /* exit on <self:ModelBuilder>*/;
-} else {
-}
-var = var_mmodules;
-goto RET_LABEL;
-RET_LABEL:;
-return var;
-}
-/* method modelbuilder#ModelBuilder#parse for (self: Object, Sequence[String]): Array[MModule] */
-val* VIRTUAL_modelbuilder__ModelBuilder__parse(val* self, val* p0) {
-val* var /* : Array[MModule] */;
-val* var1 /* : Array[MModule] */;
-var1 = modelbuilder__ModelBuilder__parse(self, p0);
-var = var1;
-RET_LABEL:;
-return var;
-}
-/* method modelbuilder#ModelBuilder#try_get_mclass_by_name for (self: ModelBuilder, ANode, MModule, String): nullable MClass */
-val* modelbuilder__ModelBuilder__try_get_mclass_by_name(val* self, val* p0, val* p1, val* p2) {
-val* var /* : nullable MClass */;
-val* var_anode /* var anode: ANode */;
-val* var_mmodule /* var mmodule: MModule */;
-val* var_name /* var name: String */;
-val* var1 /* : Model */;
-val* var2 /* : nullable Array[MClass] */;
-val* var_classes /* var classes: nullable Array[MClass] */;
-val* var3 /* : null */;
-short int var4 /* : Bool */;
-val* var5 /* : null */;
-val* var6 /* : null */;
-val* var_res /* var res: nullable MClass */;
-val* var7 /* : Iterator[nullable Object] */;
-short int var8 /* : Bool */;
-val* var9 /* : nullable Object */;
-val* var_mclass /* var mclass: MClass */;
-val* var10 /* : POSetElement[MModule] */;
-val* var11 /* : MModule */;
-short int var12 /* : Bool */;
-short int var13 /* : Bool */;
-val* var14 /* : MModule */;
-val* var15 /* : MVisibility */;
-short int var16 /* : Bool */;
-short int var17 /* : Bool */;
-val* var18 /* : null */;
-short int var19 /* : Bool */;
-static val* varonce;
-val* var20 /* : String */;
-char* var21 /* : NativeString */;
-long var22 /* : Int */;
-val* var23 /* : String */;
-static val* varonce24;
-val* var25 /* : String */;
-char* var26 /* : NativeString */;
-long var27 /* : Int */;
-val* var28 /* : String */;
-val* var29 /* : String */;
-static val* varonce30;
-val* var31 /* : String */;
-char* var32 /* : NativeString */;
-long var33 /* : Int */;
-val* var34 /* : String */;
-val* var35 /* : String */;
-val* var36 /* : Array[Object] */;
-long var37 /* : Int */;
-val* var38 /* : NativeArray[Object] */;
-val* var39 /* : String */;
-val* var40 /* : null */;
-var_anode = p0;
-var_mmodule = p1;
-var_name = p2;
-var1 = ((val* (*)(val*))(self->class->vft[COLOR_modelbuilder__ModelBuilder__model]))(self) /* model on <self:ModelBuilder>*/;
-var2 = ((val* (*)(val*, val*))(var1->class->vft[COLOR_model__Model__get_mclasses_by_name]))(var1, var_name) /* get_mclasses_by_name on <var1:Model>*/;
-var_classes = var2;
-var3 = NULL;
-if (var_classes == NULL) {
-var4 = 1; /* is null */
-} else {
-var4 = 0; /* arg is null but recv is not */
-}
-if (var4){
-var5 = NULL;
-var = var5;
-goto RET_LABEL;
-} else {
-}
-var6 = NULL;
-var_res = var6;
-var7 = ((val* (*)(val*))(var_classes->class->vft[COLOR_abstract_collection__Collection__iterator]))(var_classes) /* iterator on <var_classes:nullable Array[MClass](Array[MClass])>*/;
-for(;;) {
-var8 = ((short int (*)(val*))(var7->class->vft[COLOR_abstract_collection__Iterator__is_ok]))(var7) /* is_ok on <var7:Iterator[nullable Object]>*/;
-if(!var8) break;
-var9 = ((val* (*)(val*))(var7->class->vft[COLOR_abstract_collection__Iterator__item]))(var7) /* item on <var7:Iterator[nullable Object]>*/;
-var_mclass = var9;
-var10 = ((val* (*)(val*))(var_mmodule->class->vft[COLOR_model_base__MModule__in_importation]))(var_mmodule) /* in_importation on <var_mmodule:MModule>*/;
-var11 = ((val* (*)(val*))(var_mclass->class->vft[COLOR_model__MClass__intro_mmodule]))(var_mclass) /* intro_mmodule on <var_mclass:MClass>*/;
-var12 = ((short int (*)(val*, val*))(var10->class->vft[COLOR_poset__POSetElement___60d_61d]))(var10, var11) /* <= on <var10:POSetElement[MModule]>*/;
-var13 = !var12;
-if (var13){
-goto CONTINUE_label;
-} else {
-}
-var14 = ((val* (*)(val*))(var_mclass->class->vft[COLOR_model__MClass__intro_mmodule]))(var_mclass) /* intro_mmodule on <var_mclass:MClass>*/;
-var15 = ((val* (*)(val*))(var_mclass->class->vft[COLOR_model__MClass__visibility]))(var_mclass) /* visibility on <var_mclass:MClass>*/;
-var16 = ((short int (*)(val*, val*, val*))(var_mmodule->class->vft[COLOR_model_base__MModule__is_visible]))(var_mmodule, var14, var15) /* is_visible on <var_mmodule:MModule>*/;
-var17 = !var16;
-if (var17){
-goto CONTINUE_label;
-} else {
-}
-var18 = NULL;
-if (var_res == NULL) {
-var19 = 1; /* is null */
-} else {
-var19 = 0; /* arg is null but recv is not */
-}
-if (var19){
-var_res = var_mclass;
-} else {
-if (varonce) {
-var20 = varonce;
-} else {
-var21 = "Ambigous class name \'";
-var22 = 21;
-var23 = string__NativeString__to_s_with_length(var21, var22);
-var20 = var23;
-varonce = var20;
-}
-if (varonce24) {
-var25 = varonce24;
-} else {
-var26 = "\'; conflict between ";
-var27 = 20;
-var28 = string__NativeString__to_s_with_length(var26, var27);
-var25 = var28;
-varonce24 = var25;
-}
-var29 = ((val* (*)(val*))(var_mclass->class->vft[COLOR_model__MClass__full_name]))(var_mclass) /* full_name on <var_mclass:MClass>*/;
-if (varonce30) {
-var31 = varonce30;
-} else {
-var32 = " and ";
-var33 = 5;
-var34 = string__NativeString__to_s_with_length(var32, var33);
-var31 = var34;
-varonce30 = var31;
-}
-var35 = ((val* (*)(val*))(var_res->class->vft[COLOR_model__MClass__full_name]))(var_res) /* full_name on <var_res:nullable MClass(MClass)>*/;
-var36 = NEW_array__Array(&type_array__Arraykernel__Object);
-{ /* var36 = array_instance Array[Object] */
-var37 = 6;
-var38 = NEW_array__NativeArray(var37, &type_array__NativeArraykernel__Object);
-((struct instance_array__NativeArray*)var38)->values[0] = (val*) var20;
-((struct instance_array__NativeArray*)var38)->values[1] = (val*) var_name;
-((struct instance_array__NativeArray*)var38)->values[2] = (val*) var25;
-((struct instance_array__NativeArray*)var38)->values[3] = (val*) var29;
-((struct instance_array__NativeArray*)var38)->values[4] = (val*) var31;
-((struct instance_array__NativeArray*)var38)->values[5] = (val*) var35;
-((void (*)(val*, val*, long))(var36->class->vft[COLOR_array__Array__with_native]))(var36, var38, var37) /* with_native on <var36:Array[Object]>*/;
-CHECK_NEW_array__Array(var36);
-}
-var39 = ((val* (*)(val*))(var36->class->vft[COLOR_string__Object__to_s]))(var36) /* to_s on <var36:Array[Object]>*/;
-((void (*)(val*, val*, val*))(self->class->vft[COLOR_modelbuilder__ModelBuilder__error]))(self, var_anode, var39) /* error on <self:ModelBuilder>*/;
-var40 = NULL;
-var = var40;
-goto RET_LABEL;
-}
-CONTINUE_label: (void)0;
-((void (*)(val*))(var7->class->vft[COLOR_abstract_collection__Iterator__next]))(var7) /* next on <var7:Iterator[nullable Object]>*/;
-}
-BREAK_label: (void)0;
-var = var_res;
-goto RET_LABEL;
-RET_LABEL:;
-return var;
-}
-/* method modelbuilder#ModelBuilder#try_get_mclass_by_name for (self: Object, ANode, MModule, String): nullable MClass */
-val* VIRTUAL_modelbuilder__ModelBuilder__try_get_mclass_by_name(val* self, val* p0, val* p1, val* p2) {
-val* var /* : nullable MClass */;
-val* var1 /* : nullable MClass */;
-var1 = modelbuilder__ModelBuilder__try_get_mclass_by_name(self, p0, p1, p2);
-var = var1;
-RET_LABEL:;
-return var;
-}
-/* method modelbuilder#ModelBuilder#try_get_mproperty_by_name2 for (self: ModelBuilder, ANode, MModule, MType, String): nullable MProperty */
-val* modelbuilder__ModelBuilder__try_get_mproperty_by_name2(val* self, val* p0, val* p1, val* p2, val* p3) {
-val* var /* : nullable MProperty */;
-val* var_anode /* var anode: ANode */;
-val* var_mmodule /* var mmodule: MModule */;
-val* var_mtype /* var mtype: MType */;
-val* var_name /* var name: String */;
-val* var1 /* : Model */;
-val* var2 /* : nullable Array[MProperty] */;
-val* var_props /* var props: nullable Array[MProperty] */;
-val* var3 /* : null */;
-short int var4 /* : Bool */;
-val* var5 /* : null */;
-val* var6 /* : HashMap3[MModule, MType, String, nullable MProperty] */;
-val* var7 /* : nullable Object */;
-val* var_cache /* var cache: nullable MProperty */;
-val* var8 /* : null */;
-short int var9 /* : Bool */;
-val* var10 /* : null */;
-val* var_res /* var res: nullable MProperty */;
-val* var11 /* : null */;
-val* var_ress /* var ress: nullable Array[MProperty] */;
-val* var12 /* : Iterator[nullable Object] */;
-short int var13 /* : Bool */;
-val* var14 /* : nullable Object */;
-val* var_mprop /* var mprop: MProperty */;
-short int var15 /* : Bool */;
-short int var16 /* : Bool */;
-val* var17 /* : MClassDef */;
-val* var18 /* : MModule */;
-val* var19 /* : MVisibility */;
-short int var20 /* : Bool */;
-short int var21 /* : Bool */;
-val* var22 /* : null */;
-short int var23 /* : Bool */;
-val* var24 /* : MClassDef */;
-val* var25 /* : MClassType */;
-val* var_restype /* var restype: MClassType */;
-val* var26 /* : MClassDef */;
-val* var27 /* : MClassType */;
-val* var_mproptype /* var mproptype: MClassType */;
-val* var28 /* : null */;
-short int var29 /* : Bool */;
-val* var30 /* : null */;
-short int var31 /* : Bool */;
-val* var32 /* : null */;
-short int var33 /* : Bool */;
-val* var34 /* : Array[MProperty] */;
-val* var35 /* : null */;
-short int var36 /* : Bool */;
-val* var37 /* : MClassDef */;
-val* var38 /* : MClassType */;
-val* var_restype39 /* var restype: MClassType */;
-val* var40 /* : Iterator[nullable Object] */;
-short int var41 /* : Bool */;
-val* var42 /* : nullable Object */;
-val* var_mprop43 /* var mprop: MProperty */;
-val* var44 /* : MClassDef */;
-val* var45 /* : MClassType */;
-val* var_mproptype46 /* var mproptype: MClassType */;
-val* var47 /* : null */;
-short int var48 /* : Bool */;
-short int var49 /* : Bool */;
-static val* varonce;
-val* var50 /* : String */;
-char* var51 /* : NativeString */;
-long var52 /* : Int */;
-val* var53 /* : String */;
-static val* varonce54;
-val* var55 /* : String */;
-char* var56 /* : NativeString */;
-long var57 /* : Int */;
-val* var58 /* : String */;
-static val* varonce59;
-val* var60 /* : String */;
-char* var61 /* : NativeString */;
-long var62 /* : Int */;
-val* var63 /* : String */;
-val* var64 /* : String */;
-static val* varonce65;
-val* var66 /* : String */;
-char* var67 /* : NativeString */;
-long var68 /* : Int */;
-val* var69 /* : String */;
-val* var70 /* : String */;
-val* var71 /* : Array[Object] */;
-long var72 /* : Int */;
-val* var73 /* : NativeArray[Object] */;
-val* var74 /* : String */;
-val* var75 /* : null */;
-val* var77 /* : HashMap3[MModule, MType, String, nullable MProperty] */;
-var_anode = p0;
-var_mmodule = p1;
-var_mtype = p2;
-var_name = p3;
-var1 = ((val* (*)(val*))(self->class->vft[COLOR_modelbuilder__ModelBuilder__model]))(self) /* model on <self:ModelBuilder>*/;
-var2 = ((val* (*)(val*, val*))(var1->class->vft[COLOR_model__Model__get_mproperties_by_name]))(var1, var_name) /* get_mproperties_by_name on <var1:Model>*/;
-var_props = var2;
-var3 = NULL;
-if (var_props == NULL) {
-var4 = 1; /* is null */
-} else {
-var4 = 0; /* arg is null but recv is not */
-}
-if (var4){
-var5 = NULL;
-var = var5;
-goto RET_LABEL;
-} else {
-}
-var6 = ((val* (*)(val*))(self->class->vft[COLOR_modelbuilder__ModelBuilder__try_get_mproperty_by_name2_cache]))(self) /* try_get_mproperty_by_name2_cache on <self:ModelBuilder>*/;
-var7 = ((val* (*)(val*, val*, val*, val*))(var6->class->vft[COLOR_more_collections__HashMap3___91d_93d]))(var6, var_mmodule, var_mtype, var_name) /* [] on <var6:HashMap3[MModule, MType, String, nullable MProperty]>*/;
-var_cache = var7;
-var8 = NULL;
-if (var_cache == NULL) {
-var9 = 0; /* is null */
-} else {
-var9 = 1; /* arg is null and recv is not */
-}
-if (var9){
-var = var_cache;
-goto RET_LABEL;
-} else {
-}
-var10 = NULL;
-var_res = var10;
-var11 = NULL;
-var_ress = var11;
-var12 = ((val* (*)(val*))(var_props->class->vft[COLOR_abstract_collection__Collection__iterator]))(var_props) /* iterator on <var_props:nullable Array[MProperty](Array[MProperty])>*/;
-for(;;) {
-var13 = ((short int (*)(val*))(var12->class->vft[COLOR_abstract_collection__Iterator__is_ok]))(var12) /* is_ok on <var12:Iterator[nullable Object]>*/;
-if(!var13) break;
-var14 = ((val* (*)(val*))(var12->class->vft[COLOR_abstract_collection__Iterator__item]))(var12) /* item on <var12:Iterator[nullable Object]>*/;
-var_mprop = var14;
-var15 = ((short int (*)(val*, val*, val*))(var_mtype->class->vft[COLOR_model__MType__has_mproperty]))(var_mtype, var_mmodule, var_mprop) /* has_mproperty on <var_mtype:MType>*/;
-var16 = !var15;
-if (var16){
-goto CONTINUE_label;
-} else {
-}
-var17 = ((val* (*)(val*))(var_mprop->class->vft[COLOR_model__MProperty__intro_mclassdef]))(var_mprop) /* intro_mclassdef on <var_mprop:MProperty>*/;
-var18 = ((val* (*)(val*))(var17->class->vft[COLOR_model__MClassDef__mmodule]))(var17) /* mmodule on <var17:MClassDef>*/;
-var19 = ((val* (*)(val*))(var_mprop->class->vft[COLOR_model__MProperty__visibility]))(var_mprop) /* visibility on <var_mprop:MProperty>*/;
-var20 = ((short int (*)(val*, val*, val*))(var_mmodule->class->vft[COLOR_model_base__MModule__is_visible]))(var_mmodule, var18, var19) /* is_visible on <var_mmodule:MModule>*/;
-var21 = !var20;
-if (var21){
-goto CONTINUE_label;
-} else {
-}
-var22 = NULL;
-if (var_res == NULL) {
-var23 = 1; /* is null */
-} else {
-var23 = 0; /* arg is null but recv is not */
-}
-if (var23){
-var_res = var_mprop;
-} else {
-var24 = ((val* (*)(val*))(var_res->class->vft[COLOR_model__MProperty__intro_mclassdef]))(var_res) /* intro_mclassdef on <var_res:nullable MProperty(MProperty)>*/;
-var25 = ((val* (*)(val*))(var24->class->vft[COLOR_model__MClassDef__bound_mtype]))(var24) /* bound_mtype on <var24:MClassDef>*/;
-var_restype = var25;
-var26 = ((val* (*)(val*))(var_mprop->class->vft[COLOR_model__MProperty__intro_mclassdef]))(var_mprop) /* intro_mclassdef on <var_mprop:MProperty>*/;
-var27 = ((val* (*)(val*))(var26->class->vft[COLOR_model__MClassDef__bound_mtype]))(var26) /* bound_mtype on <var26:MClassDef>*/;
-var_mproptype = var27;
-var28 = NULL;
-var29 = ((short int (*)(val*, val*, val*, val*))(var_restype->class->vft[COLOR_model__MType__is_subtype]))(var_restype, var_mmodule, var28, var_mproptype) /* is_subtype on <var_restype:MClassType>*/;
-if (var29){
-} else {
-var30 = NULL;
-var31 = ((short int (*)(val*, val*, val*, val*))(var_mproptype->class->vft[COLOR_model__MType__is_subtype]))(var_mproptype, var_mmodule, var30, var_restype) /* is_subtype on <var_mproptype:MClassType>*/;
-if (var31){
-var_res = var_mprop;
-} else {
-var32 = NULL;
-if (var_ress == NULL) {
-var33 = 1; /* is null */
-} else {
-var33 = 0; /* arg is null but recv is not */
-}
-if (var33){
-var34 = NEW_array__Array(&type_array__Arraymodel__MProperty);
-((void (*)(val*))(var34->class->vft[COLOR_array__Array__init]))(var34) /* init on <var34:Array[MProperty]>*/;
-CHECK_NEW_array__Array(var34);
-var_ress = var34;
-} else {
-}
-((void (*)(val*, val*))(var_ress->class->vft[COLOR_abstract_collection__SimpleCollection__add]))(var_ress, var_mprop) /* add on <var_ress:nullable Array[MProperty](Array[MProperty])>*/;
-}
-}
-}
-CONTINUE_label: (void)0;
-((void (*)(val*))(var12->class->vft[COLOR_abstract_collection__Iterator__next]))(var12) /* next on <var12:Iterator[nullable Object]>*/;
-}
-BREAK_label: (void)0;
-var35 = NULL;
-if (var_ress == NULL) {
-var36 = 0; /* is null */
-} else {
-var36 = 1; /* arg is null and recv is not */
-}
-if (var36){
-if (var_res == NULL) {
-fprintf(stderr, "Runtime error: %s", "Reciever is null");
-fprintf(stderr, " (%s:%d)\n", "src/modelbuilder.nit", 203);
-exit(1);
-} else {
-var37 = ((val* (*)(val*))(var_res->class->vft[COLOR_model__MProperty__intro_mclassdef]))(var_res) /* intro_mclassdef on <var_res:nullable MProperty>*/;
-}
-var38 = ((val* (*)(val*))(var37->class->vft[COLOR_model__MClassDef__bound_mtype]))(var37) /* bound_mtype on <var37:MClassDef>*/;
-var_restype39 = var38;
-var40 = ((val* (*)(val*))(var_ress->class->vft[COLOR_abstract_collection__Collection__iterator]))(var_ress) /* iterator on <var_ress:nullable Array[MProperty](Array[MProperty])>*/;
-for(;;) {
-var41 = ((short int (*)(val*))(var40->class->vft[COLOR_abstract_collection__Iterator__is_ok]))(var40) /* is_ok on <var40:Iterator[nullable Object]>*/;
-if(!var41) break;
-var42 = ((val* (*)(val*))(var40->class->vft[COLOR_abstract_collection__Iterator__item]))(var40) /* item on <var40:Iterator[nullable Object]>*/;
-var_mprop43 = var42;
-var44 = ((val* (*)(val*))(var_mprop43->class->vft[COLOR_model__MProperty__intro_mclassdef]))(var_mprop43) /* intro_mclassdef on <var_mprop43:MProperty>*/;
-var45 = ((val* (*)(val*))(var44->class->vft[COLOR_model__MClassDef__bound_mtype]))(var44) /* bound_mtype on <var44:MClassDef>*/;
-var_mproptype46 = var45;
-var47 = NULL;
-var48 = ((short int (*)(val*, val*, val*, val*))(var_restype39->class->vft[COLOR_model__MType__is_subtype]))(var_restype39, var_mmodule, var47, var_mproptype46) /* is_subtype on <var_restype39:MClassType>*/;
-var49 = !var48;
-if (var49){
-if (varonce) {
-var50 = varonce;
-} else {
-var51 = "Ambigous property name \'";
-var52 = 24;
-var53 = string__NativeString__to_s_with_length(var51, var52);
-var50 = var53;
-varonce = var50;
-}
-if (varonce54) {
-var55 = varonce54;
-} else {
-var56 = "\' for ";
-var57 = 6;
-var58 = string__NativeString__to_s_with_length(var56, var57);
-var55 = var58;
-varonce54 = var55;
-}
-if (varonce59) {
-var60 = varonce59;
-} else {
-var61 = "; conflict between ";
-var62 = 19;
-var63 = string__NativeString__to_s_with_length(var61, var62);
-var60 = var63;
-varonce59 = var60;
-}
-var64 = ((val* (*)(val*))(var_mprop43->class->vft[COLOR_model__MProperty__full_name]))(var_mprop43) /* full_name on <var_mprop43:MProperty>*/;
-if (varonce65) {
-var66 = varonce65;
-} else {
-var67 = " and ";
-var68 = 5;
-var69 = string__NativeString__to_s_with_length(var67, var68);
-var66 = var69;
-varonce65 = var66;
-}
-if (var_res == NULL) {
-fprintf(stderr, "Runtime error: %s", "Reciever is null");
-fprintf(stderr, " (%s:%d)\n", "src/modelbuilder.nit", 207);
-exit(1);
-} else {
-var70 = ((val* (*)(val*))(var_res->class->vft[COLOR_model__MProperty__full_name]))(var_res) /* full_name on <var_res:nullable MProperty>*/;
-}
-var71 = NEW_array__Array(&type_array__Arraykernel__Object);
-{ /* var71 = array_instance Array[Object] */
-var72 = 8;
-var73 = NEW_array__NativeArray(var72, &type_array__NativeArraykernel__Object);
-((struct instance_array__NativeArray*)var73)->values[0] = (val*) var50;
-((struct instance_array__NativeArray*)var73)->values[1] = (val*) var_name;
-((struct instance_array__NativeArray*)var73)->values[2] = (val*) var55;
-((struct instance_array__NativeArray*)var73)->values[3] = (val*) var_mtype;
-((struct instance_array__NativeArray*)var73)->values[4] = (val*) var60;
-((struct instance_array__NativeArray*)var73)->values[5] = (val*) var64;
-((struct instance_array__NativeArray*)var73)->values[6] = (val*) var66;
-((struct instance_array__NativeArray*)var73)->values[7] = (val*) var70;
-((void (*)(val*, val*, long))(var71->class->vft[COLOR_array__Array__with_native]))(var71, var73, var72) /* with_native on <var71:Array[Object]>*/;
-CHECK_NEW_array__Array(var71);
-}
-var74 = ((val* (*)(val*))(var71->class->vft[COLOR_string__Object__to_s]))(var71) /* to_s on <var71:Array[Object]>*/;
-((void (*)(val*, val*, val*))(self->class->vft[COLOR_modelbuilder__ModelBuilder__error]))(self, var_anode, var74) /* error on <self:ModelBuilder>*/;
-var75 = NULL;
-var = var75;
-goto RET_LABEL;
-} else {
-}
-CONTINUE_label76: (void)0;
-((void (*)(val*))(var40->class->vft[COLOR_abstract_collection__Iterator__next]))(var40) /* next on <var40:Iterator[nullable Object]>*/;
-}
-BREAK_label76: (void)0;
-} else {
-}
-var77 = ((val* (*)(val*))(self->class->vft[COLOR_modelbuilder__ModelBuilder__try_get_mproperty_by_name2_cache]))(self) /* try_get_mproperty_by_name2_cache on <self:ModelBuilder>*/;
-((void (*)(val*, val*, val*, val*, val*))(var77->class->vft[COLOR_more_collections__HashMap3___91d_93d_61d]))(var77, var_mmodule, var_mtype, var_name, var_res) /* []= on <var77:HashMap3[MModule, MType, String, nullable MProperty]>*/;
-var = var_res;
-goto RET_LABEL;
-RET_LABEL:;
-return var;
-}
-/* method modelbuilder#ModelBuilder#try_get_mproperty_by_name2 for (self: Object, ANode, MModule, MType, String): nullable MProperty */
-val* VIRTUAL_modelbuilder__ModelBuilder__try_get_mproperty_by_name2(val* self, val* p0, val* p1, val* p2, val* p3) {
-val* var /* : nullable MProperty */;
-val* var1 /* : nullable MProperty */;
-var1 = modelbuilder__ModelBuilder__try_get_mproperty_by_name2(self, p0, p1, p2, p3);
-var = var1;
-RET_LABEL:;
-return var;
-}
-/* method modelbuilder#ModelBuilder#try_get_mproperty_by_name2_cache for (self: ModelBuilder): HashMap3[MModule, MType, String, nullable MProperty] */
-val* modelbuilder__ModelBuilder__try_get_mproperty_by_name2_cache(val* self) {
-val* var /* : HashMap3[MModule, MType, String, nullable MProperty] */;
-val* var1 /* : HashMap3[MModule, MType, String, nullable MProperty] */;
-var1 = self->attrs[COLOR_modelbuilder__ModelBuilder___64dtry_get_mproperty_by_name2_cache].val; /* @try_get_mproperty_by_name2_cache on <self:ModelBuilder> */
-if (var1 == NULL) {
-fprintf(stderr, "Runtime error: %s", "Uninitialized attribute @try_get_mproperty_by_name2_cache");
-fprintf(stderr, " (%s:%d)\n", "src/modelbuilder.nit", 217);
-exit(1);
-}
-var = var1;
-RET_LABEL:;
-return var;
-}
-/* method modelbuilder#ModelBuilder#try_get_mproperty_by_name2_cache for (self: Object): HashMap3[MModule, MType, String, nullable MProperty] */
-val* VIRTUAL_modelbuilder__ModelBuilder__try_get_mproperty_by_name2_cache(val* self) {
-val* var /* : HashMap3[MModule, MType, String, nullable MProperty] */;
-val* var1 /* : HashMap3[MModule, MType, String, nullable MProperty] */;
-var1 = modelbuilder__ModelBuilder__try_get_mproperty_by_name2_cache(self);
-var = var1;
-RET_LABEL:;
-return var;
-}
-/* method modelbuilder#ModelBuilder#try_get_mproperty_by_name2_cache= for (self: ModelBuilder, HashMap3[MModule, MType, String, nullable MProperty]) */
-void modelbuilder__ModelBuilder__try_get_mproperty_by_name2_cache_61d(val* self, val* p0) {
-self->attrs[COLOR_modelbuilder__ModelBuilder___64dtry_get_mproperty_by_name2_cache].val = p0; /* @try_get_mproperty_by_name2_cache on <self:ModelBuilder> */
-RET_LABEL:;
-}
-/* method modelbuilder#ModelBuilder#try_get_mproperty_by_name2_cache= for (self: Object, HashMap3[MModule, MType, String, nullable MProperty]) */
-void VIRTUAL_modelbuilder__ModelBuilder__try_get_mproperty_by_name2_cache_61d(val* self, val* p0) {
-modelbuilder__ModelBuilder__try_get_mproperty_by_name2_cache_61d(self, p0);
-RET_LABEL:;
-}
-/* method modelbuilder#ModelBuilder#try_get_mproperty_by_name for (self: ModelBuilder, ANode, MClassDef, String): nullable MProperty */
-val* modelbuilder__ModelBuilder__try_get_mproperty_by_name(val* self, val* p0, val* p1, val* p2) {
-val* var /* : nullable MProperty */;
-val* var_anode /* var anode: ANode */;
-val* var_mclassdef /* var mclassdef: MClassDef */;
-val* var_name /* var name: String */;
-val* var1 /* : MModule */;
-val* var2 /* : MClassType */;
-val* var3 /* : nullable MProperty */;
-var_anode = p0;
-var_mclassdef = p1;
-var_name = p2;
-var1 = ((val* (*)(val*))(var_mclassdef->class->vft[COLOR_model__MClassDef__mmodule]))(var_mclassdef) /* mmodule on <var_mclassdef:MClassDef>*/;
-var2 = ((val* (*)(val*))(var_mclassdef->class->vft[COLOR_model__MClassDef__bound_mtype]))(var_mclassdef) /* bound_mtype on <var_mclassdef:MClassDef>*/;
-var3 = ((val* (*)(val*, val*, val*, val*, val*))(self->class->vft[COLOR_modelbuilder__ModelBuilder__try_get_mproperty_by_name2]))(self, var_anode, var1, var2, var_name) /* try_get_mproperty_by_name2 on <self:ModelBuilder>*/;
-var = var3;
-goto RET_LABEL;
-RET_LABEL:;
-return var;
-}
-/* method modelbuilder#ModelBuilder#try_get_mproperty_by_name for (self: Object, ANode, MClassDef, String): nullable MProperty */
-val* VIRTUAL_modelbuilder__ModelBuilder__try_get_mproperty_by_name(val* self, val* p0, val* p1, val* p2) {
-val* var /* : nullable MProperty */;
-val* var1 /* : nullable MProperty */;
-var1 = modelbuilder__ModelBuilder__try_get_mproperty_by_name(self, p0, p1, p2);
-var = var1;
-RET_LABEL:;
-return var;
-}
-/* method modelbuilder#ModelBuilder#paths for (self: ModelBuilder): Array[String] */
-val* modelbuilder__ModelBuilder__paths(val* self) {
-val* var /* : Array[String] */;
-val* var1 /* : Array[String] */;
-var1 = self->attrs[COLOR_modelbuilder__ModelBuilder___64dpaths].val; /* @paths on <self:ModelBuilder> */
-if (var1 == NULL) {
-fprintf(stderr, "Runtime error: %s", "Uninitialized attribute @paths");
-fprintf(stderr, " (%s:%d)\n", "src/modelbuilder.nit", 226);
-exit(1);
-}
-var = var1;
-RET_LABEL:;
-return var;
-}
-/* method modelbuilder#ModelBuilder#paths for (self: Object): Array[String] */
-val* VIRTUAL_modelbuilder__ModelBuilder__paths(val* self) {
-val* var /* : Array[String] */;
-val* var1 /* : Array[String] */;
-var1 = modelbuilder__ModelBuilder__paths(self);
-var = var1;
-RET_LABEL:;
-return var;
-}
-/* method modelbuilder#ModelBuilder#paths= for (self: ModelBuilder, Array[String]) */
-void modelbuilder__ModelBuilder__paths_61d(val* self, val* p0) {
-self->attrs[COLOR_modelbuilder__ModelBuilder___64dpaths].val = p0; /* @paths on <self:ModelBuilder> */
-RET_LABEL:;
-}
-/* method modelbuilder#ModelBuilder#paths= for (self: Object, Array[String]) */
-void VIRTUAL_modelbuilder__ModelBuilder__paths_61d(val* self, val* p0) {
-modelbuilder__ModelBuilder__paths_61d(self, p0);
-RET_LABEL:;
-}
-/* method modelbuilder#ModelBuilder#get_mmodule_by_name for (self: ModelBuilder, ANode, nullable MModule, String): nullable MModule */
-val* modelbuilder__ModelBuilder__get_mmodule_by_name(val* self, val* p0, val* p1, val* p2) {
-val* var /* : nullable MModule */;
-val* var_anode /* var anode: ANode */;
-val* var_mmodule /* var mmodule: nullable MModule */;
-val* var_name /* var name: String */;
-val* var_origmmodule /* var origmmodule: nullable MModule */;
-val* var1 /* : Model */;
-val* var2 /* : nullable Array[MModule] */;
-val* var_modules /* var modules: nullable Array[MModule] */;
-val* var3 /* : Array[String] */;
-val* var_tries /* var tries: Array[String] */;
-val* var_lastmodule /* var lastmodule: nullable MModule */;
-val* var4 /* : null */;
-short int var5 /* : Bool */;
-val* var6 /* : Location */;
-val* var7 /* : nullable SourceFile */;
-val* var8 /* : String */;
-val* var9 /* : String */;
-val* var_dirname /* var dirname: String */;
-static val* varonce;
-val* var10 /* : String */;
-char* var11 /* : NativeString */;
-long var12 /* : Int */;
-val* var13 /* : String */;
-val* var14 /* : String */;
-val* var15 /* : String */;
-short int var16 /* : Bool */;
-val* var17 /* : nullable MModule */;
-val* var_owner /* var owner: nullable MModule */;
-val* var18 /* : null */;
-short int var19 /* : Bool */;
-val* var20 /* : Iterator[nullable Object] */;
-short int var21 /* : Bool */;
-val* var22 /* : nullable Object */;
-val* var_candidate /* var candidate: MModule */;
-val* var23 /* : nullable MModule */;
-short int var24 /* : Bool */;
-static val* varonce25;
-val* var26 /* : String */;
-char* var27 /* : NativeString */;
-long var28 /* : Int */;
-val* var29 /* : String */;
-val* var30 /* : String */;
-val* var31 /* : String */;
-static val* varonce32;
-val* var33 /* : String */;
-char* var34 /* : NativeString */;
-long var35 /* : Int */;
-val* var36 /* : String */;
-val* var37 /* : String */;
-val* var_try_file /* var try_file: String */;
-short int var38 /* : Bool */;
-val* var39 /* : String */;
-val* var40 /* : nullable AModule */;
-val* var_res /* var res: nullable AModule */;
-val* var41 /* : null */;
-short int var42 /* : Bool */;
-val* var43 /* : null */;
-val* var44 /* : nullable MModule */;
-static val* varonce45;
-val* var46 /* : String */;
-char* var47 /* : NativeString */;
-long var48 /* : Int */;
-val* var49 /* : String */;
-val* var50 /* : String */;
-val* var51 /* : String */;
-static val* varonce52;
-val* var53 /* : String */;
-char* var54 /* : NativeString */;
-long var55 /* : Int */;
-val* var56 /* : String */;
-val* var57 /* : String */;
-val* var58 /* : String */;
-static val* varonce59;
-val* var60 /* : String */;
-char* var61 /* : NativeString */;
-long var62 /* : Int */;
-val* var63 /* : String */;
-val* var64 /* : String */;
-short int var65 /* : Bool */;
-val* var66 /* : String */;
-val* var67 /* : nullable AModule */;
-val* var_res68 /* var res: nullable AModule */;
-val* var69 /* : null */;
-short int var70 /* : Bool */;
-val* var71 /* : null */;
-val* var72 /* : nullable MModule */;
-val* var73 /* : nullable MModule */;
-val* var75 /* : null */;
-short int var76 /* : Bool */;
-val* var77 /* : Iterator[nullable Object] */;
-short int var78 /* : Bool */;
-val* var79 /* : nullable Object */;
-val* var_candidate80 /* var candidate: MModule */;
-val* var81 /* : nullable MModule */;
-val* var82 /* : null */;
-short int var83 /* : Bool */;
-val* var85 /* : Array[String] */;
-val* var_lookpaths /* var lookpaths: Array[String] */;
-val* var86 /* : null */;
-short int var87 /* : Bool */;
-val* var88 /* : Location */;
-val* var89 /* : nullable SourceFile */;
-val* var90 /* : String */;
-val* var91 /* : String */;
-val* var_dirname92 /* var dirname: String */;
-static val* varonce93;
-val* var94 /* : String */;
-char* var95 /* : NativeString */;
-long var96 /* : Int */;
-val* var97 /* : String */;
-val* var98 /* : String */;
-val* var99 /* : String */;
-short int var100 /* : Bool */;
-val* var101 /* : String */;
-short int var102 /* : Bool */;
-short int var103 /* : Bool */;
-val* var104 /* : Array[nullable Object] */;
-val* var105 /* : null */;
-val* var_candidate106 /* var candidate: nullable String */;
-val* var107 /* : Iterator[nullable Object] */;
-short int var108 /* : Bool */;
-val* var109 /* : nullable Object */;
-val* var_dirname110 /* var dirname: String */;
-static val* varonce111;
-val* var112 /* : String */;
-char* var113 /* : NativeString */;
-long var114 /* : Int */;
-val* var115 /* : String */;
-val* var116 /* : String */;
-val* var117 /* : String */;
-static val* varonce118;
-val* var119 /* : String */;
-char* var120 /* : NativeString */;
-long var121 /* : Int */;
-val* var122 /* : String */;
-val* var123 /* : String */;
-val* var124 /* : String */;
-val* var_try_file125 /* var try_file: String */;
-short int var126 /* : Bool */;
-val* var127 /* : null */;
-short int var128 /* : Bool */;
-short int var129 /* : Bool */;
-val* var130 /* : String */;
-val* var_abs_candidate /* var abs_candidate: String */;
-val* var131 /* : String */;
-val* var_abs_try_file /* var abs_try_file: String */;
-short int var132 /* : Bool */;
-static val* varonce133;
-val* var134 /* : String */;
-char* var135 /* : NativeString */;
-long var136 /* : Int */;
-val* var137 /* : String */;
-static val* varonce138;
-val* var139 /* : String */;
-char* var140 /* : NativeString */;
-long var141 /* : Int */;
-val* var142 /* : String */;
-static val* varonce143;
-val* var144 /* : String */;
-char* var145 /* : NativeString */;
-long var146 /* : Int */;
-val* var147 /* : String */;
-val* var148 /* : Array[Object] */;
-long var149 /* : Int */;
-val* var150 /* : NativeArray[Object] */;
-val* var151 /* : String */;
-static val* varonce152;
-val* var153 /* : String */;
-char* var154 /* : NativeString */;
-long var155 /* : Int */;
-val* var156 /* : String */;
-val* var157 /* : String */;
-val* var158 /* : String */;
-static val* varonce159;
-val* var160 /* : String */;
-char* var161 /* : NativeString */;
-long var162 /* : Int */;
-val* var163 /* : String */;
-val* var164 /* : String */;
-val* var165 /* : String */;
-static val* varonce166;
-val* var167 /* : String */;
-char* var168 /* : NativeString */;
-long var169 /* : Int */;
-val* var170 /* : String */;
-val* var171 /* : String */;
-val* var172 /* : String */;
-short int var173 /* : Bool */;
-val* var174 /* : null */;
-short int var175 /* : Bool */;
-short int var176 /* : Bool */;
-val* var177 /* : String */;
-val* var_abs_candidate178 /* var abs_candidate: String */;
-val* var179 /* : String */;
-val* var_abs_try_file180 /* var abs_try_file: String */;
-short int var181 /* : Bool */;
-static val* varonce182;
-val* var183 /* : String */;
-char* var184 /* : NativeString */;
-long var185 /* : Int */;
-val* var186 /* : String */;
-static val* varonce187;
-val* var188 /* : String */;
-char* var189 /* : NativeString */;
-long var190 /* : Int */;
-val* var191 /* : String */;
-static val* varonce192;
-val* var193 /* : String */;
-char* var194 /* : NativeString */;
-long var195 /* : Int */;
-val* var196 /* : String */;
-val* var197 /* : Array[Object] */;
-long var198 /* : Int */;
-val* var199 /* : NativeArray[Object] */;
-val* var200 /* : String */;
-val* var202 /* : null */;
-short int var203 /* : Bool */;
-val* var204 /* : null */;
-short int var205 /* : Bool */;
-static val* varonce206;
-val* var207 /* : String */;
-char* var208 /* : NativeString */;
-long var209 /* : Int */;
-val* var210 /* : String */;
-static val* varonce211;
-val* var212 /* : String */;
-char* var213 /* : NativeString */;
-long var214 /* : Int */;
-val* var215 /* : String */;
-static val* varonce216;
-val* var217 /* : String */;
-char* var218 /* : NativeString */;
-long var219 /* : Int */;
-val* var220 /* : String */;
-static val* varonce221;
-val* var222 /* : String */;
-char* var223 /* : NativeString */;
-long var224 /* : Int */;
-val* var225 /* : String */;
-val* var226 /* : String */;
-val* var227 /* : Array[Object] */;
-long var228 /* : Int */;
-val* var229 /* : NativeArray[Object] */;
-val* var230 /* : String */;
-static val* varonce231;
-val* var232 /* : String */;
-char* var233 /* : NativeString */;
-long var234 /* : Int */;
-val* var235 /* : String */;
-static val* varonce236;
-val* var237 /* : String */;
-char* var238 /* : NativeString */;
-long var239 /* : Int */;
-val* var240 /* : String */;
-static val* varonce241;
-val* var242 /* : String */;
-char* var243 /* : NativeString */;
-long var244 /* : Int */;
-val* var245 /* : String */;
-val* var246 /* : String */;
-val* var247 /* : Array[Object] */;
-long var248 /* : Int */;
-val* var249 /* : NativeArray[Object] */;
-val* var250 /* : String */;
-val* var251 /* : null */;
-val* var252 /* : nullable AModule */;
-val* var_res253 /* var res: nullable AModule */;
-val* var254 /* : null */;
-short int var255 /* : Bool */;
-val* var256 /* : null */;
-val* var257 /* : nullable MModule */;
-var_anode = p0;
-var_mmodule = p1;
-var_name = p2;
-var_origmmodule = var_mmodule;
-var1 = ((val* (*)(val*))(self->class->vft[COLOR_modelbuilder__ModelBuilder__model]))(self) /* model on <self:ModelBuilder>*/;
-var2 = ((val* (*)(val*, val*))(var1->class->vft[COLOR_model_base__Model__get_mmodules_by_name]))(var1, var_name) /* get_mmodules_by_name on <var1:Model>*/;
-var_modules = var2;
-var3 = NEW_array__Array(&type_array__Arraystring__String);
-((void (*)(val*))(var3->class->vft[COLOR_array__Array__init]))(var3) /* init on <var3:Array[String]>*/;
-CHECK_NEW_array__Array(var3);
-var_tries = var3;
-var_lastmodule = var_mmodule;
-for(;;) {
-var4 = NULL;
-if (var_mmodule == NULL) {
-var5 = 0; /* is null */
-} else {
-var5 = 1; /* arg is null and recv is not */
-}
-if (!var5) break;
-var6 = ((val* (*)(val*))(var_mmodule->class->vft[COLOR_model_base__MModule__location]))(var_mmodule) /* location on <var_mmodule:nullable MModule(MModule)>*/;
-var7 = ((val* (*)(val*))(var6->class->vft[COLOR_location__Location__file]))(var6) /* file on <var6:Location>*/;
-if (var7 == NULL) {
-fprintf(stderr, "Runtime error: %s", "Reciever is null");
-fprintf(stderr, " (%s:%d)\n", "src/modelbuilder.nit", 248);
-exit(1);
-} else {
-var8 = ((val* (*)(val*))(var7->class->vft[COLOR_location__SourceFile__filename]))(var7) /* filename on <var7:nullable SourceFile>*/;
-}
-var9 = ((val* (*)(val*))(var8->class->vft[COLOR_file__String__dirname]))(var8) /* dirname on <var8:String>*/;
-var_dirname = var9;
-if (varonce) {
-var10 = varonce;
-} else {
-var11 = "";
-var12 = 0;
-var13 = string__NativeString__to_s_with_length(var11, var12);
-var10 = var13;
-varonce = var10;
-}
-var14 = ((val* (*)(val*, val*))(var_dirname->class->vft[COLOR_file__String__basename]))(var_dirname, var10) /* basename on <var_dirname:String>*/;
-var15 = ((val* (*)(val*))(var_mmodule->class->vft[COLOR_model_base__MModule__name]))(var_mmodule) /* name on <var_mmodule:nullable MModule(MModule)>*/;
-var16 = ((short int (*)(val*, val*))(var14->class->vft[COLOR_kernel__Object___33d_61d]))(var14, var15) /* != on <var14:String>*/;
-if (var16){
-var17 = ((val* (*)(val*))(var_mmodule->class->vft[COLOR_model_base__MModule__direct_owner]))(var_mmodule) /* direct_owner on <var_mmodule:nullable MModule(MModule)>*/;
-var_owner = var17;
-} else {
-var_owner = var_mmodule;
-}
-var18 = NULL;
-if (var_modules == NULL) {
-var19 = 0; /* is null */
-} else {
-var19 = 1; /* arg is null and recv is not */
-}
-if (var19){
-var20 = ((val* (*)(val*))(var_modules->class->vft[COLOR_abstract_collection__Collection__iterator]))(var_modules) /* iterator on <var_modules:nullable Array[MModule](Array[MModule])>*/;
-for(;;) {
-var21 = ((short int (*)(val*))(var20->class->vft[COLOR_abstract_collection__Iterator__is_ok]))(var20) /* is_ok on <var20:Iterator[nullable Object]>*/;
-if(!var21) break;
-var22 = ((val* (*)(val*))(var20->class->vft[COLOR_abstract_collection__Iterator__item]))(var20) /* item on <var20:Iterator[nullable Object]>*/;
-var_candidate = var22;
-var23 = ((val* (*)(val*))(var_candidate->class->vft[COLOR_model_base__MModule__direct_owner]))(var_candidate) /* direct_owner on <var_candidate:MModule>*/;
-if (var23 == NULL) {
-var24 = (var_owner == NULL);
-} else {
-var24 = ((short int (*)(val*, val*))(var23->class->vft[COLOR_kernel__Object___61d_61d]))(var23, var_owner) /* == on <var23:nullable MModule>*/;
-}
-if (var24){
-var = var_candidate;
-goto RET_LABEL;
-} else {
-}
-CONTINUE_label: (void)0;
-((void (*)(val*))(var20->class->vft[COLOR_abstract_collection__Iterator__next]))(var20) /* next on <var20:Iterator[nullable Object]>*/;
-}
-BREAK_label: (void)0;
-} else {
-}
-if (varonce25) {
-var26 = varonce25;
-} else {
-var27 = "/";
-var28 = 1;
-var29 = string__NativeString__to_s_with_length(var27, var28);
-var26 = var29;
-varonce25 = var26;
-}
-var30 = ((val* (*)(val*, val*))(var_dirname->class->vft[COLOR_string__String___43d]))(var_dirname, var26) /* + on <var_dirname:String>*/;
-var31 = ((val* (*)(val*, val*))(var30->class->vft[COLOR_string__String___43d]))(var30, var_name) /* + on <var30:String>*/;
-if (varonce32) {
-var33 = varonce32;
-} else {
-var34 = ".nit";
-var35 = 4;
-var36 = string__NativeString__to_s_with_length(var34, var35);
-var33 = var36;
-varonce32 = var33;
-}
-var37 = ((val* (*)(val*, val*))(var31->class->vft[COLOR_string__String___43d]))(var31, var33) /* + on <var31:String>*/;
-var_try_file = var37;
-((void (*)(val*, val*))(var_tries->class->vft[COLOR_abstract_collection__SimpleCollection__add]))(var_tries, var_try_file) /* add on <var_tries:Array[String]>*/;
-var38 = ((short int (*)(val*))(var_try_file->class->vft[COLOR_file__String__file_exists]))(var_try_file) /* file_exists on <var_try_file:String>*/;
-if (var38){
-var39 = ((val* (*)(val*))(var_try_file->class->vft[COLOR_file__String__simplify_path]))(var_try_file) /* simplify_path on <var_try_file:String>*/;
-var40 = ((val* (*)(val*, val*, val*))(self->class->vft[COLOR_modelbuilder__ModelBuilder__load_module]))(self, var_owner, var39) /* load_module on <self:ModelBuilder>*/;
-var_res = var40;
-var41 = NULL;
-if (var_res == NULL) {
-var42 = 1; /* is null */
-} else {
-var42 = 0; /* arg is null but recv is not */
-}
-if (var42){
-var43 = NULL;
-var = var43;
-goto RET_LABEL;
-} else {
-}
-var44 = ((val* (*)(val*))(var_res->class->vft[COLOR_modelbuilder__AModule__mmodule]))(var_res) /* mmodule on <var_res:nullable AModule(AModule)>*/;
-if (var44 == NULL) {
-fprintf(stderr, "Runtime error: %s", "Cast failed");
-fprintf(stderr, " (%s:%d)\n", "src/modelbuilder.nit", 273);
-exit(1);
-}
-var = var44;
-goto RET_LABEL;
-} else {
-}
-if (varonce45) {
-var46 = varonce45;
-} else {
-var47 = "/";
-var48 = 1;
-var49 = string__NativeString__to_s_with_length(var47, var48);
-var46 = var49;
-varonce45 = var46;
-}
-var50 = ((val* (*)(val*, val*))(var_dirname->class->vft[COLOR_string__String___43d]))(var_dirname, var46) /* + on <var_dirname:String>*/;
-var51 = ((val* (*)(val*, val*))(var50->class->vft[COLOR_string__String___43d]))(var50, var_name) /* + on <var50:String>*/;
-if (varonce52) {
-var53 = varonce52;
-} else {
-var54 = "/";
-var55 = 1;
-var56 = string__NativeString__to_s_with_length(var54, var55);
-var53 = var56;
-varonce52 = var53;
-}
-var57 = ((val* (*)(val*, val*))(var51->class->vft[COLOR_string__String___43d]))(var51, var53) /* + on <var51:String>*/;
-var58 = ((val* (*)(val*, val*))(var57->class->vft[COLOR_string__String___43d]))(var57, var_name) /* + on <var57:String>*/;
-if (varonce59) {
-var60 = varonce59;
-} else {
-var61 = ".nit";
-var62 = 4;
-var63 = string__NativeString__to_s_with_length(var61, var62);
-var60 = var63;
-varonce59 = var60;
-}
-var64 = ((val* (*)(val*, val*))(var58->class->vft[COLOR_string__String___43d]))(var58, var60) /* + on <var58:String>*/;
-var_try_file = var64;
-var65 = ((short int (*)(val*))(var_try_file->class->vft[COLOR_file__String__file_exists]))(var_try_file) /* file_exists on <var_try_file:String>*/;
-if (var65){
-var66 = ((val* (*)(val*))(var_try_file->class->vft[COLOR_file__String__simplify_path]))(var_try_file) /* simplify_path on <var_try_file:String>*/;
-var67 = ((val* (*)(val*, val*, val*))(self->class->vft[COLOR_modelbuilder__ModelBuilder__load_module]))(self, var_owner, var66) /* load_module on <self:ModelBuilder>*/;
-var_res68 = var67;
-var69 = NULL;
-if (var_res68 == NULL) {
-var70 = 1; /* is null */
-} else {
-var70 = 0; /* arg is null but recv is not */
-}
-if (var70){
-var71 = NULL;
-var = var71;
-goto RET_LABEL;
-} else {
-}
-var72 = ((val* (*)(val*))(var_res68->class->vft[COLOR_modelbuilder__AModule__mmodule]))(var_res68) /* mmodule on <var_res68:nullable AModule(AModule)>*/;
-if (var72 == NULL) {
-fprintf(stderr, "Runtime error: %s", "Cast failed");
-fprintf(stderr, " (%s:%d)\n", "src/modelbuilder.nit", 281);
-exit(1);
-}
-var = var72;
-goto RET_LABEL;
-} else {
-}
-var_lastmodule = var_mmodule;
-var73 = ((val* (*)(val*))(var_mmodule->class->vft[COLOR_model_base__MModule__direct_owner]))(var_mmodule) /* direct_owner on <var_mmodule:nullable MModule(MModule)>*/;
-var_mmodule = var73;
-CONTINUE_label74: (void)0;
-}
-BREAK_label74: (void)0;
-var75 = NULL;
-if (var_modules == NULL) {
-var76 = 0; /* is null */
-} else {
-var76 = 1; /* arg is null and recv is not */
-}
-if (var76){
-var77 = ((val* (*)(val*))(var_modules->class->vft[COLOR_abstract_collection__Collection__iterator]))(var_modules) /* iterator on <var_modules:nullable Array[MModule](Array[MModule])>*/;
-for(;;) {
-var78 = ((short int (*)(val*))(var77->class->vft[COLOR_abstract_collection__Iterator__is_ok]))(var77) /* is_ok on <var77:Iterator[nullable Object]>*/;
-if(!var78) break;
-var79 = ((val* (*)(val*))(var77->class->vft[COLOR_abstract_collection__Iterator__item]))(var77) /* item on <var77:Iterator[nullable Object]>*/;
-var_candidate80 = var79;
-var81 = ((val* (*)(val*))(var_candidate80->class->vft[COLOR_model_base__MModule__direct_owner]))(var_candidate80) /* direct_owner on <var_candidate80:MModule>*/;
-var82 = NULL;
-if (var81 == NULL) {
-var83 = 1; /* is null */
-} else {
-var83 = 0; /* arg is null but recv is not */
-}
-if (var83){
-var = var_candidate80;
-goto RET_LABEL;
-} else {
-}
-CONTINUE_label84: (void)0;
-((void (*)(val*))(var77->class->vft[COLOR_abstract_collection__Iterator__next]))(var77) /* next on <var77:Iterator[nullable Object]>*/;
-}
-BREAK_label84: (void)0;
-} else {
-}
-var85 = ((val* (*)(val*))(self->class->vft[COLOR_modelbuilder__ModelBuilder__paths]))(self) /* paths on <self:ModelBuilder>*/;
-var_lookpaths = var85;
-var86 = NULL;
-if (var_lastmodule == NULL) {
-var87 = 0; /* is null */
-} else {
-var87 = 1; /* arg is null and recv is not */
-}
-if (var87){
-var88 = ((val* (*)(val*))(var_lastmodule->class->vft[COLOR_model_base__MModule__location]))(var_lastmodule) /* location on <var_lastmodule:nullable MModule(MModule)>*/;
-var89 = ((val* (*)(val*))(var88->class->vft[COLOR_location__Location__file]))(var88) /* file on <var88:Location>*/;
-if (var89 == NULL) {
-fprintf(stderr, "Runtime error: %s", "Reciever is null");
-fprintf(stderr, " (%s:%d)\n", "src/modelbuilder.nit", 301);
-exit(1);
-} else {
-var90 = ((val* (*)(val*))(var89->class->vft[COLOR_location__SourceFile__filename]))(var89) /* filename on <var89:nullable SourceFile>*/;
-}
-var91 = ((val* (*)(val*))(var90->class->vft[COLOR_file__String__dirname]))(var90) /* dirname on <var90:String>*/;
-var_dirname92 = var91;
-if (varonce93) {
-var94 = varonce93;
-} else {
-var95 = "";
-var96 = 0;
-var97 = string__NativeString__to_s_with_length(var95, var96);
-var94 = var97;
-varonce93 = var94;
-}
-var98 = ((val* (*)(val*, val*))(var_dirname92->class->vft[COLOR_file__String__basename]))(var_dirname92, var94) /* basename on <var_dirname92:String>*/;
-var99 = ((val* (*)(val*))(var_lastmodule->class->vft[COLOR_model_base__MModule__name]))(var_lastmodule) /* name on <var_lastmodule:nullable MModule(MModule)>*/;
-var100 = ((short int (*)(val*, val*))(var98->class->vft[COLOR_kernel__Object___61d_61d]))(var98, var99) /* == on <var98:String>*/;
-if (var100){
-var101 = ((val* (*)(val*))(var_dirname92->class->vft[COLOR_file__String__dirname]))(var_dirname92) /* dirname on <var_dirname92:String>*/;
-var_dirname92 = var101;
-} else {
-}
-var102 = ((short int (*)(val*, val*))(var_lookpaths->class->vft[COLOR_abstract_collection__Collection__has]))(var_lookpaths, var_dirname92) /* has on <var_lookpaths:Array[String]>*/;
-var103 = !var102;
-if (var103){
-var104 = ((val* (*)(val*))(var_lookpaths->class->vft[COLOR_array__Collection__to_a]))(var_lookpaths) /* to_a on <var_lookpaths:Array[String]>*/;
-var_lookpaths = var104;
-((void (*)(val*, val*))(var_lookpaths->class->vft[COLOR_abstract_collection__SimpleCollection__add]))(var_lookpaths, var_dirname92) /* add on <var_lookpaths:Array[String]>*/;
-} else {
-}
-} else {
-}
-var105 = NULL;
-var_candidate106 = var105;
-var107 = ((val* (*)(val*))(var_lookpaths->class->vft[COLOR_abstract_collection__Collection__iterator]))(var_lookpaths) /* iterator on <var_lookpaths:Array[String]>*/;
-for(;;) {
-var108 = ((short int (*)(val*))(var107->class->vft[COLOR_abstract_collection__Iterator__is_ok]))(var107) /* is_ok on <var107:Iterator[nullable Object]>*/;
-if(!var108) break;
-var109 = ((val* (*)(val*))(var107->class->vft[COLOR_abstract_collection__Iterator__item]))(var107) /* item on <var107:Iterator[nullable Object]>*/;
-var_dirname110 = var109;
-if (varonce111) {
-var112 = varonce111;
-} else {
-var113 = "/";
-var114 = 1;
-var115 = string__NativeString__to_s_with_length(var113, var114);
-var112 = var115;
-varonce111 = var112;
-}
-var116 = ((val* (*)(val*, val*))(var_dirname110->class->vft[COLOR_string__String___43d]))(var_dirname110, var112) /* + on <var_dirname110:String>*/;
-var117 = ((val* (*)(val*, val*))(var116->class->vft[COLOR_string__String___43d]))(var116, var_name) /* + on <var116:String>*/;
-if (varonce118) {
-var119 = varonce118;
-} else {
-var120 = ".nit";
-var121 = 4;
-var122 = string__NativeString__to_s_with_length(var120, var121);
-var119 = var122;
-varonce118 = var119;
-}
-var123 = ((val* (*)(val*, val*))(var117->class->vft[COLOR_string__String___43d]))(var117, var119) /* + on <var117:String>*/;
-var124 = ((val* (*)(val*))(var123->class->vft[COLOR_file__String__simplify_path]))(var123) /* simplify_path on <var123:String>*/;
-var_try_file125 = var124;
-((void (*)(val*, val*))(var_tries->class->vft[COLOR_abstract_collection__SimpleCollection__add]))(var_tries, var_try_file125) /* add on <var_tries:Array[String]>*/;
-var126 = ((short int (*)(val*))(var_try_file125->class->vft[COLOR_file__String__file_exists]))(var_try_file125) /* file_exists on <var_try_file125:String>*/;
-if (var126){
-var127 = NULL;
-if (var_candidate106 == NULL) {
-var128 = 1; /* is null */
-} else {
-var128 = 0; /* arg is null but recv is not */
-}
-if (var128){
-var_candidate106 = var_try_file125;
-} else {
-var129 = ((short int (*)(val*, val*))(var_candidate106->class->vft[COLOR_kernel__Object___33d_61d]))(var_candidate106, var_try_file125) /* != on <var_candidate106:nullable String(String)>*/;
-if (var129){
-var130 = ((val* (*)(val*, val*))(self->class->vft[COLOR_modelbuilder__ModelBuilder__module_absolute_path]))(self, var_candidate106) /* module_absolute_path on <self:ModelBuilder>*/;
-var_abs_candidate = var130;
-var131 = ((val* (*)(val*, val*))(self->class->vft[COLOR_modelbuilder__ModelBuilder__module_absolute_path]))(self, var_try_file125) /* module_absolute_path on <self:ModelBuilder>*/;
-var_abs_try_file = var131;
-var132 = ((short int (*)(val*, val*))(var_abs_candidate->class->vft[COLOR_kernel__Object___33d_61d]))(var_abs_candidate, var_abs_try_file) /* != on <var_abs_candidate:String>*/;
-if (var132){
-if (varonce133) {
-var134 = varonce133;
-} else {
-var135 = "Error: conflicting module file for ";
-var136 = 35;
-var137 = string__NativeString__to_s_with_length(var135, var136);
-var134 = var137;
-varonce133 = var134;
-}
-if (varonce138) {
-var139 = varonce138;
-} else {
-var140 = ": ";
-var141 = 2;
-var142 = string__NativeString__to_s_with_length(var140, var141);
-var139 = var142;
-varonce138 = var139;
-}
-if (varonce143) {
-var144 = varonce143;
-} else {
-var145 = " ";
-var146 = 1;
-var147 = string__NativeString__to_s_with_length(var145, var146);
-var144 = var147;
-varonce143 = var144;
-}
-var148 = NEW_array__Array(&type_array__Arraykernel__Object);
-{ /* var148 = array_instance Array[Object] */
-var149 = 6;
-var150 = NEW_array__NativeArray(var149, &type_array__NativeArraykernel__Object);
-((struct instance_array__NativeArray*)var150)->values[0] = (val*) var134;
-((struct instance_array__NativeArray*)var150)->values[1] = (val*) var_name;
-((struct instance_array__NativeArray*)var150)->values[2] = (val*) var139;
-((struct instance_array__NativeArray*)var150)->values[3] = (val*) var_candidate106;
-((struct instance_array__NativeArray*)var150)->values[4] = (val*) var144;
-((struct instance_array__NativeArray*)var150)->values[5] = (val*) var_try_file125;
-((void (*)(val*, val*, long))(var148->class->vft[COLOR_array__Array__with_native]))(var148, var150, var149) /* with_native on <var148:Array[Object]>*/;
-CHECK_NEW_array__Array(var148);
-}
-var151 = ((val* (*)(val*))(var148->class->vft[COLOR_string__Object__to_s]))(var148) /* to_s on <var148:Array[Object]>*/;
-((void (*)(val*, val*, val*))(self->class->vft[COLOR_modelbuilder__ModelBuilder__error]))(self, var_anode, var151) /* error on <self:ModelBuilder>*/;
-} else {
-}
-} else {
-}
-}
-} else {
-}
-if (varonce152) {
-var153 = varonce152;
-} else {
-var154 = "/";
-var155 = 1;
-var156 = string__NativeString__to_s_with_length(var154, var155);
-var153 = var156;
-varonce152 = var153;
-}
-var157 = ((val* (*)(val*, val*))(var_dirname110->class->vft[COLOR_string__String___43d]))(var_dirname110, var153) /* + on <var_dirname110:String>*/;
-var158 = ((val* (*)(val*, val*))(var157->class->vft[COLOR_string__String___43d]))(var157, var_name) /* + on <var157:String>*/;
-if (varonce159) {
-var160 = varonce159;
-} else {
-var161 = "/";
-var162 = 1;
-var163 = string__NativeString__to_s_with_length(var161, var162);
-var160 = var163;
-varonce159 = var160;
-}
-var164 = ((val* (*)(val*, val*))(var158->class->vft[COLOR_string__String___43d]))(var158, var160) /* + on <var158:String>*/;
-var165 = ((val* (*)(val*, val*))(var164->class->vft[COLOR_string__String___43d]))(var164, var_name) /* + on <var164:String>*/;
-if (varonce166) {
-var167 = varonce166;
-} else {
-var168 = ".nit";
-var169 = 4;
-var170 = string__NativeString__to_s_with_length(var168, var169);
-var167 = var170;
-varonce166 = var167;
-}
-var171 = ((val* (*)(val*, val*))(var165->class->vft[COLOR_string__String___43d]))(var165, var167) /* + on <var165:String>*/;
-var172 = ((val* (*)(val*))(var171->class->vft[COLOR_file__String__simplify_path]))(var171) /* simplify_path on <var171:String>*/;
-var_try_file125 = var172;
-var173 = ((short int (*)(val*))(var_try_file125->class->vft[COLOR_file__String__file_exists]))(var_try_file125) /* file_exists on <var_try_file125:String>*/;
-if (var173){
-var174 = NULL;
-if (var_candidate106 == NULL) {
-var175 = 1; /* is null */
-} else {
-var175 = 0; /* arg is null but recv is not */
-}
-if (var175){
-var_candidate106 = var_try_file125;
-} else {
-var176 = ((short int (*)(val*, val*))(var_candidate106->class->vft[COLOR_kernel__Object___33d_61d]))(var_candidate106, var_try_file125) /* != on <var_candidate106:nullable String(String)>*/;
-if (var176){
-var177 = ((val* (*)(val*, val*))(self->class->vft[COLOR_modelbuilder__ModelBuilder__module_absolute_path]))(self, var_candidate106) /* module_absolute_path on <self:ModelBuilder>*/;
-var_abs_candidate178 = var177;
-var179 = ((val* (*)(val*, val*))(self->class->vft[COLOR_modelbuilder__ModelBuilder__module_absolute_path]))(self, var_try_file125) /* module_absolute_path on <self:ModelBuilder>*/;
-var_abs_try_file180 = var179;
-var181 = ((short int (*)(val*, val*))(var_abs_candidate178->class->vft[COLOR_kernel__Object___33d_61d]))(var_abs_candidate178, var_abs_try_file180) /* != on <var_abs_candidate178:String>*/;
-if (var181){
-if (varonce182) {
-var183 = varonce182;
-} else {
-var184 = "Error: conflicting module file for ";
-var185 = 35;
-var186 = string__NativeString__to_s_with_length(var184, var185);
-var183 = var186;
-varonce182 = var183;
-}
-if (varonce187) {
-var188 = varonce187;
-} else {
-var189 = ": ";
-var190 = 2;
-var191 = string__NativeString__to_s_with_length(var189, var190);
-var188 = var191;
-varonce187 = var188;
-}
-if (varonce192) {
-var193 = varonce192;
-} else {
-var194 = " ";
-var195 = 1;
-var196 = string__NativeString__to_s_with_length(var194, var195);
-var193 = var196;
-varonce192 = var193;
-}
-var197 = NEW_array__Array(&type_array__Arraykernel__Object);
-{ /* var197 = array_instance Array[Object] */
-var198 = 6;
-var199 = NEW_array__NativeArray(var198, &type_array__NativeArraykernel__Object);
-((struct instance_array__NativeArray*)var199)->values[0] = (val*) var183;
-((struct instance_array__NativeArray*)var199)->values[1] = (val*) var_name;
-((struct instance_array__NativeArray*)var199)->values[2] = (val*) var188;
-((struct instance_array__NativeArray*)var199)->values[3] = (val*) var_candidate106;
-((struct instance_array__NativeArray*)var199)->values[4] = (val*) var193;
-((struct instance_array__NativeArray*)var199)->values[5] = (val*) var_try_file125;
-((void (*)(val*, val*, long))(var197->class->vft[COLOR_array__Array__with_native]))(var197, var199, var198) /* with_native on <var197:Array[Object]>*/;
-CHECK_NEW_array__Array(var197);
-}
-var200 = ((val* (*)(val*))(var197->class->vft[COLOR_string__Object__to_s]))(var197) /* to_s on <var197:Array[Object]>*/;
-((void (*)(val*, val*, val*))(self->class->vft[COLOR_modelbuilder__ModelBuilder__error]))(self, var_anode, var200) /* error on <self:ModelBuilder>*/;
-} else {
-}
-} else {
-}
-}
-} else {
-}
-CONTINUE_label201: (void)0;
-((void (*)(val*))(var107->class->vft[COLOR_abstract_collection__Iterator__next]))(var107) /* next on <var107:Iterator[nullable Object]>*/;
-}
-BREAK_label201: (void)0;
-var202 = NULL;
-if (var_candidate106 == NULL) {
-var203 = 1; /* is null */
-} else {
-var203 = 0; /* arg is null but recv is not */
-}
-if (var203){
-var204 = NULL;
-if (var_origmmodule == NULL) {
-var205 = 0; /* is null */
-} else {
-var205 = 1; /* arg is null and recv is not */
-}
-if (var205){
-if (varonce206) {
-var207 = varonce206;
-} else {
-var208 = "Error: cannot find module ";
-var209 = 26;
-var210 = string__NativeString__to_s_with_length(var208, var209);
-var207 = var210;
-varonce206 = var207;
-}
-if (varonce211) {
-var212 = varonce211;
-} else {
-var213 = " from ";
-var214 = 6;
-var215 = string__NativeString__to_s_with_length(var213, var214);
-var212 = var215;
-varonce211 = var212;
-}
-if (varonce216) {
-var217 = varonce216;
-} else {
-var218 = ". tried ";
-var219 = 8;
-var220 = string__NativeString__to_s_with_length(var218, var219);
-var217 = var220;
-varonce216 = var217;
-}
-if (varonce221) {
-var222 = varonce221;
-} else {
-var223 = ", ";
-var224 = 2;
-var225 = string__NativeString__to_s_with_length(var223, var224);
-var222 = var225;
-varonce221 = var222;
-}
-var226 = ((val* (*)(val*, val*))(var_tries->class->vft[COLOR_string__Collection__join]))(var_tries, var222) /* join on <var_tries:Array[String]>*/;
-var227 = NEW_array__Array(&type_array__Arraykernel__Object);
-{ /* var227 = array_instance Array[Object] */
-var228 = 6;
-var229 = NEW_array__NativeArray(var228, &type_array__NativeArraykernel__Object);
-((struct instance_array__NativeArray*)var229)->values[0] = (val*) var207;
-((struct instance_array__NativeArray*)var229)->values[1] = (val*) var_name;
-((struct instance_array__NativeArray*)var229)->values[2] = (val*) var212;
-((struct instance_array__NativeArray*)var229)->values[3] = (val*) var_origmmodule;
-((struct instance_array__NativeArray*)var229)->values[4] = (val*) var217;
-((struct instance_array__NativeArray*)var229)->values[5] = (val*) var226;
-((void (*)(val*, val*, long))(var227->class->vft[COLOR_array__Array__with_native]))(var227, var229, var228) /* with_native on <var227:Array[Object]>*/;
-CHECK_NEW_array__Array(var227);
-}
-var230 = ((val* (*)(val*))(var227->class->vft[COLOR_string__Object__to_s]))(var227) /* to_s on <var227:Array[Object]>*/;
-((void (*)(val*, val*, val*))(self->class->vft[COLOR_modelbuilder__ModelBuilder__error]))(self, var_anode, var230) /* error on <self:ModelBuilder>*/;
-} else {
-if (varonce231) {
-var232 = varonce231;
-} else {
-var233 = "Error: cannot find module ";
-var234 = 26;
-var235 = string__NativeString__to_s_with_length(var233, var234);
-var232 = var235;
-varonce231 = var232;
-}
-if (varonce236) {
-var237 = varonce236;
-} else {
-var238 = ". tried ";
-var239 = 8;
-var240 = string__NativeString__to_s_with_length(var238, var239);
-var237 = var240;
-varonce236 = var237;
-}
-if (varonce241) {
-var242 = varonce241;
-} else {
-var243 = ", ";
-var244 = 2;
-var245 = string__NativeString__to_s_with_length(var243, var244);
-var242 = var245;
-varonce241 = var242;
-}
-var246 = ((val* (*)(val*, val*))(var_tries->class->vft[COLOR_string__Collection__join]))(var_tries, var242) /* join on <var_tries:Array[String]>*/;
-var247 = NEW_array__Array(&type_array__Arraykernel__Object);
-{ /* var247 = array_instance Array[Object] */
-var248 = 4;
-var249 = NEW_array__NativeArray(var248, &type_array__NativeArraykernel__Object);
-((struct instance_array__NativeArray*)var249)->values[0] = (val*) var232;
-((struct instance_array__NativeArray*)var249)->values[1] = (val*) var_name;
-((struct instance_array__NativeArray*)var249)->values[2] = (val*) var237;
-((struct instance_array__NativeArray*)var249)->values[3] = (val*) var246;
-((void (*)(val*, val*, long))(var247->class->vft[COLOR_array__Array__with_native]))(var247, var249, var248) /* with_native on <var247:Array[Object]>*/;
-CHECK_NEW_array__Array(var247);
-}
-var250 = ((val* (*)(val*))(var247->class->vft[COLOR_string__Object__to_s]))(var247) /* to_s on <var247:Array[Object]>*/;
-((void (*)(val*, val*, val*))(self->class->vft[COLOR_modelbuilder__ModelBuilder__error]))(self, var_anode, var250) /* error on <self:ModelBuilder>*/;
-}
-var251 = NULL;
-var = var251;
-goto RET_LABEL;
-} else {
-}
-var252 = ((val* (*)(val*, val*, val*))(self->class->vft[COLOR_modelbuilder__ModelBuilder__load_module]))(self, var_mmodule, var_candidate106) /* load_module on <self:ModelBuilder>*/;
-var_res253 = var252;
-var254 = NULL;
-if (var_res253 == NULL) {
-var255 = 1; /* is null */
-} else {
-var255 = 0; /* arg is null but recv is not */
-}
-if (var255){
-var256 = NULL;
-var = var256;
-goto RET_LABEL;
-} else {
-}
-var257 = ((val* (*)(val*))(var_res253->class->vft[COLOR_modelbuilder__AModule__mmodule]))(var_res253) /* mmodule on <var_res253:nullable AModule(AModule)>*/;
-if (var257 == NULL) {
-fprintf(stderr, "Runtime error: %s", "Cast failed");
-fprintf(stderr, " (%s:%d)\n", "src/modelbuilder.nit", 351);
-exit(1);
-}
-var = var257;
-goto RET_LABEL;
-RET_LABEL:;
-return var;
-}
-/* method modelbuilder#ModelBuilder#get_mmodule_by_name for (self: Object, ANode, nullable MModule, String): nullable MModule */
-val* VIRTUAL_modelbuilder__ModelBuilder__get_mmodule_by_name(val* self, val* p0, val* p1, val* p2) {
-val* var /* : nullable MModule */;
-val* var1 /* : nullable MModule */;
-var1 = modelbuilder__ModelBuilder__get_mmodule_by_name(self, p0, p1, p2);
-var = var1;
-RET_LABEL:;
-return var;
-}
-/* method modelbuilder#ModelBuilder#module_absolute_path for (self: ModelBuilder, String): String */
-val* modelbuilder__ModelBuilder__module_absolute_path(val* self, val* p0) {
-val* var /* : String */;
-val* var_path /* var path: String */;
-static val* varonce;
-val* var1 /* : String */;
-char* var2 /* : NativeString */;
-long var3 /* : Int */;
-val* var4 /* : String */;
-short int var5 /* : Bool */;
-val* var6 /* : String */;
-val* var7 /* : String */;
-val* var8 /* : String */;
-var_path = p0;
-if (varonce) {
-var1 = varonce;
-} else {
-var2 = "..";
-var3 = 2;
-var4 = string__NativeString__to_s_with_length(var2, var3);
-var1 = var4;
-varonce = var1;
-}
-var5 = ((short int (*)(val*, val*))(var_path->class->vft[COLOR_string__AbstractString__has_prefix]))(var_path, var1) /* has_prefix on <var_path:String>*/;
-if (var5){
-var6 = ((val* (*)(val*))(self->class->vft[COLOR_file__Object__getcwd]))(self) /* getcwd on <self:ModelBuilder>*/;
-var7 = ((val* (*)(val*, val*))(var6->class->vft[COLOR_file__String__join_path]))(var6, var_path) /* join_path on <var6:String>*/;
-var8 = ((val* (*)(val*))(var7->class->vft[COLOR_file__String__simplify_path]))(var7) /* simplify_path on <var7:String>*/;
-var = var8;
-goto RET_LABEL;
-} else {
-}
-var = var_path;
-goto RET_LABEL;
-RET_LABEL:;
-return var;
-}
-/* method modelbuilder#ModelBuilder#module_absolute_path for (self: Object, String): String */
-val* VIRTUAL_modelbuilder__ModelBuilder__module_absolute_path(val* self, val* p0) {
-val* var /* : String */;
-val* var1 /* : String */;
-var1 = modelbuilder__ModelBuilder__module_absolute_path(self, p0);
-var = var1;
-RET_LABEL:;
-return var;
-}
-/* method modelbuilder#ModelBuilder#loaded_nmodules for (self: ModelBuilder): HashMap[String, AModule] */
-val* modelbuilder__ModelBuilder__loaded_nmodules(val* self) {
-val* var /* : HashMap[String, AModule] */;
-val* var1 /* : HashMap[String, AModule] */;
-var1 = self->attrs[COLOR_modelbuilder__ModelBuilder___64dloaded_nmodules].val; /* @loaded_nmodules on <self:ModelBuilder> */
-if (var1 == NULL) {
-fprintf(stderr, "Runtime error: %s", "Uninitialized attribute @loaded_nmodules");
-fprintf(stderr, " (%s:%d)\n", "src/modelbuilder.nit", 362);
-exit(1);
-}
-var = var1;
-RET_LABEL:;
-return var;
-}
-/* method modelbuilder#ModelBuilder#loaded_nmodules for (self: Object): HashMap[String, AModule] */
-val* VIRTUAL_modelbuilder__ModelBuilder__loaded_nmodules(val* self) {
-val* var /* : HashMap[String, AModule] */;
-val* var1 /* : HashMap[String, AModule] */;
-var1 = modelbuilder__ModelBuilder__loaded_nmodules(self);
-var = var1;
-RET_LABEL:;
-return var;
-}
-/* method modelbuilder#ModelBuilder#loaded_nmodules= for (self: ModelBuilder, HashMap[String, AModule]) */
-void modelbuilder__ModelBuilder__loaded_nmodules_61d(val* self, val* p0) {
-self->attrs[COLOR_modelbuilder__ModelBuilder___64dloaded_nmodules].val = p0; /* @loaded_nmodules on <self:ModelBuilder> */
-RET_LABEL:;
-}
-/* method modelbuilder#ModelBuilder#loaded_nmodules= for (self: Object, HashMap[String, AModule]) */
-void VIRTUAL_modelbuilder__ModelBuilder__loaded_nmodules_61d(val* self, val* p0) {
-modelbuilder__ModelBuilder__loaded_nmodules_61d(self, p0);
-RET_LABEL:;
-}
-/* method modelbuilder#ModelBuilder#load_module for (self: ModelBuilder, nullable MModule, String): nullable AModule */
-val* modelbuilder__ModelBuilder__load_module(val* self, val* p0, val* p1) {
-val* var /* : nullable AModule */;
-val* var_owner /* var owner: nullable MModule */;
-val* var_filename /* var filename: String */;
-val* var1 /* : nullable String */;
-static val* varonce;
-val* var2 /* : String */;
-char* var3 /* : NativeString */;
-long var4 /* : Int */;
-val* var5 /* : String */;
-short int var6 /* : Bool */;
-val* var7 /* : ToolContext */;
-val* var8 /* : null */;
-static val* varonce9;
-val* var10 /* : String */;
-char* var11 /* : NativeString */;
-long var12 /* : Int */;
-val* var13 /* : String */;
-static val* varonce14;
-val* var15 /* : String */;
-char* var16 /* : NativeString */;
-long var17 /* : Int */;
-val* var18 /* : String */;
-val* var19 /* : Array[Object] */;
-long var20 /* : Int */;
-val* var21 /* : NativeArray[Object] */;
-val* var22 /* : String */;
-val* var23 /* : null */;
-short int var24 /* : Bool */;
-short int var25 /* : Bool */;
-val* var26 /* : ToolContext */;
-val* var27 /* : null */;
-static val* varonce28;
-val* var29 /* : String */;
-char* var30 /* : NativeString */;
-long var31 /* : Int */;
-val* var32 /* : String */;
-static val* varonce33;
-val* var34 /* : String */;
-char* var35 /* : NativeString */;
-long var36 /* : Int */;
-val* var37 /* : String */;
-val* var38 /* : Array[Object] */;
-long var39 /* : Int */;
-val* var40 /* : NativeArray[Object] */;
-val* var41 /* : String */;
-val* var42 /* : null */;
-val* var43 /* : String */;
-val* var_module_path /* var module_path: String */;
-val* var44 /* : HashMap[String, AModule] */;
-val* var45 /* : Collection[Object] */;
-short int var46 /* : Bool */;
-val* var47 /* : HashMap[String, AModule] */;
-val* var48 /* : nullable Object */;
-val* var49 /* : String */;
-val* var50 /* : null */;
-short int var51 /* : Bool */;
-val* var52 /* : String */;
-static val* varonce53;
-val* var54 /* : String */;
-char* var55 /* : NativeString */;
-long var56 /* : Int */;
-val* var57 /* : String */;
-val* var_x /* var x: String */;
-val* var58 /* : ToolContext */;
-static val* varonce59;
-val* var60 /* : String */;
-char* var61 /* : NativeString */;
-long var62 /* : Int */;
-val* var63 /* : String */;
-static val* varonce64;
-val* var65 /* : String */;
-char* var66 /* : NativeString */;
-long var67 /* : Int */;
-val* var68 /* : String */;
-val* var69 /* : Array[Object] */;
-long var70 /* : Int */;
-val* var71 /* : NativeArray[Object] */;
-val* var72 /* : String */;
-long var73 /* : Int */;
-val* var74 /* : IFStream */;
-val* var_file /* var file: IFStream */;
-val* var75 /* : Lexer */;
-val* var76 /* : SourceFile */;
-val* var_lexer /* var lexer: Lexer */;
-val* var77 /* : Parser */;
-val* var_parser /* var parser: Parser */;
-val* var78 /* : Start */;
-val* var_tree /* var tree: Start */;
-val* var79 /* : nullable AModule */;
-val* var_nmodule /* var nmodule: nullable AModule */;
-val* var80 /* : null */;
-short int var81 /* : Bool */;
-val* var82 /* : EOF */;
-val* var_neof /* var neof: EOF */;
-short int var83 /* : Bool */;
-int cltype;
-int idtype;
-val* var84 /* : String */;
-val* var85 /* : null */;
-static val* varonce86;
-val* var87 /* : String */;
-char* var88 /* : NativeString */;
-long var89 /* : Int */;
-val* var90 /* : String */;
-val* var91 /* : String */;
-val* var_mod_name /* var mod_name: String */;
-val* var92 /* : nullable AModuledecl */;
-val* var_decl /* var decl: nullable AModuledecl */;
-val* var93 /* : null */;
-short int var94 /* : Bool */;
-val* var95 /* : AModuleName */;
-val* var96 /* : TId */;
-val* var97 /* : String */;
-val* var_decl_name /* var decl_name: String */;
-short int var98 /* : Bool */;
-val* var99 /* : AModuleName */;
-static val* varonce100;
-val* var101 /* : String */;
-char* var102 /* : NativeString */;
-long var103 /* : Int */;
-val* var104 /* : String */;
-static val* varonce105;
-val* var106 /* : String */;
-char* var107 /* : NativeString */;
-long var108 /* : Int */;
-val* var109 /* : String */;
-val* var110 /* : Array[Object] */;
-long var111 /* : Int */;
-val* var112 /* : NativeArray[Object] */;
-val* var113 /* : String */;
-val* var114 /* : MModule */;
-val* var115 /* : Model */;
-val* var116 /* : Location */;
-val* var_mmodule /* var mmodule: MModule */;
-val* var117 /* : Array[AModule] */;
-val* var118 /* : HashMap[MModule, AModule] */;
-val* var119 /* : HashMap[String, AModule] */;
-var_owner = p0;
-var_filename = p1;
-var1 = ((val* (*)(val*))(var_filename->class->vft[COLOR_file__String__file_extension]))(var_filename) /* file_extension on <var_filename:String>*/;
-if (varonce) {
-var2 = varonce;
-} else {
-var3 = "nit";
-var4 = 3;
-var5 = string__NativeString__to_s_with_length(var3, var4);
-var2 = var5;
-varonce = var2;
-}
-if (var1 == NULL) {
-var6 = 1; /* <var2:String> cannot be null */
-} else {
-var6 = ((short int (*)(val*, val*))(var1->class->vft[COLOR_kernel__Object___33d_61d]))(var1, var2) /* != on <var1:nullable String>*/;
-}
-if (var6){
-var7 = ((val* (*)(val*))(self->class->vft[COLOR_modelbuilder__ModelBuilder__toolcontext]))(self) /* toolcontext on <self:ModelBuilder>*/;
-var8 = NULL;
-if (varonce9) {
-var10 = varonce9;
-} else {
-var11 = "Error: file ";
-var12 = 12;
-var13 = string__NativeString__to_s_with_length(var11, var12);
-var10 = var13;
-varonce9 = var10;
-}
-if (varonce14) {
-var15 = varonce14;
-} else {
-var16 = " is not a valid nit module.";
-var17 = 27;
-var18 = string__NativeString__to_s_with_length(var16, var17);
-var15 = var18;
-varonce14 = var15;
-}
-var19 = NEW_array__Array(&type_array__Arraykernel__Object);
-{ /* var19 = array_instance Array[Object] */
-var20 = 3;
-var21 = NEW_array__NativeArray(var20, &type_array__NativeArraykernel__Object);
-((struct instance_array__NativeArray*)var21)->values[0] = (val*) var10;
-((struct instance_array__NativeArray*)var21)->values[1] = (val*) var_filename;
-((struct instance_array__NativeArray*)var21)->values[2] = (val*) var15;
-((void (*)(val*, val*, long))(var19->class->vft[COLOR_array__Array__with_native]))(var19, var21, var20) /* with_native on <var19:Array[Object]>*/;
-CHECK_NEW_array__Array(var19);
-}
-var22 = ((val* (*)(val*))(var19->class->vft[COLOR_string__Object__to_s]))(var19) /* to_s on <var19:Array[Object]>*/;
-((void (*)(val*, val*, val*))(var7->class->vft[COLOR_toolcontext__ToolContext__error]))(var7, var8, var22) /* error on <var7:ToolContext>*/;
-var23 = NULL;
-var = var23;
-goto RET_LABEL;
-} else {
-}
-var24 = ((short int (*)(val*))(var_filename->class->vft[COLOR_file__String__file_exists]))(var_filename) /* file_exists on <var_filename:String>*/;
-var25 = !var24;
-if (var25){
-var26 = ((val* (*)(val*))(self->class->vft[COLOR_modelbuilder__ModelBuilder__toolcontext]))(self) /* toolcontext on <self:ModelBuilder>*/;
-var27 = NULL;
-if (varonce28) {
-var29 = varonce28;
-} else {
-var30 = "Error: file ";
-var31 = 12;
-var32 = string__NativeString__to_s_with_length(var30, var31);
-var29 = var32;
-varonce28 = var29;
-}
-if (varonce33) {
-var34 = varonce33;
-} else {
-var35 = " not found.";
-var36 = 11;
-var37 = string__NativeString__to_s_with_length(var35, var36);
-var34 = var37;
-varonce33 = var34;
-}
-var38 = NEW_array__Array(&type_array__Arraykernel__Object);
-{ /* var38 = array_instance Array[Object] */
-var39 = 3;
-var40 = NEW_array__NativeArray(var39, &type_array__NativeArraykernel__Object);
-((struct instance_array__NativeArray*)var40)->values[0] = (val*) var29;
-((struct instance_array__NativeArray*)var40)->values[1] = (val*) var_filename;
-((struct instance_array__NativeArray*)var40)->values[2] = (val*) var34;
-((void (*)(val*, val*, long))(var38->class->vft[COLOR_array__Array__with_native]))(var38, var40, var39) /* with_native on <var38:Array[Object]>*/;
-CHECK_NEW_array__Array(var38);
-}
-var41 = ((val* (*)(val*))(var38->class->vft[COLOR_string__Object__to_s]))(var38) /* to_s on <var38:Array[Object]>*/;
-((void (*)(val*, val*, val*))(var26->class->vft[COLOR_toolcontext__ToolContext__error]))(var26, var27, var41) /* error on <var26:ToolContext>*/;
-var42 = NULL;
-var = var42;
-goto RET_LABEL;
-} else {
-}
-var43 = ((val* (*)(val*, val*))(self->class->vft[COLOR_modelbuilder__ModelBuilder__module_absolute_path]))(self, var_filename) /* module_absolute_path on <self:ModelBuilder>*/;
-var_module_path = var43;
-var44 = ((val* (*)(val*))(self->class->vft[COLOR_modelbuilder__ModelBuilder__loaded_nmodules]))(self) /* loaded_nmodules on <self:ModelBuilder>*/;
-var45 = ((val* (*)(val*))(var44->class->vft[COLOR_abstract_collection__MapRead__keys]))(var44) /* keys on <var44:HashMap[String, AModule]>*/;
-var46 = ((short int (*)(val*, val*))(var45->class->vft[COLOR_abstract_collection__Collection__has]))(var45, var_module_path) /* has on <var45:Collection[Object](HashMapKeys[String, AModule])>*/;
-if (var46){
-var47 = ((val* (*)(val*))(self->class->vft[COLOR_modelbuilder__ModelBuilder__loaded_nmodules]))(self) /* loaded_nmodules on <self:ModelBuilder>*/;
-var48 = ((val* (*)(val*, val*))(var47->class->vft[COLOR_abstract_collection__MapRead___91d_93d]))(var47, var_module_path) /* [] on <var47:HashMap[String, AModule]>*/;
-var = var48;
-goto RET_LABEL;
-} else {
-}
-var50 = NULL;
-if (var_owner == NULL) {
-var51 = 0; /* is null */
-} else {
-var51 = 1; /* arg is null and recv is not */
-}
-if (var51){
-var52 = ((val* (*)(val*))(var_owner->class->vft[COLOR_string__Object__to_s]))(var_owner) /* to_s on <var_owner:nullable MModule(MModule)>*/;
-var49 = var52;
-} else {
-if (varonce53) {
-var54 = varonce53;
-} else {
-var55 = ".";
-var56 = 1;
-var57 = string__NativeString__to_s_with_length(var55, var56);
-var54 = var57;
-varonce53 = var54;
-}
-var49 = var54;
-}
-var_x = var49;
-var58 = ((val* (*)(val*))(self->class->vft[COLOR_modelbuilder__ModelBuilder__toolcontext]))(self) /* toolcontext on <self:ModelBuilder>*/;
-if (varonce59) {
-var60 = varonce59;
-} else {
-var61 = "load module ";
-var62 = 12;
-var63 = string__NativeString__to_s_with_length(var61, var62);
-var60 = var63;
-varonce59 = var60;
-}
-if (varonce64) {
-var65 = varonce64;
-} else {
-var66 = " in ";
-var67 = 4;
-var68 = string__NativeString__to_s_with_length(var66, var67);
-var65 = var68;
-varonce64 = var65;
-}
-var69 = NEW_array__Array(&type_array__Arraykernel__Object);
-{ /* var69 = array_instance Array[Object] */
-var70 = 4;
-var71 = NEW_array__NativeArray(var70, &type_array__NativeArraykernel__Object);
-((struct instance_array__NativeArray*)var71)->values[0] = (val*) var60;
-((struct instance_array__NativeArray*)var71)->values[1] = (val*) var_filename;
-((struct instance_array__NativeArray*)var71)->values[2] = (val*) var65;
-((struct instance_array__NativeArray*)var71)->values[3] = (val*) var_x;
-((void (*)(val*, val*, long))(var69->class->vft[COLOR_array__Array__with_native]))(var69, var71, var70) /* with_native on <var69:Array[Object]>*/;
-CHECK_NEW_array__Array(var69);
-}
-var72 = ((val* (*)(val*))(var69->class->vft[COLOR_string__Object__to_s]))(var69) /* to_s on <var69:Array[Object]>*/;
-var73 = 2;
-((void (*)(val*, val*, long))(var58->class->vft[COLOR_toolcontext__ToolContext__info]))(var58, var72, var73) /* info on <var58:ToolContext>*/;
-var74 = NEW_file__IFStream(&type_file__IFStream);
-((void (*)(val*, val*))(var74->class->vft[COLOR_file__IFStream__open]))(var74, var_filename) /* open on <var74:IFStream>*/;
-CHECK_NEW_file__IFStream(var74);
-var_file = var74;
-var75 = NEW_lexer__Lexer(&type_lexer__Lexer);
-var76 = NEW_location__SourceFile(&type_location__SourceFile);
-((void (*)(val*, val*, val*))(var76->class->vft[COLOR_location__SourceFile__init]))(var76, var_filename, var_file) /* init on <var76:SourceFile>*/;
-CHECK_NEW_location__SourceFile(var76);
-((void (*)(val*, val*))(var75->class->vft[COLOR_lexer__Lexer__init]))(var75, var76) /* init on <var75:Lexer>*/;
-CHECK_NEW_lexer__Lexer(var75);
-var_lexer = var75;
-var77 = NEW_parser__Parser(&type_parser__Parser);
-((void (*)(val*, val*))(var77->class->vft[COLOR_parser__Parser__init]))(var77, var_lexer) /* init on <var77:Parser>*/;
-CHECK_NEW_parser__Parser(var77);
-var_parser = var77;
-var78 = ((val* (*)(val*))(var_parser->class->vft[COLOR_parser__Parser__parse]))(var_parser) /* parse on <var_parser:Parser>*/;
-var_tree = var78;
-((void (*)(val*))(var_file->class->vft[COLOR_stream__IOS__close]))(var_file) /* close on <var_file:IFStream>*/;
-var79 = ((val* (*)(val*))(var_tree->class->vft[COLOR_parser_nodes__Start__n_base]))(var_tree) /* n_base on <var_tree:Start>*/;
-var_nmodule = var79;
-var80 = NULL;
-if (var_nmodule == NULL) {
-var81 = 1; /* is null */
-} else {
-var81 = 0; /* arg is null but recv is not */
-}
-if (var81){
-var82 = ((val* (*)(val*))(var_tree->class->vft[COLOR_parser_nodes__Start__n_eof]))(var_tree) /* n_eof on <var_tree:Start>*/;
-var_neof = var82;
-/* <var_neof:EOF> isa AError */
-cltype = type_parser_nodes__AError.color;
-idtype = type_parser_nodes__AError.id;
-if(cltype >= var_neof->type->table_size) {
-var83 = 0;
-} else {
-var83 = var_neof->type->type_table[cltype] == idtype;
-}
-if (!var83) {
-fprintf(stderr, "Runtime error: %s", "Assert failed");
-fprintf(stderr, " (%s:%d)\n", "src/modelbuilder.nit", 398);
-exit(1);
-}
-var84 = ((val* (*)(val*))(var_neof->class->vft[COLOR_lexer__AError__message]))(var_neof) /* message on <var_neof:EOF(AError)>*/;
-((void (*)(val*, val*, val*))(self->class->vft[COLOR_modelbuilder__ModelBuilder__error]))(self, var_neof, var84) /* error on <self:ModelBuilder>*/;
-var85 = NULL;
-var = var85;
-goto RET_LABEL;
-} else {
-}
-if (varonce86) {
-var87 = varonce86;
-} else {
-var88 = ".nit";
-var89 = 4;
-var90 = string__NativeString__to_s_with_length(var88, var89);
-var87 = var90;
-varonce86 = var87;
-}
-var91 = ((val* (*)(val*, val*))(var_filename->class->vft[COLOR_file__String__basename]))(var_filename, var87) /* basename on <var_filename:String>*/;
-var_mod_name = var91;
-var92 = ((val* (*)(val*))(var_nmodule->class->vft[COLOR_parser_nodes__AModule__n_moduledecl]))(var_nmodule) /* n_moduledecl on <var_nmodule:nullable AModule(AModule)>*/;
-var_decl = var92;
-var93 = NULL;
-if (var_decl == NULL) {
-var94 = 1; /* is null */
-} else {
-var94 = 0; /* arg is null but recv is not */
-}
-if (var94){
-} else {
-var95 = ((val* (*)(val*))(var_decl->class->vft[COLOR_parser_nodes__AModuledecl__n_name]))(var_decl) /* n_name on <var_decl:nullable AModuledecl(AModuledecl)>*/;
-var96 = ((val* (*)(val*))(var95->class->vft[COLOR_parser_nodes__AModuleName__n_id]))(var95) /* n_id on <var95:AModuleName>*/;
-var97 = ((val* (*)(val*))(var96->class->vft[COLOR_parser_nodes__Token__text]))(var96) /* text on <var96:TId>*/;
-var_decl_name = var97;
-var98 = ((short int (*)(val*, val*))(var_decl_name->class->vft[COLOR_kernel__Object___33d_61d]))(var_decl_name, var_mod_name) /* != on <var_decl_name:String>*/;
-if (var98){
-var99 = ((val* (*)(val*))(var_decl->class->vft[COLOR_parser_nodes__AModuledecl__n_name]))(var_decl) /* n_name on <var_decl:nullable AModuledecl(AModuledecl)>*/;
-if (varonce100) {
-var101 = varonce100;
-} else {
-var102 = "Error: module name missmatch; declared ";
-var103 = 39;
-var104 = string__NativeString__to_s_with_length(var102, var103);
-var101 = var104;
-varonce100 = var101;
-}
-if (varonce105) {
-var106 = varonce105;
-} else {
-var107 = " file named ";
-var108 = 12;
-var109 = string__NativeString__to_s_with_length(var107, var108);
-var106 = var109;
-varonce105 = var106;
-}
-var110 = NEW_array__Array(&type_array__Arraykernel__Object);
-{ /* var110 = array_instance Array[Object] */
-var111 = 4;
-var112 = NEW_array__NativeArray(var111, &type_array__NativeArraykernel__Object);
-((struct instance_array__NativeArray*)var112)->values[0] = (val*) var101;
-((struct instance_array__NativeArray*)var112)->values[1] = (val*) var_decl_name;
-((struct instance_array__NativeArray*)var112)->values[2] = (val*) var106;
-((struct instance_array__NativeArray*)var112)->values[3] = (val*) var_mod_name;
-((void (*)(val*, val*, long))(var110->class->vft[COLOR_array__Array__with_native]))(var110, var112, var111) /* with_native on <var110:Array[Object]>*/;
-CHECK_NEW_array__Array(var110);
-}
-var113 = ((val* (*)(val*))(var110->class->vft[COLOR_string__Object__to_s]))(var110) /* to_s on <var110:Array[Object]>*/;
-((void (*)(val*, val*, val*))(self->class->vft[COLOR_modelbuilder__ModelBuilder__error]))(self, var99, var113) /* error on <self:ModelBuilder>*/;
-} else {
-}
-}
-var114 = NEW_model_base__MModule(&type_model_base__MModule);
-var115 = ((val* (*)(val*))(self->class->vft[COLOR_modelbuilder__ModelBuilder__model]))(self) /* model on <self:ModelBuilder>*/;
-var116 = ((val* (*)(val*))(var_nmodule->class->vft[COLOR_parser_nodes__ANode__location]))(var_nmodule) /* location on <var_nmodule:nullable AModule(AModule)>*/;
-((void (*)(val*, val*, val*, val*, val*))(var114->class->vft[COLOR_model_base__MModule__init]))(var114, var115, var_owner, var_mod_name, var116) /* init on <var114:MModule>*/;
-CHECK_NEW_model_base__MModule(var114);
-var_mmodule = var114;
-((void (*)(val*, val*))(var_nmodule->class->vft[COLOR_modelbuilder__AModule__mmodule_61d]))(var_nmodule, var_mmodule) /* mmodule= on <var_nmodule:nullable AModule(AModule)>*/;
-var117 = ((val* (*)(val*))(self->class->vft[COLOR_modelbuilder__ModelBuilder__nmodules]))(self) /* nmodules on <self:ModelBuilder>*/;
-((void (*)(val*, val*))(var117->class->vft[COLOR_abstract_collection__SimpleCollection__add]))(var117, var_nmodule) /* add on <var117:Array[AModule]>*/;
-var118 = ((val* (*)(val*))(self->class->vft[COLOR_modelbuilder__ModelBuilder__mmodule2nmodule]))(self) /* mmodule2nmodule on <self:ModelBuilder>*/;
-((void (*)(val*, val*, val*))(var118->class->vft[COLOR_abstract_collection__Map___91d_93d_61d]))(var118, var_mmodule, var_nmodule) /* []= on <var118:HashMap[MModule, AModule]>*/;
-var119 = ((val* (*)(val*))(self->class->vft[COLOR_modelbuilder__ModelBuilder__loaded_nmodules]))(self) /* loaded_nmodules on <self:ModelBuilder>*/;
-((void (*)(val*, val*, val*))(var119->class->vft[COLOR_abstract_collection__Map___91d_93d_61d]))(var119, var_module_path, var_nmodule) /* []= on <var119:HashMap[String, AModule]>*/;
-((void (*)(val*, val*))(self->class->vft[COLOR_modelbuilder__ModelBuilder__build_module_importation]))(self, var_nmodule) /* build_module_importation on <self:ModelBuilder>*/;
-var = var_nmodule;
-goto RET_LABEL;
-RET_LABEL:;
-return var;
-}
-/* method modelbuilder#ModelBuilder#load_module for (self: Object, nullable MModule, String): nullable AModule */
-val* VIRTUAL_modelbuilder__ModelBuilder__load_module(val* self, val* p0, val* p1) {
-val* var /* : nullable AModule */;
-val* var1 /* : nullable AModule */;
-var1 = modelbuilder__ModelBuilder__load_module(self, p0, p1);
-var = var1;
-RET_LABEL:;
-return var;
-}
-/* method modelbuilder#ModelBuilder#build_module_importation for (self: ModelBuilder, AModule) */
-void modelbuilder__ModelBuilder__build_module_importation(val* self, val* p0) {
-val* var_nmodule /* var nmodule: AModule */;
-short int var /* : Bool */;
-short int var1 /* : Bool */;
-val* var2 /* : nullable MModule */;
-val* var_mmodule /* var mmodule: MModule */;
-short int var3 /* : Bool */;
-short int var_stdimport /* var stdimport: Bool */;
-val* var4 /* : Array[MModule] */;
-val* var_imported_modules /* var imported_modules: Array[MModule] */;
-val* var5 /* : ANodes[AImport] */;
-val* var6 /* : Iterator[nullable Object] */;
-short int var7 /* : Bool */;
-val* var8 /* : nullable Object */;
-val* var_aimport /* var aimport: AImport */;
-short int var9 /* : Bool */;
-short int var10 /* : Bool */;
-int cltype;
-int idtype;
-short int var11 /* : Bool */;
-val* var12 /* : AModuleName */;
-val* var13 /* : TId */;
-val* var14 /* : String */;
-val* var_mod_name /* var mod_name: String */;
-val* var15 /* : AModuleName */;
-val* var16 /* : nullable MModule */;
-val* var_sup /* var sup: nullable MModule */;
-val* var17 /* : null */;
-short int var18 /* : Bool */;
-val* var19 /* : AVisibility */;
-val* var20 /* : MVisibility */;
-val* var_mvisibility /* var mvisibility: MVisibility */;
-val* var21 /* : MVisibility */;
-short int var22 /* : Bool */;
-val* var23 /* : AVisibility */;
-static val* varonce;
-val* var24 /* : String */;
-char* var25 /* : NativeString */;
-long var26 /* : Int */;
-val* var27 /* : String */;
-static val* varonce28;
-val* var29 /* : String */;
-char* var30 /* : NativeString */;
-long var31 /* : Int */;
-val* var32 /* : String */;
-val* var_mod_name33 /* var mod_name: String */;
-val* var34 /* : null */;
-val* var35 /* : nullable MModule */;
-val* var_sup36 /* var sup: nullable MModule */;
-val* var37 /* : null */;
-short int var38 /* : Bool */;
-val* var39 /* : MVisibility */;
-val* var40 /* : ToolContext */;
-static val* varonce41;
-val* var42 /* : String */;
-char* var43 /* : NativeString */;
-long var44 /* : Int */;
-val* var45 /* : String */;
-static val* varonce46;
-val* var47 /* : String */;
-char* var48 /* : NativeString */;
-long var49 /* : Int */;
-val* var50 /* : String */;
-val* var51 /* : String */;
-val* var52 /* : Array[Object] */;
-long var53 /* : Int */;
-val* var54 /* : NativeArray[Object] */;
-val* var55 /* : String */;
-long var56 /* : Int */;
-var_nmodule = p0;
-var = ((short int (*)(val*))(var_nmodule->class->vft[COLOR_modelbuilder__AModule__is_importation_done]))(var_nmodule) /* is_importation_done on <var_nmodule:AModule>*/;
-if (var){
-goto RET_LABEL;
-} else {
-}
-var1 = 1;
-((void (*)(val*, short int))(var_nmodule->class->vft[COLOR_modelbuilder__AModule__is_importation_done_61d]))(var_nmodule, var1) /* is_importation_done= on <var_nmodule:AModule>*/;
-var2 = ((val* (*)(val*))(var_nmodule->class->vft[COLOR_modelbuilder__AModule__mmodule]))(var_nmodule) /* mmodule on <var_nmodule:AModule>*/;
-if (var2 == NULL) {
-fprintf(stderr, "Runtime error: %s", "Cast failed");
-fprintf(stderr, " (%s:%d)\n", "src/modelbuilder.nit", 432);
-exit(1);
-}
-var_mmodule = var2;
-var3 = 1;
-var_stdimport = var3;
-var4 = NEW_array__Array(&type_array__Arraymodel_base__MModule);
-((void (*)(val*))(var4->class->vft[COLOR_array__Array__init]))(var4) /* init on <var4:Array[MModule]>*/;
-CHECK_NEW_array__Array(var4);
-var_imported_modules = var4;
-var5 = ((val* (*)(val*))(var_nmodule->class->vft[COLOR_parser_nodes__AModule__n_imports]))(var_nmodule) /* n_imports on <var_nmodule:AModule>*/;
-var6 = ((val* (*)(val*))(var5->class->vft[COLOR_abstract_collection__Collection__iterator]))(var5) /* iterator on <var5:ANodes[AImport]>*/;
-for(;;) {
-var7 = ((short int (*)(val*))(var6->class->vft[COLOR_abstract_collection__Iterator__is_ok]))(var6) /* is_ok on <var6:Iterator[nullable Object]>*/;
-if(!var7) break;
-var8 = ((val* (*)(val*))(var6->class->vft[COLOR_abstract_collection__Iterator__item]))(var6) /* item on <var6:Iterator[nullable Object]>*/;
-var_aimport = var8;
-var9 = 0;
-var_stdimport = var9;
-/* <var_aimport:AImport> isa AStdImport */
-cltype = type_parser_nodes__AStdImport.color;
-idtype = type_parser_nodes__AStdImport.id;
-if(cltype >= var_aimport->type->table_size) {
-var10 = 0;
-} else {
-var10 = var_aimport->type->type_table[cltype] == idtype;
-}
-var11 = !var10;
-if (var11){
-goto CONTINUE_label;
-} else {
-}
-var12 = ((val* (*)(val*))(var_aimport->class->vft[COLOR_parser_nodes__AStdImport__n_name]))(var_aimport) /* n_name on <var_aimport:AImport(AStdImport)>*/;
-var13 = ((val* (*)(val*))(var12->class->vft[COLOR_parser_nodes__AModuleName__n_id]))(var12) /* n_id on <var12:AModuleName>*/;
-var14 = ((val* (*)(val*))(var13->class->vft[COLOR_parser_nodes__Token__text]))(var13) /* text on <var13:TId>*/;
-var_mod_name = var14;
-var15 = ((val* (*)(val*))(var_aimport->class->vft[COLOR_parser_nodes__AStdImport__n_name]))(var_aimport) /* n_name on <var_aimport:AImport(AStdImport)>*/;
-var16 = ((val* (*)(val*, val*, val*, val*))(self->class->vft[COLOR_modelbuilder__ModelBuilder__get_mmodule_by_name]))(self, var15, var_mmodule, var_mod_name) /* get_mmodule_by_name on <self:ModelBuilder>*/;
-var_sup = var16;
-var17 = NULL;
-if (var_sup == NULL) {
-var18 = 1; /* is null */
-} else {
-var18 = 0; /* arg is null but recv is not */
-}
-if (var18){
-goto CONTINUE_label;
-} else {
-}
-((void (*)(val*, val*))(var_aimport->class->vft[COLOR_modelbuilder__AStdImport__mmodule_61d]))(var_aimport, var_sup) /* mmodule= on <var_aimport:AImport(AStdImport)>*/;
-((void (*)(val*, val*))(var_imported_modules->class->vft[COLOR_abstract_collection__SimpleCollection__add]))(var_imported_modules, var_sup) /* add on <var_imported_modules:Array[MModule]>*/;
-var19 = ((val* (*)(val*))(var_aimport->class->vft[COLOR_parser_nodes__AStdImport__n_visibility]))(var_aimport) /* n_visibility on <var_aimport:AImport(AStdImport)>*/;
-var20 = ((val* (*)(val*))(var19->class->vft[COLOR_modelbuilder__AVisibility__mvisibility]))(var19) /* mvisibility on <var19:AVisibility>*/;
-var_mvisibility = var20;
-var21 = ((val* (*)(val*))(self->class->vft[COLOR_model_base__Object__protected_visibility]))(self) /* protected_visibility on <self:ModelBuilder>*/;
-var22 = ((short int (*)(val*, val*))(var_mvisibility->class->vft[COLOR_kernel__Object___61d_61d]))(var_mvisibility, var21) /* == on <var_mvisibility:MVisibility>*/;
-if (var22){
-var23 = ((val* (*)(val*))(var_aimport->class->vft[COLOR_parser_nodes__AStdImport__n_visibility]))(var_aimport) /* n_visibility on <var_aimport:AImport(AStdImport)>*/;
-if (varonce) {
-var24 = varonce;
-} else {
-var25 = "Error: only properties can be protected.";
-var26 = 40;
-var27 = string__NativeString__to_s_with_length(var25, var26);
-var24 = var27;
-varonce = var24;
-}
-((void (*)(val*, val*, val*))(self->class->vft[COLOR_modelbuilder__ModelBuilder__error]))(self, var23, var24) /* error on <self:ModelBuilder>*/;
-goto RET_LABEL;
-} else {
-}
-((void (*)(val*, val*, val*))(var_mmodule->class->vft[COLOR_model_base__MModule__set_visibility_for]))(var_mmodule, var_sup, var_mvisibility) /* set_visibility_for on <var_mmodule:MModule>*/;
-CONTINUE_label: (void)0;
-((void (*)(val*))(var6->class->vft[COLOR_abstract_collection__Iterator__next]))(var6) /* next on <var6:Iterator[nullable Object]>*/;
-}
-BREAK_label: (void)0;
-if (var_stdimport){
-if (varonce28) {
-var29 = varonce28;
-} else {
-var30 = "standard";
-var31 = 8;
-var32 = string__NativeString__to_s_with_length(var30, var31);
-var29 = var32;
-varonce28 = var29;
-}
-var_mod_name33 = var29;
-var34 = NULL;
-var35 = ((val* (*)(val*, val*, val*, val*))(self->class->vft[COLOR_modelbuilder__ModelBuilder__get_mmodule_by_name]))(self, var_nmodule, var34, var_mod_name33) /* get_mmodule_by_name on <self:ModelBuilder>*/;
-var_sup36 = var35;
-var37 = NULL;
-if (var_sup36 == NULL) {
-var38 = 0; /* is null */
-} else {
-var38 = 1; /* arg is null and recv is not */
-}
-if (var38){
-((void (*)(val*, val*))(var_imported_modules->class->vft[COLOR_abstract_collection__SimpleCollection__add]))(var_imported_modules, var_sup36) /* add on <var_imported_modules:Array[MModule]>*/;
-var39 = ((val* (*)(val*))(self->class->vft[COLOR_model_base__Object__public_visibility]))(self) /* public_visibility on <self:ModelBuilder>*/;
-((void (*)(val*, val*, val*))(var_mmodule->class->vft[COLOR_model_base__MModule__set_visibility_for]))(var_mmodule, var_sup36, var39) /* set_visibility_for on <var_mmodule:MModule>*/;
-} else {
-}
-} else {
-}
-var40 = ((val* (*)(val*))(self->class->vft[COLOR_modelbuilder__ModelBuilder__toolcontext]))(self) /* toolcontext on <self:ModelBuilder>*/;
-if (varonce41) {
-var42 = varonce41;
-} else {
-var43 = " imports ";
-var44 = 9;
-var45 = string__NativeString__to_s_with_length(var43, var44);
-var42 = var45;
-varonce41 = var42;
-}
-if (varonce46) {
-var47 = varonce46;
-} else {
-var48 = ", ";
-var49 = 2;
-var50 = string__NativeString__to_s_with_length(var48, var49);
-var47 = var50;
-varonce46 = var47;
-}
-var51 = ((val* (*)(val*, val*))(var_imported_modules->class->vft[COLOR_string__Collection__join]))(var_imported_modules, var47) /* join on <var_imported_modules:Array[MModule]>*/;
-var52 = NEW_array__Array(&type_array__Arraykernel__Object);
-{ /* var52 = array_instance Array[Object] */
-var53 = 3;
-var54 = NEW_array__NativeArray(var53, &type_array__NativeArraykernel__Object);
-((struct instance_array__NativeArray*)var54)->values[0] = (val*) var_mmodule;
-((struct instance_array__NativeArray*)var54)->values[1] = (val*) var42;
-((struct instance_array__NativeArray*)var54)->values[2] = (val*) var51;
-((void (*)(val*, val*, long))(var52->class->vft[COLOR_array__Array__with_native]))(var52, var54, var53) /* with_native on <var52:Array[Object]>*/;
-CHECK_NEW_array__Array(var52);
-}
-var55 = ((val* (*)(val*))(var52->class->vft[COLOR_string__Object__to_s]))(var52) /* to_s on <var52:Array[Object]>*/;
-var56 = 3;
-((void (*)(val*, val*, long))(var40->class->vft[COLOR_toolcontext__ToolContext__info]))(var40, var55, var56) /* info on <var40:ToolContext>*/;
-((void (*)(val*, val*))(var_mmodule->class->vft[COLOR_model_base__MModule__set_imported_mmodules]))(var_mmodule, var_imported_modules) /* set_imported_mmodules on <var_mmodule:MModule>*/;
-RET_LABEL:;
-}
-/* method modelbuilder#ModelBuilder#build_module_importation for (self: Object, AModule) */
-void VIRTUAL_modelbuilder__ModelBuilder__build_module_importation(val* self, val* p0) {
-modelbuilder__ModelBuilder__build_module_importation(self, p0);
-RET_LABEL:;
-}
-/* method modelbuilder#ModelBuilder#nmodules for (self: ModelBuilder): Array[AModule] */
-val* modelbuilder__ModelBuilder__nmodules(val* self) {
-val* var /* : Array[AModule] */;
-val* var1 /* : Array[AModule] */;
-var1 = self->attrs[COLOR_modelbuilder__ModelBuilder___64dnmodules].val; /* @nmodules on <self:ModelBuilder> */
-if (var1 == NULL) {
-fprintf(stderr, "Runtime error: %s", "Uninitialized attribute @nmodules");
-fprintf(stderr, " (%s:%d)\n", "src/modelbuilder.nit", 464);
-exit(1);
-}
-var = var1;
-RET_LABEL:;
-return var;
-}
-/* method modelbuilder#ModelBuilder#nmodules for (self: Object): Array[AModule] */
-val* VIRTUAL_modelbuilder__ModelBuilder__nmodules(val* self) {
-val* var /* : Array[AModule] */;
-val* var1 /* : Array[AModule] */;
-var1 = modelbuilder__ModelBuilder__nmodules(self);
-var = var1;
-RET_LABEL:;
-return var;
-}
-/* method modelbuilder#ModelBuilder#nmodules= for (self: ModelBuilder, Array[AModule]) */
-void modelbuilder__ModelBuilder__nmodules_61d(val* self, val* p0) {
-self->attrs[COLOR_modelbuilder__ModelBuilder___64dnmodules].val = p0; /* @nmodules on <self:ModelBuilder> */
-RET_LABEL:;
-}
-/* method modelbuilder#ModelBuilder#nmodules= for (self: Object, Array[AModule]) */
-void VIRTUAL_modelbuilder__ModelBuilder__nmodules_61d(val* self, val* p0) {
-modelbuilder__ModelBuilder__nmodules_61d(self, p0);
-RET_LABEL:;
-}
-/* method modelbuilder#ModelBuilder#mmodule2nmodule for (self: ModelBuilder): HashMap[MModule, AModule] */
-val* modelbuilder__ModelBuilder__mmodule2nmodule(val* self) {
-val* var /* : HashMap[MModule, AModule] */;
-val* var1 /* : HashMap[MModule, AModule] */;
-var1 = self->attrs[COLOR_modelbuilder__ModelBuilder___64dmmodule2nmodule].val; /* @mmodule2nmodule on <self:ModelBuilder> */
-if (var1 == NULL) {
-fprintf(stderr, "Runtime error: %s", "Uninitialized attribute @mmodule2nmodule");
-fprintf(stderr, " (%s:%d)\n", "src/modelbuilder.nit", 467);
-exit(1);
-}
-var = var1;
-RET_LABEL:;
-return var;
-}
-/* method modelbuilder#ModelBuilder#mmodule2nmodule for (self: Object): HashMap[MModule, AModule] */
-val* VIRTUAL_modelbuilder__ModelBuilder__mmodule2nmodule(val* self) {
-val* var /* : HashMap[MModule, AModule] */;
-val* var1 /* : HashMap[MModule, AModule] */;
-var1 = modelbuilder__ModelBuilder__mmodule2nmodule(self);
-var = var1;
-RET_LABEL:;
-return var;
-}
-/* method modelbuilder#ModelBuilder#mmodule2nmodule= for (self: ModelBuilder, HashMap[MModule, AModule]) */
-void modelbuilder__ModelBuilder__mmodule2nmodule_61d(val* self, val* p0) {
-self->attrs[COLOR_modelbuilder__ModelBuilder___64dmmodule2nmodule].val = p0; /* @mmodule2nmodule on <self:ModelBuilder> */
-RET_LABEL:;
-}
-/* method modelbuilder#ModelBuilder#mmodule2nmodule= for (self: Object, HashMap[MModule, AModule]) */
-void VIRTUAL_modelbuilder__ModelBuilder__mmodule2nmodule_61d(val* self, val* p0) {
-modelbuilder__ModelBuilder__mmodule2nmodule_61d(self, p0);
-RET_LABEL:;
-}
-/* method modelbuilder#ModelBuilder#error for (self: ModelBuilder, ANode, String) */
-void modelbuilder__ModelBuilder__error(val* self, val* p0, val* p1) {
-val* var_n /* var n: ANode */;
-val* var_text /* var text: String */;
-val* var /* : ToolContext */;
-val* var1 /* : Location */;
-var_n = p0;
-var_text = p1;
-var = ((val* (*)(val*))(self->class->vft[COLOR_modelbuilder__ModelBuilder__toolcontext]))(self) /* toolcontext on <self:ModelBuilder>*/;
-var1 = ((val* (*)(val*))(var_n->class->vft[COLOR_parser_nodes__ANode__hot_location]))(var_n) /* hot_location on <var_n:ANode>*/;
-((void (*)(val*, val*, val*))(var->class->vft[COLOR_toolcontext__ToolContext__error]))(var, var1, var_text) /* error on <var:ToolContext>*/;
-RET_LABEL:;
-}
-/* method modelbuilder#ModelBuilder#error for (self: Object, ANode, String) */
-void VIRTUAL_modelbuilder__ModelBuilder__error(val* self, val* p0, val* p1) {
-modelbuilder__ModelBuilder__error(self, p0, p1);
-RET_LABEL:;
-}
-/* method modelbuilder#ModelBuilder#warning for (self: ModelBuilder, ANode, String) */
-void modelbuilder__ModelBuilder__warning(val* self, val* p0, val* p1) {
-val* var_n /* var n: ANode */;
-val* var_text /* var text: String */;
-val* var /* : ToolContext */;
-val* var1 /* : Location */;
-var_n = p0;
-var_text = p1;
-var = ((val* (*)(val*))(self->class->vft[COLOR_modelbuilder__ModelBuilder__toolcontext]))(self) /* toolcontext on <self:ModelBuilder>*/;
-var1 = ((val* (*)(val*))(var_n->class->vft[COLOR_parser_nodes__ANode__hot_location]))(var_n) /* hot_location on <var_n:ANode>*/;
-((void (*)(val*, val*, val*))(var->class->vft[COLOR_toolcontext__ToolContext__warning]))(var, var1, var_text) /* warning on <var:ToolContext>*/;
-RET_LABEL:;
-}
-/* method modelbuilder#ModelBuilder#warning for (self: Object, ANode, String) */
-void VIRTUAL_modelbuilder__ModelBuilder__warning(val* self, val* p0, val* p1) {
-modelbuilder__ModelBuilder__warning(self, p0, p1);
-RET_LABEL:;
-}
-/* method modelbuilder#ModelBuilder#force_get_primitive_method for (self: ModelBuilder, ANode, String, MClass, MModule): MMethod */
-val* modelbuilder__ModelBuilder__force_get_primitive_method(val* self, val* p0, val* p1, val* p2, val* p3) {
-val* var /* : MMethod */;
-val* var_n /* var n: ANode */;
-val* var_name /* var name: String */;
-val* var_recv /* var recv: MClass */;
-val* var_mmodule /* var mmodule: MModule */;
-val* var1 /* : nullable MMethod */;
-val* var_res /* var res: nullable MMethod */;
-val* var2 /* : null */;
-short int var3 /* : Bool */;
-val* var4 /* : ToolContext */;
-val* var5 /* : Location */;
-static val* varonce;
-val* var6 /* : String */;
-char* var7 /* : NativeString */;
-long var8 /* : Int */;
-val* var9 /* : String */;
-static val* varonce10;
-val* var11 /* : String */;
-char* var12 /* : NativeString */;
-long var13 /* : Int */;
-val* var14 /* : String */;
-static val* varonce15;
-val* var16 /* : String */;
-char* var17 /* : NativeString */;
-long var18 /* : Int */;
-val* var19 /* : String */;
-val* var20 /* : Array[Object] */;
-long var21 /* : Int */;
-val* var22 /* : NativeArray[Object] */;
-val* var23 /* : String */;
-var_n = p0;
-var_name = p1;
-var_recv = p2;
-var_mmodule = p3;
-var1 = ((val* (*)(val*, val*, val*))(var_mmodule->class->vft[COLOR_model__MModule__try_get_primitive_method]))(var_mmodule, var_name, var_recv) /* try_get_primitive_method on <var_mmodule:MModule>*/;
-var_res = var1;
-var2 = NULL;
-if (var_res == NULL) {
-var3 = 1; /* is null */
-} else {
-var3 = 0; /* arg is null but recv is not */
-}
-if (var3){
-var4 = ((val* (*)(val*))(self->class->vft[COLOR_modelbuilder__ModelBuilder__toolcontext]))(self) /* toolcontext on <self:ModelBuilder>*/;
-var5 = ((val* (*)(val*))(var_n->class->vft[COLOR_parser_nodes__ANode__hot_location]))(var_n) /* hot_location on <var_n:ANode>*/;
-if (varonce) {
-var6 = varonce;
-} else {
-var7 = "Fatal Error: ";
-var8 = 13;
-var9 = string__NativeString__to_s_with_length(var7, var8);
-var6 = var9;
-varonce = var6;
-}
-if (varonce10) {
-var11 = varonce10;
-} else {
-var12 = " must have a property named ";
-var13 = 28;
-var14 = string__NativeString__to_s_with_length(var12, var13);
-var11 = var14;
-varonce10 = var11;
-}
-if (varonce15) {
-var16 = varonce15;
-} else {
-var17 = ".";
-var18 = 1;
-var19 = string__NativeString__to_s_with_length(var17, var18);
-var16 = var19;
-varonce15 = var16;
-}
-var20 = NEW_array__Array(&type_array__Arraykernel__Object);
-{ /* var20 = array_instance Array[Object] */
-var21 = 5;
-var22 = NEW_array__NativeArray(var21, &type_array__NativeArraykernel__Object);
-((struct instance_array__NativeArray*)var22)->values[0] = (val*) var6;
-((struct instance_array__NativeArray*)var22)->values[1] = (val*) var_recv;
-((struct instance_array__NativeArray*)var22)->values[2] = (val*) var11;
-((struct instance_array__NativeArray*)var22)->values[3] = (val*) var_name;
-((struct instance_array__NativeArray*)var22)->values[4] = (val*) var16;
-((void (*)(val*, val*, long))(var20->class->vft[COLOR_array__Array__with_native]))(var20, var22, var21) /* with_native on <var20:Array[Object]>*/;
-CHECK_NEW_array__Array(var20);
-}
-var23 = ((val* (*)(val*))(var20->class->vft[COLOR_string__Object__to_s]))(var20) /* to_s on <var20:Array[Object]>*/;
-((void (*)(val*, val*, val*))(var4->class->vft[COLOR_toolcontext__ToolContext__fatal_error]))(var4, var5, var23) /* fatal_error on <var4:ToolContext>*/;
-fprintf(stderr, "Runtime error: %s", "Aborted");
-fprintf(stderr, " (%s:%d)\n", "src/modelbuilder.nit", 491);
-exit(1);
-} else {
-}
-var = var_res;
-goto RET_LABEL;
-RET_LABEL:;
-return var;
-}
-/* method modelbuilder#ModelBuilder#force_get_primitive_method for (self: Object, ANode, String, MClass, MModule): MMethod */
-val* VIRTUAL_modelbuilder__ModelBuilder__force_get_primitive_method(val* self, val* p0, val* p1, val* p2, val* p3) {
-val* var /* : MMethod */;
-val* var1 /* : MMethod */;
-var1 = modelbuilder__ModelBuilder__force_get_primitive_method(self, p0, p1, p2, p3);
-var = var1;
-RET_LABEL:;
-return var;
-}
-/* method modelbuilder#AStdImport#mmodule for (self: AStdImport): nullable MModule */
-val* modelbuilder__AStdImport__mmodule(val* self) {
-val* var /* : nullable MModule */;
-val* var1 /* : nullable MModule */;
-var1 = self->attrs[COLOR_modelbuilder__AStdImport___64dmmodule].val; /* @mmodule on <self:AStdImport> */
-var = var1;
-RET_LABEL:;
-return var;
-}
-/* method modelbuilder#AStdImport#mmodule for (self: Object): nullable MModule */
-val* VIRTUAL_modelbuilder__AStdImport__mmodule(val* self) {
-val* var /* : nullable MModule */;
-val* var1 /* : nullable MModule */;
-var1 = modelbuilder__AStdImport__mmodule(self);
-var = var1;
-RET_LABEL:;
-return var;
-}
-/* method modelbuilder#AStdImport#mmodule= for (self: AStdImport, nullable MModule) */
-void modelbuilder__AStdImport__mmodule_61d(val* self, val* p0) {
-self->attrs[COLOR_modelbuilder__AStdImport___64dmmodule].val = p0; /* @mmodule on <self:AStdImport> */
-RET_LABEL:;
-}
-/* method modelbuilder#AStdImport#mmodule= for (self: Object, nullable MModule) */
-void VIRTUAL_modelbuilder__AStdImport__mmodule_61d(val* self, val* p0) {
-modelbuilder__AStdImport__mmodule_61d(self, p0);
-RET_LABEL:;
-}
-/* method modelbuilder#AModule#mmodule for (self: AModule): nullable MModule */
-val* modelbuilder__AModule__mmodule(val* self) {
-val* var /* : nullable MModule */;
-val* var1 /* : nullable MModule */;
-var1 = self->attrs[COLOR_modelbuilder__AModule___64dmmodule].val; /* @mmodule on <self:AModule> */
-var = var1;
-RET_LABEL:;
-return var;
-}
-/* method modelbuilder#AModule#mmodule for (self: Object): nullable MModule */
-val* VIRTUAL_modelbuilder__AModule__mmodule(val* self) {
-val* var /* : nullable MModule */;
-val* var1 /* : nullable MModule */;
-var1 = modelbuilder__AModule__mmodule(self);
-var = var1;
-RET_LABEL:;
-return var;
-}
-/* method modelbuilder#AModule#mmodule= for (self: AModule, nullable MModule) */
-void modelbuilder__AModule__mmodule_61d(val* self, val* p0) {
-self->attrs[COLOR_modelbuilder__AModule___64dmmodule].val = p0; /* @mmodule on <self:AModule> */
-RET_LABEL:;
-}
-/* method modelbuilder#AModule#mmodule= for (self: Object, nullable MModule) */
-void VIRTUAL_modelbuilder__AModule__mmodule_61d(val* self, val* p0) {
-modelbuilder__AModule__mmodule_61d(self, p0);
-RET_LABEL:;
-}
-/* method modelbuilder#AModule#is_importation_done for (self: AModule): Bool */
-short int modelbuilder__AModule__is_importation_done(val* self) {
-short int var /* : Bool */;
-short int var1 /* : Bool */;
-var1 = self->attrs[COLOR_modelbuilder__AModule___64dis_importation_done].s; /* @is_importation_done on <self:AModule> */
-var = var1;
-RET_LABEL:;
-return var;
-}
-/* method modelbuilder#AModule#is_importation_done for (self: Object): Bool */
-short int VIRTUAL_modelbuilder__AModule__is_importation_done(val* self) {
-short int var /* : Bool */;
-short int var1 /* : Bool */;
-var1 = modelbuilder__AModule__is_importation_done(self);
-var = var1;
-RET_LABEL:;
-return var;
-}
-/* method modelbuilder#AModule#is_importation_done= for (self: AModule, Bool) */
-void modelbuilder__AModule__is_importation_done_61d(val* self, short int p0) {
-self->attrs[COLOR_modelbuilder__AModule___64dis_importation_done].s = p0; /* @is_importation_done on <self:AModule> */
-RET_LABEL:;
-}
-/* method modelbuilder#AModule#is_importation_done= for (self: Object, Bool) */
-void VIRTUAL_modelbuilder__AModule__is_importation_done_61d(val* self, short int p0) {
-modelbuilder__AModule__is_importation_done_61d(self, p0);
-RET_LABEL:;
-}
-/* method modelbuilder#AVisibility#mvisibility for (self: AVisibility): MVisibility */
-val* modelbuilder__AVisibility__mvisibility(val* self) {
-val* var /* : MVisibility */;
-const char* var_class_name;
-var_class_name = self == NULL ? "null" : self->type->name;
-fprintf(stderr, "Runtime error: Abstract method `%s` called on `%s`", "mvisibility", var_class_name);
-fprintf(stderr, " (%s:%d)\n", "src/modelbuilder.nit", 510);
-exit(1);
-RET_LABEL:;
-return var;
-}
-/* method modelbuilder#AVisibility#mvisibility for (self: Object): MVisibility */
-val* VIRTUAL_modelbuilder__AVisibility__mvisibility(val* self) {
-val* var /* : MVisibility */;
-val* var1 /* : MVisibility */;
-var1 = modelbuilder__AVisibility__mvisibility(self);
-var = var1;
-RET_LABEL:;
-return var;
-}
-/* method modelbuilder#AIntrudeVisibility#mvisibility for (self: AIntrudeVisibility): MVisibility */
-val* modelbuilder__AIntrudeVisibility__mvisibility(val* self) {
-val* var /* : MVisibility */;
-val* var1 /* : MVisibility */;
-var1 = ((val* (*)(val*))(self->class->vft[COLOR_model_base__Object__intrude_visibility]))(self) /* intrude_visibility on <self:AIntrudeVisibility>*/;
-var = var1;
-goto RET_LABEL;
-RET_LABEL:;
-return var;
-}
-/* method modelbuilder#AIntrudeVisibility#mvisibility for (self: Object): MVisibility */
-val* VIRTUAL_modelbuilder__AIntrudeVisibility__mvisibility(val* self) {
-val* var /* : MVisibility */;
-val* var1 /* : MVisibility */;
-var1 = modelbuilder__AIntrudeVisibility__mvisibility(self);
-var = var1;
-RET_LABEL:;
-return var;
-}
-/* method modelbuilder#APublicVisibility#mvisibility for (self: APublicVisibility): MVisibility */
-val* modelbuilder__APublicVisibility__mvisibility(val* self) {
-val* var /* : MVisibility */;
-val* var1 /* : MVisibility */;
-var1 = ((val* (*)(val*))(self->class->vft[COLOR_model_base__Object__public_visibility]))(self) /* public_visibility on <self:APublicVisibility>*/;
-var = var1;
-goto RET_LABEL;
-RET_LABEL:;
-return var;
-}
-/* method modelbuilder#APublicVisibility#mvisibility for (self: Object): MVisibility */
-val* VIRTUAL_modelbuilder__APublicVisibility__mvisibility(val* self) {
-val* var /* : MVisibility */;
-val* var1 /* : MVisibility */;
-var1 = modelbuilder__APublicVisibility__mvisibility(self);
-var = var1;
-RET_LABEL:;
-return var;
-}
-/* method modelbuilder#AProtectedVisibility#mvisibility for (self: AProtectedVisibility): MVisibility */
-val* modelbuilder__AProtectedVisibility__mvisibility(val* self) {
-val* var /* : MVisibility */;
-val* var1 /* : MVisibility */;
-var1 = ((val* (*)(val*))(self->class->vft[COLOR_model_base__Object__protected_visibility]))(self) /* protected_visibility on <self:AProtectedVisibility>*/;
-var = var1;
-goto RET_LABEL;
-RET_LABEL:;
-return var;
-}
-/* method modelbuilder#AProtectedVisibility#mvisibility for (self: Object): MVisibility */
-val* VIRTUAL_modelbuilder__AProtectedVisibility__mvisibility(val* self) {
-val* var /* : MVisibility */;
-val* var1 /* : MVisibility */;
-var1 = modelbuilder__AProtectedVisibility__mvisibility(self);
-var = var1;
-RET_LABEL:;
-return var;
-}
-/* method modelbuilder#APrivateVisibility#mvisibility for (self: APrivateVisibility): MVisibility */
-val* modelbuilder__APrivateVisibility__mvisibility(val* self) {
-val* var /* : MVisibility */;
-val* var1 /* : MVisibility */;
-var1 = ((val* (*)(val*))(self->class->vft[COLOR_model_base__Object__private_visibility]))(self) /* private_visibility on <self:APrivateVisibility>*/;
-var = var1;
-goto RET_LABEL;
-RET_LABEL:;
-return var;
-}
-/* method modelbuilder#APrivateVisibility#mvisibility for (self: Object): MVisibility */
-val* VIRTUAL_modelbuilder__APrivateVisibility__mvisibility(val* self) {
-val* var /* : MVisibility */;
-val* var1 /* : MVisibility */;
-var1 = modelbuilder__APrivateVisibility__mvisibility(self);
-var = var1;
-RET_LABEL:;
-return var;
-}