c_src: update with new intern methods
[nit.git] / c_src / separate_compiler.sep.2.c
index 402b281..8d5f525 100644 (file)
@@ -1,607 +1,4 @@
 #include "separate_compiler.sep.0.h"
-/* method separate_compiler#SeparateCompilerVisitor#autobox for (self: SeparateCompilerVisitor, RuntimeVariable, MType): RuntimeVariable */
-val* separate_compiler__SeparateCompilerVisitor__autobox(val* self, val* p0, val* p1) {
-val* var /* : RuntimeVariable */;
-val* var_value /* var value: RuntimeVariable */;
-val* var_mtype /* var mtype: MType */;
-val* var1 /* : MType */;
-short int var2 /* : Bool */;
-short int var3 /* : Bool */;
-val* var4 /* : MType */;
-val* var5 /* : String */;
-static val* varonce;
-val* var6 /* : String */;
-char* var7 /* : NativeString */;
-long var8 /* : Int */;
-val* var9 /* : String */;
-short int var10 /* : Bool */;
-short int var_ /* var : Bool */;
-val* var11 /* : String */;
-static val* varonce12;
-val* var13 /* : String */;
-char* var14 /* : NativeString */;
-long var15 /* : Int */;
-val* var16 /* : String */;
-short int var17 /* : Bool */;
-val* var18 /* : MType */;
-val* var19 /* : String */;
-static val* varonce20;
-val* var21 /* : String */;
-char* var22 /* : NativeString */;
-long var23 /* : Int */;
-val* var24 /* : String */;
-short int var25 /* : Bool */;
-static val* varonce26;
-val* var27 /* : String */;
-char* var28 /* : NativeString */;
-long var29 /* : Int */;
-val* var30 /* : String */;
-val* var31 /* : String */;
-static val* varonce32;
-val* var33 /* : String */;
-char* var34 /* : NativeString */;
-long var35 /* : Int */;
-val* var36 /* : String */;
-static val* varonce37;
-val* var38 /* : String */;
-char* var39 /* : NativeString */;
-long var40 /* : Int */;
-val* var41 /* : String */;
-val* var42 /* : MType */;
-static val* varonce43;
-val* var44 /* : String */;
-char* var45 /* : NativeString */;
-long var46 /* : Int */;
-val* var47 /* : String */;
-static val* varonce48;
-val* var49 /* : String */;
-char* var50 /* : NativeString */;
-long var51 /* : Int */;
-val* var52 /* : String */;
-val* var53 /* : Array[Object] */;
-long var54 /* : Int */;
-val* var55 /* : NativeArray[Object] */;
-val* var56 /* : String */;
-val* var57 /* : RuntimeVariable */;
-val* var58 /* : String */;
-static val* varonce59;
-val* var60 /* : String */;
-char* var61 /* : NativeString */;
-long var62 /* : Int */;
-val* var63 /* : String */;
-short int var64 /* : Bool */;
-val* var65 /* : MType */;
-short int var66 /* : Bool */;
-int cltype;
-int idtype;
-const char* var_class_name;
-val* var_valtype /* var valtype: MClassType */;
-val* var67 /* : RuntimeVariable */;
-val* var_res /* var res: RuntimeVariable */;
-val* var68 /* : AbstractCompiler */;
-val* var69 /* : RapidTypeAnalysis */;
-val* var70 /* : HashSet[MClassType] */;
-short int var71 /* : Bool */;
-short int var72 /* : Bool */;
-static val* varonce73;
-val* var74 /* : String */;
-char* var75 /* : NativeString */;
-long var76 /* : Int */;
-val* var77 /* : String */;
-val* var78 /* : MType */;
-static val* varonce79;
-val* var80 /* : String */;
-char* var81 /* : NativeString */;
-long var82 /* : Int */;
-val* var83 /* : String */;
-static val* varonce84;
-val* var85 /* : String */;
-char* var86 /* : NativeString */;
-long var87 /* : Int */;
-val* var88 /* : String */;
-val* var89 /* : MType */;
-static val* varonce90;
-val* var91 /* : String */;
-char* var92 /* : NativeString */;
-long var93 /* : Int */;
-val* var94 /* : String */;
-val* var95 /* : Array[Object] */;
-long var96 /* : Int */;
-val* var97 /* : NativeArray[Object] */;
-val* var98 /* : String */;
-static val* varonce99;
-val* var100 /* : String */;
-char* var101 /* : NativeString */;
-long var102 /* : Int */;
-val* var103 /* : String */;
-static val* varonce104;
-val* var105 /* : String */;
-char* var106 /* : NativeString */;
-long var107 /* : Int */;
-val* var108 /* : String */;
-val* var109 /* : String */;
-static val* varonce110;
-val* var111 /* : String */;
-char* var112 /* : NativeString */;
-long var113 /* : Int */;
-val* var114 /* : String */;
-static val* varonce115;
-val* var116 /* : String */;
-char* var117 /* : NativeString */;
-long var118 /* : Int */;
-val* var119 /* : String */;
-val* var120 /* : MType */;
-static val* varonce121;
-val* var122 /* : String */;
-char* var123 /* : NativeString */;
-long var124 /* : Int */;
-val* var125 /* : String */;
-static val* varonce126;
-val* var127 /* : String */;
-char* var128 /* : NativeString */;
-long var129 /* : Int */;
-val* var130 /* : String */;
-val* var131 /* : Array[Object] */;
-long var132 /* : Int */;
-val* var133 /* : NativeArray[Object] */;
-val* var134 /* : String */;
-val* var135 /* : RuntimeVariable */;
-val* var_res136 /* var res: RuntimeVariable */;
-static val* varonce137;
-val* var138 /* : String */;
-char* var139 /* : NativeString */;
-long var140 /* : Int */;
-val* var141 /* : String */;
-static val* varonce142;
-val* var143 /* : String */;
-char* var144 /* : NativeString */;
-long var145 /* : Int */;
-val* var146 /* : String */;
-val* var147 /* : MType */;
-static val* varonce148;
-val* var149 /* : String */;
-char* var150 /* : NativeString */;
-long var151 /* : Int */;
-val* var152 /* : String */;
-static val* varonce153;
-val* var154 /* : String */;
-char* var155 /* : NativeString */;
-long var156 /* : Int */;
-val* var157 /* : String */;
-val* var158 /* : Array[Object] */;
-long var159 /* : Int */;
-val* var160 /* : NativeArray[Object] */;
-val* var161 /* : String */;
-static val* varonce162;
-val* var163 /* : String */;
-char* var164 /* : NativeString */;
-long var165 /* : Int */;
-val* var166 /* : String */;
-val* var167 /* : MType */;
-static val* varonce168;
-val* var169 /* : String */;
-char* var170 /* : NativeString */;
-long var171 /* : Int */;
-val* var172 /* : String */;
-static val* varonce173;
-val* var174 /* : String */;
-char* var175 /* : NativeString */;
-long var176 /* : Int */;
-val* var177 /* : String */;
-val* var178 /* : Array[Object] */;
-long var179 /* : Int */;
-val* var180 /* : NativeArray[Object] */;
-val* var181 /* : String */;
-var_value = p0;
-var_mtype = p1;
-var1 = ((val* (*)(val*))(var_value->class->vft[COLOR_abstract_compiler__RuntimeVariable__mtype]))(var_value) /* mtype on <var_value:RuntimeVariable>*/;
-var2 = ((short int (*)(val*, val*))(var1->class->vft[COLOR_kernel__Object___61d_61d]))(var1, var_mtype) /* == on <var1:MType>*/;
-if (var2){
-var = var_value;
-goto RET_LABEL;
-} else {
-var4 = ((val* (*)(val*))(var_value->class->vft[COLOR_abstract_compiler__RuntimeVariable__mtype]))(var_value) /* mtype on <var_value:RuntimeVariable>*/;
-var5 = ((val* (*)(val*))(var4->class->vft[COLOR_abstract_compiler__MType__ctype]))(var4) /* ctype on <var4:MType>*/;
-if (varonce) {
-var6 = varonce;
-} else {
-var7 = "val*";
-var8 = 4;
-var9 = string__NativeString__to_s_with_length(var7, var8);
-var6 = var9;
-varonce = var6;
-}
-var10 = ((short int (*)(val*, val*))(var5->class->vft[COLOR_kernel__Object___61d_61d]))(var5, var6) /* == on <var5:String>*/;
-var_ = var10;
-if (var10){
-var11 = ((val* (*)(val*))(var_mtype->class->vft[COLOR_abstract_compiler__MType__ctype]))(var_mtype) /* ctype on <var_mtype:MType>*/;
-if (varonce12) {
-var13 = varonce12;
-} else {
-var14 = "val*";
-var15 = 4;
-var16 = string__NativeString__to_s_with_length(var14, var15);
-var13 = var16;
-varonce12 = var13;
-}
-var17 = ((short int (*)(val*, val*))(var11->class->vft[COLOR_kernel__Object___61d_61d]))(var11, var13) /* == on <var11:String>*/;
-var3 = var17;
-} else {
-var3 = var_;
-}
-if (var3){
-var = var_value;
-goto RET_LABEL;
-} else {
-var18 = ((val* (*)(val*))(var_value->class->vft[COLOR_abstract_compiler__RuntimeVariable__mtype]))(var_value) /* mtype on <var_value:RuntimeVariable>*/;
-var19 = ((val* (*)(val*))(var18->class->vft[COLOR_abstract_compiler__MType__ctype]))(var18) /* ctype on <var18:MType>*/;
-if (varonce20) {
-var21 = varonce20;
-} else {
-var22 = "val*";
-var23 = 4;
-var24 = string__NativeString__to_s_with_length(var22, var23);
-var21 = var24;
-varonce20 = var21;
-}
-var25 = ((short int (*)(val*, val*))(var19->class->vft[COLOR_kernel__Object___61d_61d]))(var19, var21) /* == on <var19:String>*/;
-if (var25){
-if (varonce26) {
-var27 = varonce26;
-} else {
-var28 = "((struct instance_";
-var29 = 18;
-var30 = string__NativeString__to_s_with_length(var28, var29);
-var27 = var30;
-varonce26 = var27;
-}
-var31 = ((val* (*)(val*))(var_mtype->class->vft[COLOR_abstract_compiler__MType__c_name]))(var_mtype) /* c_name on <var_mtype:MType>*/;
-if (varonce32) {
-var33 = varonce32;
-} else {
-var34 = "*)";
-var35 = 2;
-var36 = string__NativeString__to_s_with_length(var34, var35);
-var33 = var36;
-varonce32 = var33;
-}
-if (varonce37) {
-var38 = varonce37;
-} else {
-var39 = ")->value; /* autounbox from ";
-var40 = 28;
-var41 = string__NativeString__to_s_with_length(var39, var40);
-var38 = var41;
-varonce37 = var38;
-}
-var42 = ((val* (*)(val*))(var_value->class->vft[COLOR_abstract_compiler__RuntimeVariable__mtype]))(var_value) /* mtype on <var_value:RuntimeVariable>*/;
-if (varonce43) {
-var44 = varonce43;
-} else {
-var45 = " to ";
-var46 = 4;
-var47 = string__NativeString__to_s_with_length(var45, var46);
-var44 = var47;
-varonce43 = var44;
-}
-if (varonce48) {
-var49 = varonce48;
-} else {
-var50 = " */";
-var51 = 3;
-var52 = string__NativeString__to_s_with_length(var50, var51);
-var49 = var52;
-varonce48 = var49;
-}
-var53 = NEW_array__Array(&type_array__Arraykernel__Object);
-{ /* var53 = array_instance Array[Object] */
-var54 = 9;
-var55 = NEW_array__NativeArray(var54, &type_array__NativeArraykernel__Object);
-((struct instance_array__NativeArray*)var55)->values[0] = (val*) var27;
-((struct instance_array__NativeArray*)var55)->values[1] = (val*) var31;
-((struct instance_array__NativeArray*)var55)->values[2] = (val*) var33;
-((struct instance_array__NativeArray*)var55)->values[3] = (val*) var_value;
-((struct instance_array__NativeArray*)var55)->values[4] = (val*) var38;
-((struct instance_array__NativeArray*)var55)->values[5] = (val*) var42;
-((struct instance_array__NativeArray*)var55)->values[6] = (val*) var44;
-((struct instance_array__NativeArray*)var55)->values[7] = (val*) var_mtype;
-((struct instance_array__NativeArray*)var55)->values[8] = (val*) var49;
-((void (*)(val*, val*, long))(var53->class->vft[COLOR_array__Array__with_native]))(var53, var55, var54) /* with_native on <var53:Array[Object]>*/;
-CHECK_NEW_array__Array(var53);
-}
-var56 = ((val* (*)(val*))(var53->class->vft[COLOR_string__Object__to_s]))(var53) /* to_s on <var53:Array[Object]>*/;
-var57 = ((val* (*)(val*, val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__new_expr]))(self, var56, var_mtype) /* new_expr on <self:SeparateCompilerVisitor>*/;
-var = var57;
-goto RET_LABEL;
-} else {
-var58 = ((val* (*)(val*))(var_mtype->class->vft[COLOR_abstract_compiler__MType__ctype]))(var_mtype) /* ctype on <var_mtype:MType>*/;
-if (varonce59) {
-var60 = varonce59;
-} else {
-var61 = "val*";
-var62 = 4;
-var63 = string__NativeString__to_s_with_length(var61, var62);
-var60 = var63;
-varonce59 = var60;
-}
-var64 = ((short int (*)(val*, val*))(var58->class->vft[COLOR_kernel__Object___61d_61d]))(var58, var60) /* == on <var58:String>*/;
-if (var64){
-var65 = ((val* (*)(val*))(var_value->class->vft[COLOR_abstract_compiler__RuntimeVariable__mtype]))(var_value) /* mtype on <var_value:RuntimeVariable>*/;
-/* <var65:MType> isa MClassType */
-cltype = type_model__MClassType.color;
-idtype = type_model__MClassType.id;
-if(cltype >= var65->type->table_size) {
-var66 = 0;
-} else {
-var66 = var65->type->type_table[cltype] == idtype;
-}
-if (!var66) {
-var_class_name = var65 == NULL ? "null" : var65->type->name;
-fprintf(stderr, "Runtime error: Cast failed. Expected `%s`, got `%s`", "MClassType", var_class_name);
-fprintf(stderr, " (%s:%d)\n", "src/separate_compiler.nit", 944);
-exit(1);
-}
-var_valtype = var65;
-var67 = ((val* (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__new_var]))(self, var_mtype) /* new_var on <self:SeparateCompilerVisitor>*/;
-var_res = var67;
-var68 = ((val* (*)(val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__compiler]))(self) /* compiler on <self:SeparateCompilerVisitor>*/;
-var69 = ((val* (*)(val*))(var68->class->vft[COLOR_separate_compiler__SeparateCompiler__runtime_type_analysis]))(var68) /* runtime_type_analysis on <var68:AbstractCompiler(SeparateCompiler)>*/;
-var70 = ((val* (*)(val*))(var69->class->vft[COLOR_rapid_type_analysis__RapidTypeAnalysis__live_types]))(var69) /* live_types on <var69:RapidTypeAnalysis>*/;
-var71 = ((short int (*)(val*, val*))(var70->class->vft[COLOR_abstract_collection__Collection__has]))(var70, var_valtype) /* has on <var70:HashSet[MClassType]>*/;
-var72 = !var71;
-if (var72){
-if (varonce73) {
-var74 = varonce73;
-} else {
-var75 = "/*no autobox from ";
-var76 = 18;
-var77 = string__NativeString__to_s_with_length(var75, var76);
-var74 = var77;
-varonce73 = var74;
-}
-var78 = ((val* (*)(val*))(var_value->class->vft[COLOR_abstract_compiler__RuntimeVariable__mtype]))(var_value) /* mtype on <var_value:RuntimeVariable>*/;
-if (varonce79) {
-var80 = varonce79;
-} else {
-var81 = " to ";
-var82 = 4;
-var83 = string__NativeString__to_s_with_length(var81, var82);
-var80 = var83;
-varonce79 = var80;
-}
-if (varonce84) {
-var85 = varonce84;
-} else {
-var86 = ": ";
-var87 = 2;
-var88 = string__NativeString__to_s_with_length(var86, var87);
-var85 = var88;
-varonce84 = var85;
-}
-var89 = ((val* (*)(val*))(var_value->class->vft[COLOR_abstract_compiler__RuntimeVariable__mtype]))(var_value) /* mtype on <var_value:RuntimeVariable>*/;
-if (varonce90) {
-var91 = varonce90;
-} else {
-var92 = " is not live! */";
-var93 = 16;
-var94 = string__NativeString__to_s_with_length(var92, var93);
-var91 = var94;
-varonce90 = var91;
-}
-var95 = NEW_array__Array(&type_array__Arraykernel__Object);
-{ /* var95 = array_instance Array[Object] */
-var96 = 7;
-var97 = NEW_array__NativeArray(var96, &type_array__NativeArraykernel__Object);
-((struct instance_array__NativeArray*)var97)->values[0] = (val*) var74;
-((struct instance_array__NativeArray*)var97)->values[1] = (val*) var78;
-((struct instance_array__NativeArray*)var97)->values[2] = (val*) var80;
-((struct instance_array__NativeArray*)var97)->values[3] = (val*) var_mtype;
-((struct instance_array__NativeArray*)var97)->values[4] = (val*) var85;
-((struct instance_array__NativeArray*)var97)->values[5] = (val*) var89;
-((struct instance_array__NativeArray*)var97)->values[6] = (val*) var91;
-((void (*)(val*, val*, long))(var95->class->vft[COLOR_array__Array__with_native]))(var95, var97, var96) /* with_native on <var95:Array[Object]>*/;
-CHECK_NEW_array__Array(var95);
-}
-var98 = ((val* (*)(val*))(var95->class->vft[COLOR_string__Object__to_s]))(var95) /* to_s on <var95:Array[Object]>*/;
-((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var98) /* add on <self:SeparateCompilerVisitor>*/;
-if (varonce99) {
-var100 = varonce99;
-} else {
-var101 = "printf(\"Dead code executed!\\n\"); exit(1);";
-var102 = 41;
-var103 = string__NativeString__to_s_with_length(var101, var102);
-var100 = var103;
-varonce99 = var100;
-}
-((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var100) /* add on <self:SeparateCompilerVisitor>*/;
-var = var_res;
-goto RET_LABEL;
-} else {
-}
-if (varonce104) {
-var105 = varonce104;
-} else {
-var106 = " = BOX_";
-var107 = 7;
-var108 = string__NativeString__to_s_with_length(var106, var107);
-var105 = var108;
-varonce104 = var105;
-}
-var109 = ((val* (*)(val*))(var_valtype->class->vft[COLOR_abstract_compiler__MType__c_name]))(var_valtype) /* c_name on <var_valtype:MClassType>*/;
-if (varonce110) {
-var111 = varonce110;
-} else {
-var112 = "(";
-var113 = 1;
-var114 = string__NativeString__to_s_with_length(var112, var113);
-var111 = var114;
-varonce110 = var111;
-}
-if (varonce115) {
-var116 = varonce115;
-} else {
-var117 = "); /* autobox from ";
-var118 = 19;
-var119 = string__NativeString__to_s_with_length(var117, var118);
-var116 = var119;
-varonce115 = var116;
-}
-var120 = ((val* (*)(val*))(var_value->class->vft[COLOR_abstract_compiler__RuntimeVariable__mtype]))(var_value) /* mtype on <var_value:RuntimeVariable>*/;
-if (varonce121) {
-var122 = varonce121;
-} else {
-var123 = " to ";
-var124 = 4;
-var125 = string__NativeString__to_s_with_length(var123, var124);
-var122 = var125;
-varonce121 = var122;
-}
-if (varonce126) {
-var127 = varonce126;
-} else {
-var128 = " */";
-var129 = 3;
-var130 = string__NativeString__to_s_with_length(var128, var129);
-var127 = var130;
-varonce126 = var127;
-}
-var131 = NEW_array__Array(&type_array__Arraykernel__Object);
-{ /* var131 = array_instance Array[Object] */
-var132 = 10;
-var133 = NEW_array__NativeArray(var132, &type_array__NativeArraykernel__Object);
-((struct instance_array__NativeArray*)var133)->values[0] = (val*) var_res;
-((struct instance_array__NativeArray*)var133)->values[1] = (val*) var105;
-((struct instance_array__NativeArray*)var133)->values[2] = (val*) var109;
-((struct instance_array__NativeArray*)var133)->values[3] = (val*) var111;
-((struct instance_array__NativeArray*)var133)->values[4] = (val*) var_value;
-((struct instance_array__NativeArray*)var133)->values[5] = (val*) var116;
-((struct instance_array__NativeArray*)var133)->values[6] = (val*) var120;
-((struct instance_array__NativeArray*)var133)->values[7] = (val*) var122;
-((struct instance_array__NativeArray*)var133)->values[8] = (val*) var_mtype;
-((struct instance_array__NativeArray*)var133)->values[9] = (val*) var127;
-((void (*)(val*, val*, long))(var131->class->vft[COLOR_array__Array__with_native]))(var131, var133, var132) /* with_native on <var131:Array[Object]>*/;
-CHECK_NEW_array__Array(var131);
-}
-var134 = ((val* (*)(val*))(var131->class->vft[COLOR_string__Object__to_s]))(var131) /* to_s on <var131:Array[Object]>*/;
-((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var134) /* add on <self:SeparateCompilerVisitor>*/;
-var = var_res;
-goto RET_LABEL;
-} else {
-var135 = ((val* (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__new_var]))(self, var_mtype) /* new_var on <self:SeparateCompilerVisitor>*/;
-var_res136 = var135;
-if (varonce137) {
-var138 = varonce137;
-} else {
-var139 = "/* ";
-var140 = 3;
-var141 = string__NativeString__to_s_with_length(var139, var140);
-var138 = var141;
-varonce137 = var138;
-}
-if (varonce142) {
-var143 = varonce142;
-} else {
-var144 = " left unintialized (cannot convert ";
-var145 = 35;
-var146 = string__NativeString__to_s_with_length(var144, var145);
-var143 = var146;
-varonce142 = var143;
-}
-var147 = ((val* (*)(val*))(var_value->class->vft[COLOR_abstract_compiler__RuntimeVariable__mtype]))(var_value) /* mtype on <var_value:RuntimeVariable>*/;
-if (varonce148) {
-var149 = varonce148;
-} else {
-var150 = " to ";
-var151 = 4;
-var152 = string__NativeString__to_s_with_length(var150, var151);
-var149 = var152;
-varonce148 = var149;
-}
-if (varonce153) {
-var154 = varonce153;
-} else {
-var155 = ") */";
-var156 = 4;
-var157 = string__NativeString__to_s_with_length(var155, var156);
-var154 = var157;
-varonce153 = var154;
-}
-var158 = NEW_array__Array(&type_array__Arraykernel__Object);
-{ /* var158 = array_instance Array[Object] */
-var159 = 7;
-var160 = NEW_array__NativeArray(var159, &type_array__NativeArraykernel__Object);
-((struct instance_array__NativeArray*)var160)->values[0] = (val*) var138;
-((struct instance_array__NativeArray*)var160)->values[1] = (val*) var_res136;
-((struct instance_array__NativeArray*)var160)->values[2] = (val*) var143;
-((struct instance_array__NativeArray*)var160)->values[3] = (val*) var147;
-((struct instance_array__NativeArray*)var160)->values[4] = (val*) var149;
-((struct instance_array__NativeArray*)var160)->values[5] = (val*) var_mtype;
-((struct instance_array__NativeArray*)var160)->values[6] = (val*) var154;
-((void (*)(val*, val*, long))(var158->class->vft[COLOR_array__Array__with_native]))(var158, var160, var159) /* with_native on <var158:Array[Object]>*/;
-CHECK_NEW_array__Array(var158);
-}
-var161 = ((val* (*)(val*))(var158->class->vft[COLOR_string__Object__to_s]))(var158) /* to_s on <var158:Array[Object]>*/;
-((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var161) /* add on <self:SeparateCompilerVisitor>*/;
-if (varonce162) {
-var163 = varonce162;
-} else {
-var164 = "printf(\"Cast error: Cannot cast %s to %s.\\n\", \"";
-var165 = 47;
-var166 = string__NativeString__to_s_with_length(var164, var165);
-var163 = var166;
-varonce162 = var163;
-}
-var167 = ((val* (*)(val*))(var_value->class->vft[COLOR_abstract_compiler__RuntimeVariable__mtype]))(var_value) /* mtype on <var_value:RuntimeVariable>*/;
-if (varonce168) {
-var169 = varonce168;
-} else {
-var170 = "\", \"";
-var171 = 4;
-var172 = string__NativeString__to_s_with_length(var170, var171);
-var169 = var172;
-varonce168 = var169;
-}
-if (varonce173) {
-var174 = varonce173;
-} else {
-var175 = "\"); exit(1);";
-var176 = 12;
-var177 = string__NativeString__to_s_with_length(var175, var176);
-var174 = var177;
-varonce173 = var174;
-}
-var178 = NEW_array__Array(&type_array__Arraykernel__Object);
-{ /* var178 = array_instance Array[Object] */
-var179 = 5;
-var180 = NEW_array__NativeArray(var179, &type_array__NativeArraykernel__Object);
-((struct instance_array__NativeArray*)var180)->values[0] = (val*) var163;
-((struct instance_array__NativeArray*)var180)->values[1] = (val*) var167;
-((struct instance_array__NativeArray*)var180)->values[2] = (val*) var169;
-((struct instance_array__NativeArray*)var180)->values[3] = (val*) var_mtype;
-((struct instance_array__NativeArray*)var180)->values[4] = (val*) var174;
-((void (*)(val*, val*, long))(var178->class->vft[COLOR_array__Array__with_native]))(var178, var180, var179) /* with_native on <var178:Array[Object]>*/;
-CHECK_NEW_array__Array(var178);
-}
-var181 = ((val* (*)(val*))(var178->class->vft[COLOR_string__Object__to_s]))(var178) /* to_s on <var178:Array[Object]>*/;
-((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var181) /* add on <self:SeparateCompilerVisitor>*/;
-var = var_res136;
-goto RET_LABEL;
-}
-}
-}
-}
-RET_LABEL:;
-return var;
-}
-/* method separate_compiler#SeparateCompilerVisitor#autobox for (self: Object, RuntimeVariable, MType): RuntimeVariable */
-val* VIRTUAL_separate_compiler__SeparateCompilerVisitor__autobox(val* self, val* p0, val* p1) {
-val* var /* : RuntimeVariable */;
-val* var1 /* : RuntimeVariable */;
-var1 = separate_compiler__SeparateCompilerVisitor__autobox(self, p0, p1);
-var = var1;
-RET_LABEL:;
-return var;
-}
 /* method separate_compiler#SeparateCompilerVisitor#type_info for (self: SeparateCompilerVisitor, RuntimeVariable): String */
 val* separate_compiler__SeparateCompilerVisitor__type_info(val* self, val* p0) {
 val* var /* : String */;
@@ -628,33 +25,36 @@ char* var17 /* : NativeString */;
 long var18 /* : Int */;
 val* var19 /* : String */;
 val* var20 /* : String */;
-static val* varonce21;
-val* var22 /* : String */;
-char* var23 /* : NativeString */;
-long var24 /* : Int */;
+val* var21 /* : AbstractCompiler */;
+val* var22 /* : Set[MType] */;
+val* var23 /* : MType */;
+static val* varonce24;
 val* var25 /* : String */;
-val* var26 /* : MType */;
-val* var27 /* : String */;
-val* var28 /* : Array[Object] */;
-long var29 /* : Int */;
-val* var30 /* : NativeArray[Object] */;
-val* var31 /* : String */;
-val* var32 /* : Array[Object] */;
-long var33 /* : Int */;
-val* var_34 /* var : Array[Object] */;
-static val* varonce35;
-val* var36 /* : String */;
-char* var37 /* : NativeString */;
-long var38 /* : Int */;
+char* var26 /* : NativeString */;
+long var27 /* : Int */;
+val* var28 /* : String */;
+val* var29 /* : MType */;
+val* var30 /* : String */;
+val* var31 /* : Array[Object] */;
+long var32 /* : Int */;
+val* var33 /* : NativeArray[Object] */;
+val* var34 /* : String */;
+val* var35 /* : Array[Object] */;
+long var36 /* : Int */;
+val* var_37 /* var : Array[Object] */;
+static val* varonce38;
 val* var39 /* : String */;
-val* var40 /* : MType */;
-val* var41 /* : String */;
-static val* varonce42;
-val* var43 /* : String */;
-char* var44 /* : NativeString */;
-long var45 /* : Int */;
+char* var40 /* : NativeString */;
+long var41 /* : Int */;
+val* var42 /* : String */;
+val* var43 /* : MType */;
+val* var44 /* : String */;
+static val* varonce45;
 val* var46 /* : String */;
-val* var47 /* : String */;
+char* var47 /* : NativeString */;
+long var48 /* : Int */;
+val* var49 /* : String */;
+val* var50 /* : String */;
 var_value = p0;
 var1 = ((val* (*)(val*))(var_value->class->vft[COLOR_abstract_compiler__RuntimeVariable__mtype]))(var_value) /* mtype on <var_value:RuntimeVariable>*/;
 var2 = ((val* (*)(val*))(var1->class->vft[COLOR_abstract_compiler__MType__ctype]))(var1) /* ctype on <var1:MType>*/;
@@ -672,7 +72,6 @@ if (var7){
 var8 = NEW_array__Array(&type_array__Arraykernel__Object);
 var9 = 3;
 ((void (*)(val*, long))(var8->class->vft[COLOR_array__Array__with_capacity]))(var8, var9) /* with_capacity on <var8:Array[Object]>*/;
-CHECK_NEW_array__Array(var8);
 var_ = var8;
 if (varonce10) {
 var11 = varonce10;
@@ -699,58 +98,60 @@ var20 = ((val* (*)(val*))(var_->class->vft[COLOR_string__Object__to_s]))(var_) /
 var = var20;
 goto RET_LABEL;
 } else {
-if (varonce21) {
-var22 = varonce21;
-} else {
-var23 = "type_";
-var24 = 5;
-var25 = string__NativeString__to_s_with_length(var23, var24);
-var22 = var25;
-varonce21 = var22;
-}
-var26 = ((val* (*)(val*))(var_value->class->vft[COLOR_abstract_compiler__RuntimeVariable__mtype]))(var_value) /* mtype on <var_value:RuntimeVariable>*/;
-var27 = ((val* (*)(val*))(var26->class->vft[COLOR_abstract_compiler__MType__c_name]))(var26) /* c_name on <var26:MType>*/;
-var28 = NEW_array__Array(&type_array__Arraykernel__Object);
-{ /* var28 = array_instance Array[Object] */
-var29 = 2;
-var30 = NEW_array__NativeArray(var29, &type_array__NativeArraykernel__Object);
-((struct instance_array__NativeArray*)var30)->values[0] = (val*) var22;
-((struct instance_array__NativeArray*)var30)->values[1] = (val*) var27;
-((void (*)(val*, val*, long))(var28->class->vft[COLOR_array__Array__with_native]))(var28, var30, var29) /* with_native on <var28:Array[Object]>*/;
-CHECK_NEW_array__Array(var28);
-}
-var31 = ((val* (*)(val*))(var28->class->vft[COLOR_string__Object__to_s]))(var28) /* to_s on <var28:Array[Object]>*/;
-((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__require_declaration]))(self, var31) /* require_declaration on <self:SeparateCompilerVisitor>*/;
-var32 = NEW_array__Array(&type_array__Arraykernel__Object);
-var33 = 3;
-((void (*)(val*, long))(var32->class->vft[COLOR_array__Array__with_capacity]))(var32, var33) /* with_capacity on <var32:Array[Object]>*/;
-CHECK_NEW_array__Array(var32);
-var_34 = var32;
-if (varonce35) {
-var36 = varonce35;
+var21 = ((val* (*)(val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__compiler]))(self) /* compiler on <self:SeparateCompilerVisitor>*/;
+var22 = ((val* (*)(val*))(var21->class->vft[COLOR_separate_compiler__SeparateCompiler__undead_types]))(var21) /* undead_types on <var21:AbstractCompiler(SeparateCompiler)>*/;
+var23 = ((val* (*)(val*))(var_value->class->vft[COLOR_abstract_compiler__RuntimeVariable__mtype]))(var_value) /* mtype on <var_value:RuntimeVariable>*/;
+((void (*)(val*, val*))(var22->class->vft[COLOR_abstract_collection__SimpleCollection__add]))(var22, var23) /* add on <var22:Set[MType]>*/;
+if (varonce24) {
+var25 = varonce24;
 } else {
-var37 = "(&type_";
-var38 = 7;
-var39 = string__NativeString__to_s_with_length(var37, var38);
-var36 = var39;
-varonce35 = var36;
+var26 = "type_";
+var27 = 5;
+var28 = string__NativeString__to_s_with_length(var26, var27);
+var25 = var28;
+varonce24 = var25;
 }
-((void (*)(val*, val*))(var_34->class->vft[COLOR_abstract_collection__SimpleCollection__add]))(var_34, var36) /* add on <var_34:Array[Object]>*/;
-var40 = ((val* (*)(val*))(var_value->class->vft[COLOR_abstract_compiler__RuntimeVariable__mtype]))(var_value) /* mtype on <var_value:RuntimeVariable>*/;
-var41 = ((val* (*)(val*))(var40->class->vft[COLOR_abstract_compiler__MType__c_name]))(var40) /* c_name on <var40:MType>*/;
-((void (*)(val*, val*))(var_34->class->vft[COLOR_abstract_collection__SimpleCollection__add]))(var_34, var41) /* add on <var_34:Array[Object]>*/;
-if (varonce42) {
-var43 = varonce42;
+var29 = ((val* (*)(val*))(var_value->class->vft[COLOR_abstract_compiler__RuntimeVariable__mtype]))(var_value) /* mtype on <var_value:RuntimeVariable>*/;
+var30 = ((val* (*)(val*))(var29->class->vft[COLOR_abstract_compiler__MType__c_name]))(var29) /* c_name on <var29:MType>*/;
+var31 = NEW_array__Array(&type_array__Arraykernel__Object);
+{ /* var31 = array_instance Array[Object] */
+var32 = 2;
+var33 = NEW_array__NativeArray(var32, &type_array__NativeArraykernel__Object);
+((struct instance_array__NativeArray*)var33)->values[0] = (val*) var25;
+((struct instance_array__NativeArray*)var33)->values[1] = (val*) var30;
+((void (*)(val*, val*, long))(var31->class->vft[COLOR_array__Array__with_native]))(var31, var33, var32) /* with_native on <var31:Array[Object]>*/;
+}
+var34 = ((val* (*)(val*))(var31->class->vft[COLOR_string__Object__to_s]))(var31) /* to_s on <var31:Array[Object]>*/;
+((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__require_declaration]))(self, var34) /* require_declaration on <self:SeparateCompilerVisitor>*/;
+var35 = NEW_array__Array(&type_array__Arraykernel__Object);
+var36 = 3;
+((void (*)(val*, long))(var35->class->vft[COLOR_array__Array__with_capacity]))(var35, var36) /* with_capacity on <var35:Array[Object]>*/;
+var_37 = var35;
+if (varonce38) {
+var39 = varonce38;
 } else {
-var44 = ")";
-var45 = 1;
-var46 = string__NativeString__to_s_with_length(var44, var45);
-var43 = var46;
-varonce42 = var43;
+var40 = "(&type_";
+var41 = 7;
+var42 = string__NativeString__to_s_with_length(var40, var41);
+var39 = var42;
+varonce38 = var39;
 }
-((void (*)(val*, val*))(var_34->class->vft[COLOR_abstract_collection__SimpleCollection__add]))(var_34, var43) /* add on <var_34:Array[Object]>*/;
-var47 = ((val* (*)(val*))(var_34->class->vft[COLOR_string__Object__to_s]))(var_34) /* to_s on <var_34:Array[Object]>*/;
-var = var47;
+((void (*)(val*, val*))(var_37->class->vft[COLOR_abstract_collection__SimpleCollection__add]))(var_37, var39) /* add on <var_37:Array[Object]>*/;
+var43 = ((val* (*)(val*))(var_value->class->vft[COLOR_abstract_compiler__RuntimeVariable__mtype]))(var_value) /* mtype on <var_value:RuntimeVariable>*/;
+var44 = ((val* (*)(val*))(var43->class->vft[COLOR_abstract_compiler__MType__c_name]))(var43) /* c_name on <var43:MType>*/;
+((void (*)(val*, val*))(var_37->class->vft[COLOR_abstract_collection__SimpleCollection__add]))(var_37, var44) /* add on <var_37:Array[Object]>*/;
+if (varonce45) {
+var46 = varonce45;
+} else {
+var47 = ")";
+var48 = 1;
+var49 = string__NativeString__to_s_with_length(var47, var48);
+var46 = var49;
+varonce45 = var46;
+}
+((void (*)(val*, val*))(var_37->class->vft[COLOR_abstract_collection__SimpleCollection__add]))(var_37, var46) /* add on <var_37:Array[Object]>*/;
+var50 = ((val* (*)(val*))(var_37->class->vft[COLOR_string__Object__to_s]))(var_37) /* to_s on <var_37:Array[Object]>*/;
+var = var50;
 goto RET_LABEL;
 }
 RET_LABEL:;
@@ -773,8 +174,28 @@ val* var_arguments /* var arguments: Array[RuntimeVariable] */;
 val* var1 /* : MPropDef */;
 val* var2 /* : MPropDef */;
 val* var3 /* : nullable MSignature */;
-val* var4 /* : String */;
-val* var5 /* : nullable RuntimeVariable */;
+val* var4 /* : nullable Object */;
+val* var5 /* : MType */;
+val* var6 /* : String */;
+static val* varonce;
+val* var7 /* : String */;
+char* var8 /* : NativeString */;
+long var9 /* : Int */;
+val* var10 /* : String */;
+short int var11 /* : Bool */;
+val* var12 /* : AbstractCompiler */;
+val* var13 /* : MModule */;
+val* var_m /* var m: MModule */;
+val* var14 /* : AbstractCompiler */;
+val* var15 /* : AbstractCompiler */;
+val* var16 /* : MModule */;
+val* var17 /* : nullable Object */;
+val* var18 /* : MType */;
+val* var19 /* : nullable RuntimeVariable */;
+val* var_res /* var res: nullable RuntimeVariable */;
+val* var20 /* : AbstractCompiler */;
+val* var21 /* : String */;
+val* var22 /* : nullable RuntimeVariable */;
 var_mmethod = p0;
 var_arguments = p1;
 var1 = ((val* (*)(val*))(var_mmethod->class->vft[COLOR_model__MProperty__intro]))(var_mmethod) /* intro on <var_mmethod:MMethod>*/;
@@ -782,13 +203,44 @@ var2 = ((val* (*)(val*))(var_mmethod->class->vft[COLOR_model__MProperty__intro])
 var3 = ((val* (*)(val*))(var2->class->vft[COLOR_model__MMethodDef__msignature]))(var2) /* msignature on <var2:MPropDef(MMethodDef)>*/;
 if (var3 == NULL) {
 fprintf(stderr, "Runtime error: %s", "Cast failed");
-fprintf(stderr, " (%s:%d)\n", "src/separate_compiler.nit", 976);
-exit(1);
+fprintf(stderr, " (%s:%d)\n", "src/separate_compiler.nit", 994);
+show_backtrace(1);
 }
 ((void (*)(val*, val*, val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__varargize]))(self, var1, var3, var_arguments) /* varargize on <self:SeparateCompilerVisitor>*/;
-var4 = ((val* (*)(val*))(var_mmethod->class->vft[COLOR_separate_compiler__MProperty__const_color]))(var_mmethod) /* const_color on <var_mmethod:MMethod>*/;
-var5 = ((val* (*)(val*, val*, val*, val*))(self->class->vft[COLOR_separate_compiler__SeparateCompilerVisitor__table_send]))(self, var_mmethod, var_arguments, var4) /* table_send on <self:SeparateCompilerVisitor>*/;
-var = var5;
+var4 = ((val* (*)(val*))(var_arguments->class->vft[COLOR_abstract_collection__Collection__first]))(var_arguments) /* first on <var_arguments:Array[RuntimeVariable]>*/;
+var5 = ((val* (*)(val*))(var4->class->vft[COLOR_abstract_compiler__RuntimeVariable__mcasttype]))(var4) /* mcasttype on <var4:nullable Object(RuntimeVariable)>*/;
+var6 = ((val* (*)(val*))(var5->class->vft[COLOR_abstract_compiler__MType__ctype]))(var5) /* ctype on <var5:MType>*/;
+if (varonce) {
+var7 = varonce;
+} else {
+var8 = "val*";
+var9 = 4;
+var10 = string__NativeString__to_s_with_length(var8, var9);
+var7 = var10;
+varonce = var7;
+}
+var11 = ((short int (*)(val*, val*))(var6->class->vft[COLOR_kernel__Object___33d_61d]))(var6, var7) /* != on <var6:String>*/;
+if (var11){
+var12 = ((val* (*)(val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__compiler]))(self) /* compiler on <self:SeparateCompilerVisitor>*/;
+var13 = ((val* (*)(val*))(var12->class->vft[COLOR_abstract_compiler__AbstractCompiler__mainmodule]))(var12) /* mainmodule on <var12:AbstractCompiler(SeparateCompiler)>*/;
+var_m = var13;
+var14 = ((val* (*)(val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__compiler]))(self) /* compiler on <self:SeparateCompilerVisitor>*/;
+var15 = ((val* (*)(val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__compiler]))(self) /* compiler on <self:SeparateCompilerVisitor>*/;
+var16 = ((val* (*)(val*))(var15->class->vft[COLOR_abstract_compiler__AbstractCompiler__realmainmodule]))(var15) /* realmainmodule on <var15:AbstractCompiler(SeparateCompiler)>*/;
+((void (*)(val*, val*))(var14->class->vft[COLOR_abstract_compiler__AbstractCompiler__mainmodule_61d]))(var14, var16) /* mainmodule= on <var14:AbstractCompiler(SeparateCompiler)>*/;
+var17 = ((val* (*)(val*))(var_arguments->class->vft[COLOR_abstract_collection__Collection__first]))(var_arguments) /* first on <var_arguments:Array[RuntimeVariable]>*/;
+var18 = ((val* (*)(val*))(var17->class->vft[COLOR_abstract_compiler__RuntimeVariable__mcasttype]))(var17) /* mcasttype on <var17:nullable Object(RuntimeVariable)>*/;
+var19 = ((val* (*)(val*, val*, val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__monomorphic_send]))(self, var_mmethod, var18, var_arguments) /* monomorphic_send on <self:SeparateCompilerVisitor>*/;
+var_res = var19;
+var20 = ((val* (*)(val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__compiler]))(self) /* compiler on <self:SeparateCompilerVisitor>*/;
+((void (*)(val*, val*))(var20->class->vft[COLOR_abstract_compiler__AbstractCompiler__mainmodule_61d]))(var20, var_m) /* mainmodule= on <var20:AbstractCompiler(SeparateCompiler)>*/;
+var = var_res;
+goto RET_LABEL;
+} else {
+}
+var21 = ((val* (*)(val*))(var_mmethod->class->vft[COLOR_separate_compiler__MProperty__const_color]))(var_mmethod) /* const_color on <var_mmethod:MMethod>*/;
+var22 = ((val* (*)(val*, val*, val*, val*))(self->class->vft[COLOR_separate_compiler__SeparateCompilerVisitor__table_send]))(self, var_mmethod, var_arguments, var21) /* table_send on <self:SeparateCompilerVisitor>*/;
+var = var22;
 goto RET_LABEL;
 RET_LABEL:;
 return var;
@@ -808,194 +260,191 @@ val* var /* : nullable RuntimeVariable */;
 val* var_mmethod /* var mmethod: MMethod */;
 val* var_arguments /* var arguments: Array[RuntimeVariable] */;
 val* var_const_color /* var const_color: String */;
-val* var1 /* : nullable Object */;
-val* var2 /* : MType */;
-val* var3 /* : String */;
-static val* varonce;
-val* var4 /* : String */;
-char* var5 /* : NativeString */;
+long var1 /* : Int */;
+val* var2 /* : MPropDef */;
+val* var3 /* : nullable MSignature */;
+long var4 /* : Int */;
+long var5 /* : Int */;
 long var6 /* : Int */;
-val* var7 /* : String */;
-short int var8 /* : Bool */;
-val* var9 /* : AbstractCompiler */;
-val* var10 /* : MModule */;
-val* var_m /* var m: MModule */;
-val* var11 /* : AbstractCompiler */;
-val* var12 /* : AbstractCompiler */;
-val* var13 /* : MModule */;
-val* var14 /* : nullable Object */;
-val* var15 /* : MType */;
-val* var16 /* : nullable RuntimeVariable */;
-val* var_res /* var res: nullable RuntimeVariable */;
-val* var17 /* : AbstractCompiler */;
-val* var18 /* : MPropDef */;
-val* var19 /* : nullable MSignature */;
-val* var20 /* : MPropDef */;
-val* var21 /* : MClassDef */;
-val* var22 /* : MClassType */;
-val* var23 /* : MPropDef */;
-val* var24 /* : MClassDef */;
-val* var25 /* : MClassType */;
-val* var26 /* : MPropDef */;
-val* var27 /* : MClassDef */;
-val* var28 /* : MModule */;
-short int var29 /* : Bool */;
-val* var30 /* : MType */;
+long var8 /* : Int */;
+short int var9 /* : Bool */;
+short int var11 /* : Bool */;
+static val* varonce;
+val* var12 /* : String */;
+char* var13 /* : NativeString */;
+long var14 /* : Int */;
+val* var15 /* : String */;
+static val* varonce16;
+val* var17 /* : String */;
+char* var18 /* : NativeString */;
+long var19 /* : Int */;
+val* var20 /* : String */;
+long var21 /* : Int */;
+static val* varonce22;
+val* var23 /* : String */;
+char* var24 /* : NativeString */;
+long var25 /* : Int */;
+val* var26 /* : String */;
+val* var27 /* : Array[Object] */;
+long var28 /* : Int */;
+val* var29 /* : NativeArray[Object] */;
+val* var30 /* : Object */;
+val* var31 /* : String */;
+val* var32 /* : MPropDef */;
+val* var33 /* : nullable MSignature */;
+val* var34 /* : MPropDef */;
+val* var35 /* : MClassDef */;
+val* var36 /* : MClassType */;
+val* var37 /* : MPropDef */;
+val* var38 /* : MClassDef */;
+val* var39 /* : MClassType */;
+val* var40 /* : MPropDef */;
+val* var41 /* : MClassDef */;
+val* var42 /* : MModule */;
+short int var43 /* : Bool */;
+val* var44 /* : MType */;
 val* var_msignature /* var msignature: MSignature */;
-val* var31 /* : nullable MType */;
+val* var45 /* : nullable MType */;
 val* var_ret /* var ret: nullable MType */;
-short int var32 /* : Bool */;
-val* var33 /* : nullable Object */;
-val* var34 /* : MType */;
-val* var35 /* : RuntimeVariable */;
-val* var_res36 /* var res: nullable RuntimeVariable */;
-val* var37 /* : null */;
-short int var38 /* : Bool */;
-val* var39 /* : null */;
-val* var40 /* : RuntimeVariable */;
-val* var41 /* : Buffer */;
+short int var46 /* : Bool */;
+val* var47 /* : nullable Object */;
+val* var48 /* : MType */;
+val* var49 /* : RuntimeVariable */;
+val* var_res /* var res: nullable RuntimeVariable */;
+val* var50 /* : null */;
+short int var51 /* : Bool */;
+val* var52 /* : null */;
+val* var53 /* : RuntimeVariable */;
+val* var54 /* : Buffer */;
 val* var_s /* var s: Buffer */;
-val* var42 /* : Buffer */;
+val* var55 /* : Buffer */;
 val* var_ss /* var ss: Buffer */;
-val* var43 /* : nullable Object */;
+val* var56 /* : nullable Object */;
 val* var_recv /* var recv: RuntimeVariable */;
-static val* varonce44;
-val* var45 /* : String */;
-char* var46 /* : NativeString */;
-long var47 /* : Int */;
-val* var48 /* : String */;
-val* var49 /* : Array[Object] */;
-long var50 /* : Int */;
-val* var51 /* : NativeArray[Object] */;
-val* var52 /* : String */;
-val* var53 /* : Range[Int] */;
-long var54 /* : Int */;
-long var55 /* : Int */;
-val* var56 /* : Discrete */;
-val* var57 /* : Discrete */;
-val* var58 /* : Iterator[nullable Object] */;
-short int var59 /* : Bool */;
-val* var60 /* : nullable Object */;
-long var_i /* var i: Int */;
-long var61 /* : Int */;
-long var62 /* : Int */;
+static val* varonce57;
+val* var58 /* : String */;
+char* var59 /* : NativeString */;
+long var60 /* : Int */;
+val* var61 /* : String */;
+val* var62 /* : Array[Object] */;
 long var63 /* : Int */;
-long var65 /* : Int */;
-val* var66 /* : nullable Object */;
-val* var_a /* var a: RuntimeVariable */;
-val* var67 /* : Array[MParameter] */;
-val* var68 /* : nullable Object */;
-val* var69 /* : MType */;
-val* var_t /* var t: MType */;
-long var70 /* : Int */;
-short int var71 /* : Bool */;
-short int var73 /* : Bool */;
+val* var64 /* : NativeArray[Object] */;
+val* var65 /* : String */;
+val* var66 /* : Range[Int] */;
+long var67 /* : Int */;
+long var68 /* : Int */;
+val* var69 /* : Discrete */;
+val* var70 /* : Discrete */;
+val* var71 /* : Iterator[nullable Object] */;
+short int var72 /* : Bool */;
+val* var73 /* : nullable Object */;
+long var_i /* var i: Int */;
 long var74 /* : Int */;
 long var75 /* : Int */;
-long var77 /* : Int */;
-val* var78 /* : nullable Object */;
-val* var79 /* : MType */;
-static val* varonce80;
-val* var81 /* : String */;
-char* var82 /* : NativeString */;
+long var76 /* : Int */;
+long var78 /* : Int */;
+val* var79 /* : nullable Object */;
+val* var_a /* var a: RuntimeVariable */;
+val* var80 /* : Array[MParameter] */;
+val* var81 /* : nullable Object */;
+val* var82 /* : MType */;
+val* var_t /* var t: MType */;
 long var83 /* : Int */;
-val* var84 /* : String */;
-val* var85 /* : String */;
-val* var86 /* : Array[Object] */;
+short int var84 /* : Bool */;
+short int var86 /* : Bool */;
 long var87 /* : Int */;
-val* var88 /* : NativeArray[Object] */;
-val* var89 /* : String */;
-val* var90 /* : RuntimeVariable */;
-static val* varonce91;
-val* var92 /* : String */;
-char* var93 /* : NativeString */;
-long var94 /* : Int */;
-val* var95 /* : String */;
-val* var96 /* : Array[Object] */;
-long var97 /* : Int */;
-val* var98 /* : NativeArray[Object] */;
-val* var99 /* : String */;
-short int var100 /* : Bool */;
-short int var101 /* : Bool */;
-val* var102 /* : AbstractCompiler */;
-val* var103 /* : ModelBuilder */;
-val* var104 /* : ToolContext */;
-val* var105 /* : OptionBool */;
-val* var106 /* : nullable Object */;
-short int var107 /* : Bool */;
-short int var108 /* : Bool */;
+long var88 /* : Int */;
+long var90 /* : Int */;
+val* var91 /* : nullable Object */;
+val* var92 /* : MType */;
+static val* varonce93;
+val* var94 /* : String */;
+char* var95 /* : NativeString */;
+long var96 /* : Int */;
+val* var97 /* : String */;
+val* var98 /* : String */;
+val* var99 /* : Array[Object] */;
+long var100 /* : Int */;
+val* var101 /* : NativeArray[Object] */;
+val* var102 /* : String */;
+val* var103 /* : RuntimeVariable */;
+static val* varonce104;
+val* var105 /* : String */;
+char* var106 /* : NativeString */;
+long var107 /* : Int */;
+val* var108 /* : String */;
+val* var109 /* : Array[Object] */;
+long var110 /* : Int */;
+val* var111 /* : NativeArray[Object] */;
+val* var112 /* : String */;
+short int var113 /* : Bool */;
+short int var114 /* : Bool */;
+val* var115 /* : AbstractCompiler */;
+val* var116 /* : ModelBuilder */;
+val* var117 /* : ToolContext */;
+val* var118 /* : OptionBool */;
+val* var119 /* : nullable Object */;
+short int var120 /* : Bool */;
+short int var121 /* : Bool */;
 short int var_ /* var : Bool */;
-val* var109 /* : String */;
-static val* varonce110;
-val* var111 /* : String */;
-char* var112 /* : NativeString */;
-long var113 /* : Int */;
-val* var114 /* : String */;
-short int var115 /* : Bool */;
-short int var_116 /* var : Bool */;
-val* var117 /* : String */;
-static val* varonce118;
-val* var119 /* : String */;
-char* var120 /* : NativeString */;
-long var121 /* : Int */;
 val* var122 /* : String */;
-short int var123 /* : Bool */;
+static val* varonce123;
+val* var124 /* : String */;
+char* var125 /* : NativeString */;
+long var126 /* : Int */;
+val* var127 /* : String */;
+short int var128 /* : Bool */;
+short int var_129 /* var : Bool */;
+val* var130 /* : String */;
+static val* varonce131;
+val* var132 /* : String */;
+char* var133 /* : NativeString */;
+long var134 /* : Int */;
+val* var135 /* : String */;
+short int var136 /* : Bool */;
 short int var_consider_null /* var consider_null: Bool */;
-short int var124 /* : Bool */;
-val* var125 /* : MType */;
-short int var126 /* : Bool */;
+short int var137 /* : Bool */;
+val* var138 /* : MType */;
+short int var139 /* : Bool */;
 int cltype;
 int idtype;
-short int var_127 /* var : Bool */;
-short int var_maybenull /* var maybenull: Bool */;
-static val* varonce128;
-val* var129 /* : String */;
-char* var130 /* : NativeString */;
-long var131 /* : Int */;
-val* var132 /* : String */;
-static val* varonce133;
-val* var134 /* : String */;
-char* var135 /* : NativeString */;
-long var136 /* : Int */;
-val* var137 /* : String */;
-val* var138 /* : Array[Object] */;
-long var139 /* : Int */;
-val* var140 /* : NativeArray[Object] */;
-val* var141 /* : String */;
-val* var142 /* : String */;
-static val* varonce143;
-val* var144 /* : String */;
-char* var145 /* : NativeString */;
-long var146 /* : Int */;
+short int var_140 /* var : Bool */;
+short int var_maybenull /* var maybenull: Bool */;
+static val* varonce141;
+val* var142 /* : String */;
+char* var143 /* : NativeString */;
+long var144 /* : Int */;
+val* var145 /* : String */;
+static val* varonce146;
 val* var147 /* : String */;
-short int var148 /* : Bool */;
-val* var149 /* : null */;
-short int var150 /* : Bool */;
-long var151 /* : Int */;
-val* var152 /* : nullable Object */;
+char* var148 /* : NativeString */;
+long var149 /* : Int */;
+val* var150 /* : String */;
+val* var151 /* : Array[Object] */;
+long var152 /* : Int */;
+val* var153 /* : NativeArray[Object] */;
+val* var154 /* : String */;
+val* var155 /* : String */;
+static val* varonce156;
+val* var157 /* : String */;
+char* var158 /* : NativeString */;
+long var159 /* : Int */;
+val* var160 /* : String */;
+short int var161 /* : Bool */;
+val* var162 /* : null */;
+short int var163 /* : Bool */;
+long var164 /* : Int */;
+val* var165 /* : nullable Object */;
 val* var_arg /* var arg: RuntimeVariable */;
-val* var153 /* : MType */;
-short int var154 /* : Bool */;
-int cltype155;
-int idtype156;
-static val* varonce157;
-val* var158 /* : String */;
-char* var159 /* : NativeString */;
-long var160 /* : Int */;
-val* var161 /* : String */;
-static val* varonce162;
-val* var163 /* : String */;
-char* var164 /* : NativeString */;
-long var165 /* : Int */;
-val* var166 /* : String */;
-val* var167 /* : Array[Object] */;
-long var168 /* : Int */;
-val* var169 /* : NativeArray[Object] */;
-val* var170 /* : String */;
-val* var171 /* : MType */;
-short int var172 /* : Bool */;
-int cltype173;
-int idtype174;
+val* var166 /* : MType */;
+short int var167 /* : Bool */;
+int cltype168;
+int idtype169;
+static val* varonce170;
+val* var171 /* : String */;
+char* var172 /* : NativeString */;
+long var173 /* : Int */;
+val* var174 /* : String */;
 static val* varonce175;
 val* var176 /* : String */;
 char* var177 /* : NativeString */;
@@ -1005,55 +454,55 @@ val* var180 /* : Array[Object] */;
 long var181 /* : Int */;
 val* var182 /* : NativeArray[Object] */;
 val* var183 /* : String */;
-static val* varonce184;
-val* var185 /* : String */;
-char* var186 /* : NativeString */;
-long var187 /* : Int */;
-val* var188 /* : String */;
+val* var184 /* : MType */;
+short int var185 /* : Bool */;
+int cltype186;
+int idtype187;
+static val* varonce188;
 val* var189 /* : String */;
-static val* varonce190;
-val* var191 /* : String */;
-char* var192 /* : NativeString */;
-long var193 /* : Int */;
-val* var194 /* : String */;
-val* var195 /* : Array[Object] */;
-long var196 /* : Int */;
-val* var197 /* : NativeArray[Object] */;
+char* var190 /* : NativeString */;
+long var191 /* : Int */;
+val* var192 /* : String */;
+val* var193 /* : Array[Object] */;
+long var194 /* : Int */;
+val* var195 /* : NativeArray[Object] */;
+val* var196 /* : String */;
+static val* varonce197;
 val* var198 /* : String */;
-val* var199 /* : String */;
-static val* varonce200;
+char* var199 /* : NativeString */;
+long var200 /* : Int */;
 val* var201 /* : String */;
-char* var202 /* : NativeString */;
-long var203 /* : Int */;
+val* var202 /* : String */;
+static val* varonce203;
 val* var204 /* : String */;
-short int var205 /* : Bool */;
-val* var206 /* : null */;
-short int var207 /* : Bool */;
-long var208 /* : Int */;
-val* var209 /* : nullable Object */;
-val* var_arg210 /* var arg: RuntimeVariable */;
-val* var211 /* : MType */;
-short int var212 /* : Bool */;
-int cltype213;
-int idtype214;
-static val* varonce215;
-val* var216 /* : String */;
-char* var217 /* : NativeString */;
-long var218 /* : Int */;
-val* var219 /* : String */;
-static val* varonce220;
-val* var221 /* : String */;
-char* var222 /* : NativeString */;
-long var223 /* : Int */;
-val* var224 /* : String */;
-val* var225 /* : Array[Object] */;
-long var226 /* : Int */;
-val* var227 /* : NativeArray[Object] */;
-val* var228 /* : String */;
-val* var229 /* : MType */;
-short int var230 /* : Bool */;
-int cltype231;
-int idtype232;
+char* var205 /* : NativeString */;
+long var206 /* : Int */;
+val* var207 /* : String */;
+val* var208 /* : Array[Object] */;
+long var209 /* : Int */;
+val* var210 /* : NativeArray[Object] */;
+val* var211 /* : String */;
+val* var212 /* : String */;
+static val* varonce213;
+val* var214 /* : String */;
+char* var215 /* : NativeString */;
+long var216 /* : Int */;
+val* var217 /* : String */;
+short int var218 /* : Bool */;
+val* var219 /* : null */;
+short int var220 /* : Bool */;
+long var221 /* : Int */;
+val* var222 /* : nullable Object */;
+val* var_arg223 /* var arg: RuntimeVariable */;
+val* var224 /* : MType */;
+short int var225 /* : Bool */;
+int cltype226;
+int idtype227;
+static val* varonce228;
+val* var229 /* : String */;
+char* var230 /* : NativeString */;
+long var231 /* : Int */;
+val* var232 /* : String */;
 static val* varonce233;
 val* var234 /* : String */;
 char* var235 /* : NativeString */;
@@ -1063,1097 +512,1131 @@ val* var238 /* : Array[Object] */;
 long var239 /* : Int */;
 val* var240 /* : NativeArray[Object] */;
 val* var241 /* : String */;
-static val* varonce242;
-val* var243 /* : String */;
-char* var244 /* : NativeString */;
-long var245 /* : Int */;
-val* var246 /* : String */;
+val* var242 /* : MType */;
+short int var243 /* : Bool */;
+int cltype244;
+int idtype245;
+static val* varonce246;
 val* var247 /* : String */;
-static val* varonce248;
-val* var249 /* : String */;
-char* var250 /* : NativeString */;
-long var251 /* : Int */;
-val* var252 /* : String */;
-val* var253 /* : Array[Object] */;
-long var254 /* : Int */;
-val* var255 /* : NativeArray[Object] */;
+char* var248 /* : NativeString */;
+long var249 /* : Int */;
+val* var250 /* : String */;
+val* var251 /* : Array[Object] */;
+long var252 /* : Int */;
+val* var253 /* : NativeArray[Object] */;
+val* var254 /* : String */;
+static val* varonce255;
 val* var256 /* : String */;
-static val* varonce257;
-val* var258 /* : String */;
-char* var259 /* : NativeString */;
-long var260 /* : Int */;
-val* var261 /* : String */;
-static val* varonce262;
-val* var263 /* : String */;
-char* var264 /* : NativeString */;
-long var265 /* : Int */;
-val* var266 /* : String */;
-short int var267 /* : Bool */;
-val* var268 /* : AbstractCompiler */;
-val* var269 /* : ModelBuilder */;
-val* var270 /* : ToolContext */;
-val* var271 /* : OptionBool */;
-val* var272 /* : nullable Object */;
-short int var273 /* : Bool */;
-short int var274 /* : Bool */;
-short int var_275 /* var : Bool */;
-short int var276 /* : Bool */;
-val* var277 /* : String */;
-static val* varonce278;
+char* var257 /* : NativeString */;
+long var258 /* : Int */;
+val* var259 /* : String */;
+val* var260 /* : String */;
+static val* varonce261;
+val* var262 /* : String */;
+char* var263 /* : NativeString */;
+long var264 /* : Int */;
+val* var265 /* : String */;
+val* var266 /* : Array[Object] */;
+long var267 /* : Int */;
+val* var268 /* : NativeArray[Object] */;
+val* var269 /* : String */;
+static val* varonce270;
+val* var271 /* : String */;
+char* var272 /* : NativeString */;
+long var273 /* : Int */;
+val* var274 /* : String */;
+static val* varonce275;
+val* var276 /* : String */;
+char* var277 /* : NativeString */;
+long var278 /* : Int */;
 val* var279 /* : String */;
-char* var280 /* : NativeString */;
-long var281 /* : Int */;
-val* var282 /* : String */;
-short int var283 /* : Bool */;
-short int var_284 /* var : Bool */;
-val* var285 /* : String */;
-static val* varonce286;
-val* var287 /* : String */;
-char* var288 /* : NativeString */;
-long var289 /* : Int */;
+short int var280 /* : Bool */;
+val* var281 /* : AbstractCompiler */;
+val* var282 /* : ModelBuilder */;
+val* var283 /* : ToolContext */;
+val* var284 /* : OptionBool */;
+val* var285 /* : nullable Object */;
+short int var286 /* : Bool */;
+short int var287 /* : Bool */;
+short int var_288 /* var : Bool */;
+short int var289 /* : Bool */;
 val* var290 /* : String */;
-short int var291 /* : Bool */;
-val* var292 /* : null */;
-short int var293 /* : Bool */;
+static val* varonce291;
+val* var292 /* : String */;
+char* var293 /* : NativeString */;
 long var294 /* : Int */;
-val* var295 /* : nullable Object */;
-val* var_arg296 /* var arg: RuntimeVariable */;
-val* var297 /* : MType */;
-short int var298 /* : Bool */;
-int cltype299;
-int idtype300;
-val* var301 /* : String */;
-static val* varonce302;
+val* var295 /* : String */;
+short int var296 /* : Bool */;
+short int var_297 /* var : Bool */;
+val* var298 /* : String */;
+static val* varonce299;
+val* var300 /* : String */;
+char* var301 /* : NativeString */;
+long var302 /* : Int */;
 val* var303 /* : String */;
-char* var304 /* : NativeString */;
-long var305 /* : Int */;
-val* var306 /* : String */;
-short int var307 /* : Bool */;
-static val* varonce308;
-val* var309 /* : String */;
-char* var310 /* : NativeString */;
-long var311 /* : Int */;
-val* var312 /* : String */;
-val* var313 /* : Array[Object] */;
-long var314 /* : Int */;
-val* var315 /* : NativeArray[Object] */;
+short int var304 /* : Bool */;
+val* var305 /* : null */;
+short int var306 /* : Bool */;
+long var307 /* : Int */;
+val* var308 /* : nullable Object */;
+val* var_arg309 /* var arg: RuntimeVariable */;
+val* var310 /* : MType */;
+short int var311 /* : Bool */;
+int cltype312;
+int idtype313;
+val* var314 /* : String */;
+static val* varonce315;
 val* var316 /* : String */;
-static val* varonce317;
-val* var318 /* : String */;
-char* var319 /* : NativeString */;
-long var320 /* : Int */;
-val* var321 /* : String */;
-val* var322 /* : Array[Object] */;
-long var323 /* : Int */;
-val* var324 /* : NativeArray[Object] */;
+char* var317 /* : NativeString */;
+long var318 /* : Int */;
+val* var319 /* : String */;
+short int var320 /* : Bool */;
+static val* varonce321;
+val* var322 /* : String */;
+char* var323 /* : NativeString */;
+long var324 /* : Int */;
 val* var325 /* : String */;
-static val* varonce326;
-val* var327 /* : String */;
-char* var328 /* : NativeString */;
-long var329 /* : Int */;
-val* var330 /* : String */;
-val* var331 /* : null */;
-short int var332 /* : Bool */;
-static val* varonce333;
+val* var326 /* : Array[Object] */;
+long var327 /* : Int */;
+val* var328 /* : NativeArray[Object] */;
+val* var329 /* : String */;
+static val* varonce330;
+val* var331 /* : String */;
+char* var332 /* : NativeString */;
+long var333 /* : Int */;
 val* var334 /* : String */;
-char* var335 /* : NativeString */;
+val* var335 /* : Array[Object] */;
 long var336 /* : Int */;
-val* var337 /* : String */;
-val* var_r /* var r: nullable Object */;
+val* var337 /* : NativeArray[Object] */;
 val* var338 /* : String */;
-val* var339 /* : Array[Object] */;
-long var340 /* : Int */;
-val* var_341 /* var : Array[Object] */;
-static val* varonce342;
+static val* varonce339;
+val* var340 /* : String */;
+char* var341 /* : NativeString */;
+long var342 /* : Int */;
 val* var343 /* : String */;
-char* var344 /* : NativeString */;
-long var345 /* : Int */;
-val* var346 /* : String */;
-static val* varonce347;
-val* var348 /* : String */;
-char* var349 /* : NativeString */;
-long var350 /* : Int */;
+val* var344 /* : null */;
+short int var345 /* : Bool */;
+static val* varonce346;
+val* var347 /* : String */;
+char* var348 /* : NativeString */;
+long var349 /* : Int */;
+val* var350 /* : String */;
+val* var_r /* var r: nullable Object */;
 val* var351 /* : String */;
-static val* varonce352;
-val* var353 /* : String */;
-char* var354 /* : NativeString */;
-long var355 /* : Int */;
+val* var352 /* : Array[Object] */;
+long var353 /* : Int */;
+val* var_354 /* var : Array[Object] */;
+static val* varonce355;
 val* var356 /* : String */;
-val* var357 /* : nullable Object */;
-static val* varonce358;
+char* var357 /* : NativeString */;
+long var358 /* : Int */;
 val* var359 /* : String */;
-char* var360 /* : NativeString */;
-long var361 /* : Int */;
-val* var362 /* : String */;
-static val* varonce363;
+static val* varonce360;
+val* var361 /* : String */;
+char* var362 /* : NativeString */;
+long var363 /* : Int */;
 val* var364 /* : String */;
-char* var365 /* : NativeString */;
-long var366 /* : Int */;
-val* var367 /* : String */;
-static val* varonce368;
+static val* varonce365;
+val* var366 /* : String */;
+char* var367 /* : NativeString */;
+long var368 /* : Int */;
 val* var369 /* : String */;
-char* var370 /* : NativeString */;
-long var371 /* : Int */;
+val* var370 /* : nullable Object */;
+static val* varonce371;
 val* var372 /* : String */;
-static val* varonce373;
-val* var374 /* : String */;
-char* var375 /* : NativeString */;
-long var376 /* : Int */;
+char* var373 /* : NativeString */;
+long var374 /* : Int */;
+val* var375 /* : String */;
+static val* varonce376;
 val* var377 /* : String */;
-val* var378 /* : nullable Object */;
-val* var379 /* : String */;
-static val* varonce380;
-val* var381 /* : String */;
-char* var382 /* : NativeString */;
-long var383 /* : Int */;
-val* var384 /* : String */;
+char* var378 /* : NativeString */;
+long var379 /* : Int */;
+val* var380 /* : String */;
+static val* varonce381;
+val* var382 /* : String */;
+char* var383 /* : NativeString */;
+long var384 /* : Int */;
 val* var385 /* : String */;
-val* var_call /* var call: String */;
-val* var386 /* : null */;
-short int var387 /* : Bool */;
-static val* varonce388;
-val* var389 /* : String */;
-char* var390 /* : NativeString */;
-long var391 /* : Int */;
+static val* varonce386;
+val* var387 /* : String */;
+char* var388 /* : NativeString */;
+long var389 /* : Int */;
+val* var390 /* : String */;
+val* var391 /* : nullable Object */;
 val* var392 /* : String */;
 static val* varonce393;
 val* var394 /* : String */;
 char* var395 /* : NativeString */;
 long var396 /* : Int */;
 val* var397 /* : String */;
-val* var398 /* : Array[Object] */;
-long var399 /* : Int */;
-val* var400 /* : NativeArray[Object] */;
-val* var401 /* : String */;
-static val* varonce402;
-val* var403 /* : String */;
-char* var404 /* : NativeString */;
-long var405 /* : Int */;
-val* var406 /* : String */;
-val* var407 /* : Array[Object] */;
-long var408 /* : Int */;
-val* var409 /* : NativeArray[Object] */;
+val* var398 /* : String */;
+val* var_call /* var call: String */;
+val* var399 /* : null */;
+short int var400 /* : Bool */;
+static val* varonce401;
+val* var402 /* : String */;
+char* var403 /* : NativeString */;
+long var404 /* : Int */;
+val* var405 /* : String */;
+static val* varonce406;
+val* var407 /* : String */;
+char* var408 /* : NativeString */;
+long var409 /* : Int */;
 val* var410 /* : String */;
-static val* varonce411;
-val* var412 /* : String */;
-char* var413 /* : NativeString */;
-long var414 /* : Int */;
-val* var415 /* : String */;
+val* var411 /* : Array[Object] */;
+long var412 /* : Int */;
+val* var413 /* : NativeArray[Object] */;
+val* var414 /* : String */;
+static val* varonce415;
+val* var416 /* : String */;
+char* var417 /* : NativeString */;
+long var418 /* : Int */;
+val* var419 /* : String */;
+val* var420 /* : Array[Object] */;
+long var421 /* : Int */;
+val* var422 /* : NativeArray[Object] */;
+val* var423 /* : String */;
+static val* varonce424;
+val* var425 /* : String */;
+char* var426 /* : NativeString */;
+long var427 /* : Int */;
+val* var428 /* : String */;
 var_mmethod = p0;
 var_arguments = p1;
 var_const_color = p2;
-var1 = ((val* (*)(val*))(var_arguments->class->vft[COLOR_abstract_collection__Collection__first]))(var_arguments) /* first on <var_arguments:Array[RuntimeVariable]>*/;
-var2 = ((val* (*)(val*))(var1->class->vft[COLOR_abstract_compiler__RuntimeVariable__mcasttype]))(var1) /* mcasttype on <var1:nullable Object(RuntimeVariable)>*/;
-var3 = ((val* (*)(val*))(var2->class->vft[COLOR_abstract_compiler__MType__ctype]))(var2) /* ctype on <var2:MType>*/;
+var1 = ((long (*)(val*))(var_arguments->class->vft[COLOR_abstract_collection__Collection__length]))(var_arguments) /* length on <var_arguments:Array[RuntimeVariable]>*/;
+var2 = ((val* (*)(val*))(var_mmethod->class->vft[COLOR_model__MProperty__intro]))(var_mmethod) /* intro on <var_mmethod:MMethod>*/;
+var3 = ((val* (*)(val*))(var2->class->vft[COLOR_model__MMethodDef__msignature]))(var2) /* msignature on <var2:MPropDef(MMethodDef)>*/;
+if (var3 == NULL) {
+fprintf(stderr, "Runtime error: %s", "Receiver is null");
+fprintf(stderr, " (%s:%d)\n", "src/separate_compiler.nit", 1011);
+show_backtrace(1);
+} else {
+var4 = ((long (*)(val*))(var3->class->vft[COLOR_model__MSignature__arity]))(var3) /* arity on <var3:nullable MSignature>*/;
+}
+var5 = 1;
+{ /* Inline kernel#Int#+ (var4,var5) */
+var8 = var4 + var5;
+var6 = var8;
+goto RET_LABEL7;
+RET_LABEL7:(void)0;
+}
+{ /* Inline kernel#Int#== (var1,var6) */
+var11 = var1 == var6;
+var9 = var11;
+goto RET_LABEL10;
+RET_LABEL10:(void)0;
+}
+if (!var9) {
 if (varonce) {
-var4 = varonce;
+var12 = varonce;
 } else {
-var5 = "val*";
-var6 = 4;
-var7 = string__NativeString__to_s_with_length(var5, var6);
-var4 = var7;
-varonce = var4;
+var13 = "Invalid arity for ";
+var14 = 18;
+var15 = string__NativeString__to_s_with_length(var13, var14);
+var12 = var15;
+varonce = var12;
 }
-var8 = ((short int (*)(val*, val*))(var3->class->vft[COLOR_kernel__Object___33d_61d]))(var3, var4) /* != on <var3:String>*/;
-if (var8){
-var9 = ((val* (*)(val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__compiler]))(self) /* compiler on <self:SeparateCompilerVisitor>*/;
-var10 = ((val* (*)(val*))(var9->class->vft[COLOR_abstract_compiler__AbstractCompiler__mainmodule]))(var9) /* mainmodule on <var9:AbstractCompiler(SeparateCompiler)>*/;
-var_m = var10;
-var11 = ((val* (*)(val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__compiler]))(self) /* compiler on <self:SeparateCompilerVisitor>*/;
-var12 = ((val* (*)(val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__compiler]))(self) /* compiler on <self:SeparateCompilerVisitor>*/;
-var13 = ((val* (*)(val*))(var12->class->vft[COLOR_abstract_compiler__AbstractCompiler__realmainmodule]))(var12) /* realmainmodule on <var12:AbstractCompiler(SeparateCompiler)>*/;
-((void (*)(val*, val*))(var11->class->vft[COLOR_abstract_compiler__AbstractCompiler__mainmodule_61d]))(var11, var13) /* mainmodule= on <var11:AbstractCompiler(SeparateCompiler)>*/;
-var14 = ((val* (*)(val*))(var_arguments->class->vft[COLOR_abstract_collection__Collection__first]))(var_arguments) /* first on <var_arguments:Array[RuntimeVariable]>*/;
-var15 = ((val* (*)(val*))(var14->class->vft[COLOR_abstract_compiler__RuntimeVariable__mcasttype]))(var14) /* mcasttype on <var14:nullable Object(RuntimeVariable)>*/;
-var16 = ((val* (*)(val*, val*, val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__monomorphic_send]))(self, var_mmethod, var15, var_arguments) /* monomorphic_send on <self:SeparateCompilerVisitor>*/;
-var_res = var16;
-var17 = ((val* (*)(val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__compiler]))(self) /* compiler on <self:SeparateCompilerVisitor>*/;
-((void (*)(val*, val*))(var17->class->vft[COLOR_abstract_compiler__AbstractCompiler__mainmodule_61d]))(var17, var_m) /* mainmodule= on <var17:AbstractCompiler(SeparateCompiler)>*/;
-var = var_res;
-goto RET_LABEL;
+if (varonce16) {
+var17 = varonce16;
 } else {
+var18 = ". ";
+var19 = 2;
+var20 = string__NativeString__to_s_with_length(var18, var19);
+var17 = var20;
+varonce16 = var17;
 }
-var18 = ((val* (*)(val*))(var_mmethod->class->vft[COLOR_model__MProperty__intro]))(var_mmethod) /* intro on <var_mmethod:MMethod>*/;
-var19 = ((val* (*)(val*))(var18->class->vft[COLOR_model__MMethodDef__msignature]))(var18) /* msignature on <var18:MPropDef(MMethodDef)>*/;
-var20 = ((val* (*)(val*))(var_mmethod->class->vft[COLOR_model__MProperty__intro]))(var_mmethod) /* intro on <var_mmethod:MMethod>*/;
-var21 = ((val* (*)(val*))(var20->class->vft[COLOR_model__MPropDef__mclassdef]))(var20) /* mclassdef on <var20:MPropDef(MMethodDef)>*/;
-var22 = ((val* (*)(val*))(var21->class->vft[COLOR_model__MClassDef__bound_mtype]))(var21) /* bound_mtype on <var21:MClassDef>*/;
-var23 = ((val* (*)(val*))(var_mmethod->class->vft[COLOR_model__MProperty__intro]))(var_mmethod) /* intro on <var_mmethod:MMethod>*/;
-var24 = ((val* (*)(val*))(var23->class->vft[COLOR_model__MPropDef__mclassdef]))(var23) /* mclassdef on <var23:MPropDef(MMethodDef)>*/;
-var25 = ((val* (*)(val*))(var24->class->vft[COLOR_model__MClassDef__bound_mtype]))(var24) /* bound_mtype on <var24:MClassDef>*/;
-var26 = ((val* (*)(val*))(var_mmethod->class->vft[COLOR_model__MProperty__intro]))(var_mmethod) /* intro on <var_mmethod:MMethod>*/;
-var27 = ((val* (*)(val*))(var26->class->vft[COLOR_model__MPropDef__mclassdef]))(var26) /* mclassdef on <var26:MPropDef(MMethodDef)>*/;
-var28 = ((val* (*)(val*))(var27->class->vft[COLOR_model__MClassDef__mmodule]))(var27) /* mmodule on <var27:MClassDef>*/;
-var29 = 1;
-if (var19 == NULL) {
-fprintf(stderr, "Runtime error: %s", "Reciever is null");
-fprintf(stderr, " (%s:%d)\n", "src/separate_compiler.nit", 993);
-exit(1);
-} else {
-var30 = ((val* (*)(val*, val*, val*, val*, short int))(var19->class->vft[COLOR_model__MType__resolve_for]))(var19, var22, var25, var28, var29) /* resolve_for on <var19:nullable MSignature>*/;
-}
-var_msignature = var30;
-var31 = ((val* (*)(val*))(var_msignature->class->vft[COLOR_model__MSignature__return_mtype]))(var_msignature) /* return_mtype on <var_msignature:MSignature>*/;
-var_ret = var31;
-var32 = ((short int (*)(val*))(var_mmethod->class->vft[COLOR_model__MMethod__is_new]))(var_mmethod) /* is_new on <var_mmethod:MMethod>*/;
-if (var32){
-var33 = ((val* (*)(val*))(var_arguments->class->vft[COLOR_abstract_collection__Collection__first]))(var_arguments) /* first on <var_arguments:Array[RuntimeVariable]>*/;
-var34 = ((val* (*)(val*))(var33->class->vft[COLOR_abstract_compiler__RuntimeVariable__mtype]))(var33) /* mtype on <var33:nullable Object(RuntimeVariable)>*/;
-var_ret = var34;
-var35 = ((val* (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__new_var]))(self, var_ret) /* new_var on <self:SeparateCompilerVisitor>*/;
-var_res36 = var35;
+var21 = ((long (*)(val*))(var_arguments->class->vft[COLOR_abstract_collection__Collection__length]))(var_arguments) /* length on <var_arguments:Array[RuntimeVariable]>*/;
+if (varonce22) {
+var23 = varonce22;
 } else {
-var37 = NULL;
+var24 = " arguments given.";
+var25 = 17;
+var26 = string__NativeString__to_s_with_length(var24, var25);
+var23 = var26;
+varonce22 = var23;
+}
+var27 = NEW_array__Array(&type_array__Arraykernel__Object);
+{ /* var27 = array_instance Array[Object] */
+var28 = 5;
+var29 = NEW_array__NativeArray(var28, &type_array__NativeArraykernel__Object);
+((struct instance_array__NativeArray*)var29)->values[0] = (val*) var12;
+((struct instance_array__NativeArray*)var29)->values[1] = (val*) var_mmethod;
+((struct instance_array__NativeArray*)var29)->values[2] = (val*) var17;
+var30 = BOX_kernel__Int(var21); /* autobox from Int to Object */
+((struct instance_array__NativeArray*)var29)->values[3] = (val*) var30;
+((struct instance_array__NativeArray*)var29)->values[4] = (val*) var23;
+((void (*)(val*, val*, long))(var27->class->vft[COLOR_array__Array__with_native]))(var27, var29, var28) /* with_native on <var27:Array[Object]>*/;
+}
+var31 = ((val* (*)(val*))(var27->class->vft[COLOR_string__Object__to_s]))(var27) /* to_s on <var27:Array[Object]>*/;
+((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__debug]))(self, var31) /* debug on <self:SeparateCompilerVisitor>*/;
+fprintf(stderr, "Runtime error: %s", "Assert failed");
+fprintf(stderr, " (%s:%d)\n", "src/separate_compiler.nit", 1011);
+show_backtrace(1);
+}
+var32 = ((val* (*)(val*))(var_mmethod->class->vft[COLOR_model__MProperty__intro]))(var_mmethod) /* intro on <var_mmethod:MMethod>*/;
+var33 = ((val* (*)(val*))(var32->class->vft[COLOR_model__MMethodDef__msignature]))(var32) /* msignature on <var32:MPropDef(MMethodDef)>*/;
+var34 = ((val* (*)(val*))(var_mmethod->class->vft[COLOR_model__MProperty__intro]))(var_mmethod) /* intro on <var_mmethod:MMethod>*/;
+var35 = ((val* (*)(val*))(var34->class->vft[COLOR_model__MPropDef__mclassdef]))(var34) /* mclassdef on <var34:MPropDef(MMethodDef)>*/;
+var36 = ((val* (*)(val*))(var35->class->vft[COLOR_model__MClassDef__bound_mtype]))(var35) /* bound_mtype on <var35:MClassDef>*/;
+var37 = ((val* (*)(val*))(var_mmethod->class->vft[COLOR_model__MProperty__intro]))(var_mmethod) /* intro on <var_mmethod:MMethod>*/;
+var38 = ((val* (*)(val*))(var37->class->vft[COLOR_model__MPropDef__mclassdef]))(var37) /* mclassdef on <var37:MPropDef(MMethodDef)>*/;
+var39 = ((val* (*)(val*))(var38->class->vft[COLOR_model__MClassDef__bound_mtype]))(var38) /* bound_mtype on <var38:MClassDef>*/;
+var40 = ((val* (*)(val*))(var_mmethod->class->vft[COLOR_model__MProperty__intro]))(var_mmethod) /* intro on <var_mmethod:MMethod>*/;
+var41 = ((val* (*)(val*))(var40->class->vft[COLOR_model__MPropDef__mclassdef]))(var40) /* mclassdef on <var40:MPropDef(MMethodDef)>*/;
+var42 = ((val* (*)(val*))(var41->class->vft[COLOR_model__MClassDef__mmodule]))(var41) /* mmodule on <var41:MClassDef>*/;
+var43 = 1;
+if (var33 == NULL) {
+fprintf(stderr, "Runtime error: %s", "Receiver is null");
+fprintf(stderr, " (%s:%d)\n", "src/separate_compiler.nit", 1014);
+show_backtrace(1);
+} else {
+var44 = ((val* (*)(val*, val*, val*, val*, short int))(var33->class->vft[COLOR_model__MType__resolve_for]))(var33, var36, var39, var42, var43) /* resolve_for on <var33:nullable MSignature>*/;
+}
+var_msignature = var44;
+var45 = ((val* (*)(val*))(var_msignature->class->vft[COLOR_model__MSignature__return_mtype]))(var_msignature) /* return_mtype on <var_msignature:MSignature>*/;
+var_ret = var45;
+var46 = ((short int (*)(val*))(var_mmethod->class->vft[COLOR_model__MMethod__is_new]))(var_mmethod) /* is_new on <var_mmethod:MMethod>*/;
+if (var46){
+var47 = ((val* (*)(val*))(var_arguments->class->vft[COLOR_abstract_collection__Collection__first]))(var_arguments) /* first on <var_arguments:Array[RuntimeVariable]>*/;
+var48 = ((val* (*)(val*))(var47->class->vft[COLOR_abstract_compiler__RuntimeVariable__mtype]))(var47) /* mtype on <var47:nullable Object(RuntimeVariable)>*/;
+var_ret = var48;
+var49 = ((val* (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__new_var]))(self, var_ret) /* new_var on <self:SeparateCompilerVisitor>*/;
+var_res = var49;
+} else {
+var50 = NULL;
 if (var_ret == NULL) {
-var38 = 1; /* is null */
+var51 = 1; /* is null */
 } else {
-var38 = 0; /* arg is null but recv is not */
+var51 = 0; /* arg is null but recv is not */
 }
-if (var38){
-var39 = NULL;
-var_res36 = var39;
-} else {
-var40 = ((val* (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__new_var]))(self, var_ret) /* new_var on <self:SeparateCompilerVisitor>*/;
-var_res36 = var40;
-}
-}
-var41 = NEW_string__Buffer(&type_string__Buffer);
-((void (*)(val*))(var41->class->vft[COLOR_string__Buffer__init]))(var41) /* init on <var41:Buffer>*/;
-CHECK_NEW_string__Buffer(var41);
-var_s = var41;
-var42 = NEW_string__Buffer(&type_string__Buffer);
-((void (*)(val*))(var42->class->vft[COLOR_string__Buffer__init]))(var42) /* init on <var42:Buffer>*/;
-CHECK_NEW_string__Buffer(var42);
-var_ss = var42;
-var43 = ((val* (*)(val*))(var_arguments->class->vft[COLOR_abstract_collection__Collection__first]))(var_arguments) /* first on <var_arguments:Array[RuntimeVariable]>*/;
-var_recv = var43;
-if (varonce44) {
-var45 = varonce44;
+if (var51){
+var52 = NULL;
+var_res = var52;
 } else {
-var46 = "val*";
-var47 = 4;
-var48 = string__NativeString__to_s_with_length(var46, var47);
-var45 = var48;
-varonce44 = var45;
+var53 = ((val* (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__new_var]))(self, var_ret) /* new_var on <self:SeparateCompilerVisitor>*/;
+var_res = var53;
+}
 }
-((void (*)(val*, val*))(var_s->class->vft[COLOR_abstract_collection__Sequence__append]))(var_s, var45) /* append on <var_s:Buffer>*/;
-var49 = NEW_array__Array(&type_array__Arraykernel__Object);
-{ /* var49 = array_instance Array[Object] */
-var50 = 1;
-var51 = NEW_array__NativeArray(var50, &type_array__NativeArraykernel__Object);
-((struct instance_array__NativeArray*)var51)->values[0] = (val*) var_recv;
-((void (*)(val*, val*, long))(var49->class->vft[COLOR_array__Array__with_native]))(var49, var51, var50) /* with_native on <var49:Array[Object]>*/;
-CHECK_NEW_array__Array(var49);
-}
-var52 = ((val* (*)(val*))(var49->class->vft[COLOR_string__Object__to_s]))(var49) /* to_s on <var49:Array[Object]>*/;
-((void (*)(val*, val*))(var_ss->class->vft[COLOR_abstract_collection__Sequence__append]))(var_ss, var52) /* append on <var_ss:Buffer>*/;
-var53 = NEW_range__Range(&type_range__Rangekernel__Int);
-var54 = 0;
-var55 = ((long (*)(val*))(var_msignature->class->vft[COLOR_model__MSignature__arity]))(var_msignature) /* arity on <var_msignature:MSignature>*/;
-var56 = BOX_kernel__Int(var54); /* autobox from Int to Discrete */
-var57 = BOX_kernel__Int(var55); /* autobox from Int to Discrete */
-((void (*)(val*, val*, val*))(var53->class->vft[COLOR_range__Range__without_last]))(var53, var56, var57) /* without_last on <var53:Range[Int]>*/;
-CHECK_NEW_range__Range(var53);
-var58 = ((val* (*)(val*))(var53->class->vft[COLOR_abstract_collection__Collection__iterator]))(var53) /* iterator on <var53:Range[Int]>*/;
+var54 = NEW_string__Buffer(&type_string__Buffer);
+((void (*)(val*))(var54->class->vft[COLOR_string__Buffer__init]))(var54) /* init on <var54:Buffer>*/;
+var_s = var54;
+var55 = NEW_string__Buffer(&type_string__Buffer);
+((void (*)(val*))(var55->class->vft[COLOR_string__Buffer__init]))(var55) /* init on <var55:Buffer>*/;
+var_ss = var55;
+var56 = ((val* (*)(val*))(var_arguments->class->vft[COLOR_abstract_collection__Collection__first]))(var_arguments) /* first on <var_arguments:Array[RuntimeVariable]>*/;
+var_recv = var56;
+if (varonce57) {
+var58 = varonce57;
+} else {
+var59 = "val*";
+var60 = 4;
+var61 = string__NativeString__to_s_with_length(var59, var60);
+var58 = var61;
+varonce57 = var58;
+}
+((void (*)(val*, val*))(var_s->class->vft[COLOR_abstract_collection__Sequence__append]))(var_s, var58) /* append on <var_s:Buffer>*/;
+var62 = NEW_array__Array(&type_array__Arraykernel__Object);
+{ /* var62 = array_instance Array[Object] */
+var63 = 1;
+var64 = NEW_array__NativeArray(var63, &type_array__NativeArraykernel__Object);
+((struct instance_array__NativeArray*)var64)->values[0] = (val*) var_recv;
+((void (*)(val*, val*, long))(var62->class->vft[COLOR_array__Array__with_native]))(var62, var64, var63) /* with_native on <var62:Array[Object]>*/;
+}
+var65 = ((val* (*)(val*))(var62->class->vft[COLOR_string__Object__to_s]))(var62) /* to_s on <var62:Array[Object]>*/;
+((void (*)(val*, val*))(var_ss->class->vft[COLOR_abstract_collection__Sequence__append]))(var_ss, var65) /* append on <var_ss:Buffer>*/;
+var66 = NEW_range__Range(&type_range__Rangekernel__Int);
+var67 = 0;
+var68 = ((long (*)(val*))(var_msignature->class->vft[COLOR_model__MSignature__arity]))(var_msignature) /* arity on <var_msignature:MSignature>*/;
+var69 = BOX_kernel__Int(var67); /* autobox from Int to Discrete */
+var70 = BOX_kernel__Int(var68); /* autobox from Int to Discrete */
+((void (*)(val*, val*, val*))(var66->class->vft[COLOR_range__Range__without_last]))(var66, var69, var70) /* without_last on <var66:Range[Int]>*/;
+var71 = ((val* (*)(val*))(var66->class->vft[COLOR_abstract_collection__Collection__iterator]))(var66) /* iterator on <var66:Range[Int]>*/;
 for(;;) {
-var59 = ((short int (*)(val*))(var58->class->vft[COLOR_abstract_collection__Iterator__is_ok]))(var58) /* is_ok on <var58:Iterator[nullable Object]>*/;
-if(!var59) break;
-var60 = ((val* (*)(val*))(var58->class->vft[COLOR_abstract_collection__Iterator__item]))(var58) /* item on <var58:Iterator[nullable Object]>*/;
-var61 = ((struct instance_kernel__Int*)var60)->value; /* autounbox from nullable Object to Int */;
-var_i = var61;
-var62 = 1;
-{ /* Inline kernel#Int#+ (var_i,var62) */
-var65 = var_i + var62;
-var63 = var65;
-goto RET_LABEL64;
-RET_LABEL64:(void)0;
-}
-var66 = ((val* (*)(val*, long))(var_arguments->class->vft[COLOR_abstract_collection__SequenceRead___91d_93d]))(var_arguments, var63) /* [] on <var_arguments:Array[RuntimeVariable]>*/;
-var_a = var66;
-var67 = ((val* (*)(val*))(var_msignature->class->vft[COLOR_model__MSignature__mparameters]))(var_msignature) /* mparameters on <var_msignature:MSignature>*/;
-var68 = ((val* (*)(val*, long))(var67->class->vft[COLOR_abstract_collection__SequenceRead___91d_93d]))(var67, var_i) /* [] on <var67:Array[MParameter]>*/;
-var69 = ((val* (*)(val*))(var68->class->vft[COLOR_model__MParameter__mtype]))(var68) /* mtype on <var68:nullable Object(MParameter)>*/;
-var_t = var69;
-var70 = ((long (*)(val*))(var_msignature->class->vft[COLOR_model__MSignature__vararg_rank]))(var_msignature) /* vararg_rank on <var_msignature:MSignature>*/;
-{ /* Inline kernel#Int#== (var_i,var70) */
-var73 = var_i == var70;
-var71 = var73;
-goto RET_LABEL72;
-RET_LABEL72:(void)0;
-}
-if (var71){
-var74 = 1;
-{ /* Inline kernel#Int#+ (var_i,var74) */
-var77 = var_i + var74;
-var75 = var77;
-goto RET_LABEL76;
-RET_LABEL76:(void)0;
-}
-var78 = ((val* (*)(val*, long))(var_arguments->class->vft[COLOR_abstract_collection__SequenceRead___91d_93d]))(var_arguments, var75) /* [] on <var_arguments:Array[RuntimeVariable]>*/;
-var79 = ((val* (*)(val*))(var78->class->vft[COLOR_abstract_compiler__RuntimeVariable__mcasttype]))(var78) /* mcasttype on <var78:nullable Object(RuntimeVariable)>*/;
-var_t = var79;
+var72 = ((short int (*)(val*))(var71->class->vft[COLOR_abstract_collection__Iterator__is_ok]))(var71) /* is_ok on <var71:Iterator[nullable Object]>*/;
+if(!var72) break;
+var73 = ((val* (*)(val*))(var71->class->vft[COLOR_abstract_collection__Iterator__item]))(var71) /* item on <var71:Iterator[nullable Object]>*/;
+var74 = ((struct instance_kernel__Int*)var73)->value; /* autounbox from nullable Object to Int */;
+var_i = var74;
+var75 = 1;
+{ /* Inline kernel#Int#+ (var_i,var75) */
+var78 = var_i + var75;
+var76 = var78;
+goto RET_LABEL77;
+RET_LABEL77:(void)0;
+}
+var79 = ((val* (*)(val*, long))(var_arguments->class->vft[COLOR_abstract_collection__SequenceRead___91d_93d]))(var_arguments, var76) /* [] on <var_arguments:Array[RuntimeVariable]>*/;
+var_a = var79;
+var80 = ((val* (*)(val*))(var_msignature->class->vft[COLOR_model__MSignature__mparameters]))(var_msignature) /* mparameters on <var_msignature:MSignature>*/;
+var81 = ((val* (*)(val*, long))(var80->class->vft[COLOR_abstract_collection__SequenceRead___91d_93d]))(var80, var_i) /* [] on <var80:Array[MParameter]>*/;
+var82 = ((val* (*)(val*))(var81->class->vft[COLOR_model__MParameter__mtype]))(var81) /* mtype on <var81:nullable Object(MParameter)>*/;
+var_t = var82;
+var83 = ((long (*)(val*))(var_msignature->class->vft[COLOR_model__MSignature__vararg_rank]))(var_msignature) /* vararg_rank on <var_msignature:MSignature>*/;
+{ /* Inline kernel#Int#== (var_i,var83) */
+var86 = var_i == var83;
+var84 = var86;
+goto RET_LABEL85;
+RET_LABEL85:(void)0;
+}
+if (var84){
+var87 = 1;
+{ /* Inline kernel#Int#+ (var_i,var87) */
+var90 = var_i + var87;
+var88 = var90;
+goto RET_LABEL89;
+RET_LABEL89:(void)0;
+}
+var91 = ((val* (*)(val*, long))(var_arguments->class->vft[COLOR_abstract_collection__SequenceRead___91d_93d]))(var_arguments, var88) /* [] on <var_arguments:Array[RuntimeVariable]>*/;
+var92 = ((val* (*)(val*))(var91->class->vft[COLOR_abstract_compiler__RuntimeVariable__mcasttype]))(var91) /* mcasttype on <var91:nullable Object(RuntimeVariable)>*/;
+var_t = var92;
 } else {
 }
-if (varonce80) {
-var81 = varonce80;
+if (varonce93) {
+var94 = varonce93;
 } else {
-var82 = ", ";
-var83 = 2;
-var84 = string__NativeString__to_s_with_length(var82, var83);
-var81 = var84;
-varonce80 = var81;
+var95 = ", ";
+var96 = 2;
+var97 = string__NativeString__to_s_with_length(var95, var96);
+var94 = var97;
+varonce93 = var94;
 }
-var85 = ((val* (*)(val*))(var_t->class->vft[COLOR_abstract_compiler__MType__ctype]))(var_t) /* ctype on <var_t:MType>*/;
-var86 = NEW_array__Array(&type_array__Arraykernel__Object);
-{ /* var86 = array_instance Array[Object] */
-var87 = 2;
-var88 = NEW_array__NativeArray(var87, &type_array__NativeArraykernel__Object);
-((struct instance_array__NativeArray*)var88)->values[0] = (val*) var81;
-((struct instance_array__NativeArray*)var88)->values[1] = (val*) var85;
-((void (*)(val*, val*, long))(var86->class->vft[COLOR_array__Array__with_native]))(var86, var88, var87) /* with_native on <var86:Array[Object]>*/;
-CHECK_NEW_array__Array(var86);
+var98 = ((val* (*)(val*))(var_t->class->vft[COLOR_abstract_compiler__MType__ctype]))(var_t) /* ctype on <var_t:MType>*/;
+var99 = NEW_array__Array(&type_array__Arraykernel__Object);
+{ /* var99 = array_instance Array[Object] */
+var100 = 2;
+var101 = NEW_array__NativeArray(var100, &type_array__NativeArraykernel__Object);
+((struct instance_array__NativeArray*)var101)->values[0] = (val*) var94;
+((struct instance_array__NativeArray*)var101)->values[1] = (val*) var98;
+((void (*)(val*, val*, long))(var99->class->vft[COLOR_array__Array__with_native]))(var99, var101, var100) /* with_native on <var99:Array[Object]>*/;
+}
+var102 = ((val* (*)(val*))(var99->class->vft[COLOR_string__Object__to_s]))(var99) /* to_s on <var99:Array[Object]>*/;
+((void (*)(val*, val*))(var_s->class->vft[COLOR_abstract_collection__Sequence__append]))(var_s, var102) /* append on <var_s:Buffer>*/;
+var103 = ((val* (*)(val*, val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__autobox]))(self, var_a, var_t) /* autobox on <self:SeparateCompilerVisitor>*/;
+var_a = var103;
+if (varonce104) {
+var105 = varonce104;
+} else {
+var106 = ", ";
+var107 = 2;
+var108 = string__NativeString__to_s_with_length(var106, var107);
+var105 = var108;
+varonce104 = var105;
+}
+var109 = NEW_array__Array(&type_array__Arraykernel__Object);
+{ /* var109 = array_instance Array[Object] */
+var110 = 2;
+var111 = NEW_array__NativeArray(var110, &type_array__NativeArraykernel__Object);
+((struct instance_array__NativeArray*)var111)->values[0] = (val*) var105;
+((struct instance_array__NativeArray*)var111)->values[1] = (val*) var_a;
+((void (*)(val*, val*, long))(var109->class->vft[COLOR_array__Array__with_native]))(var109, var111, var110) /* with_native on <var109:Array[Object]>*/;
+}
+var112 = ((val* (*)(val*))(var109->class->vft[COLOR_string__Object__to_s]))(var109) /* to_s on <var109:Array[Object]>*/;
+((void (*)(val*, val*))(var_ss->class->vft[COLOR_abstract_collection__Sequence__append]))(var_ss, var112) /* append on <var_ss:Buffer>*/;
+CONTINUE_label: (void)0;
+((void (*)(val*))(var71->class->vft[COLOR_abstract_collection__Iterator__next]))(var71) /* next on <var71:Iterator[nullable Object]>*/;
+}
+BREAK_label: (void)0;
+var115 = ((val* (*)(val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__compiler]))(self) /* compiler on <self:SeparateCompilerVisitor>*/;
+var116 = ((val* (*)(val*))(var115->class->vft[COLOR_abstract_compiler__AbstractCompiler__modelbuilder]))(var115) /* modelbuilder on <var115:AbstractCompiler(SeparateCompiler)>*/;
+var117 = ((val* (*)(val*))(var116->class->vft[COLOR_modelbuilder__ModelBuilder__toolcontext]))(var116) /* toolcontext on <var116:ModelBuilder>*/;
+var118 = ((val* (*)(val*))(var117->class->vft[COLOR_abstract_compiler__ToolContext__opt_no_check_other]))(var117) /* opt_no_check_other on <var117:ToolContext>*/;
+var119 = ((val* (*)(val*))(var118->class->vft[COLOR_opts__Option__value]))(var118) /* value on <var118:OptionBool>*/;
+var120 = ((struct instance_kernel__Bool*)var119)->value; /* autounbox from nullable Object to Bool */;
+var121 = !var120;
+var_ = var121;
+if (var121){
+var114 = var_;
+} else {
+var122 = ((val* (*)(val*))(var_mmethod->class->vft[COLOR_model__MProperty__name]))(var_mmethod) /* name on <var_mmethod:MMethod>*/;
+if (varonce123) {
+var124 = varonce123;
+} else {
+var125 = "==";
+var126 = 2;
+var127 = string__NativeString__to_s_with_length(var125, var126);
+var124 = var127;
+varonce123 = var124;
+}
+var128 = ((short int (*)(val*, val*))(var122->class->vft[COLOR_kernel__Object___61d_61d]))(var122, var124) /* == on <var122:String>*/;
+var114 = var128;
+}
+var_129 = var114;
+if (var114){
+var113 = var_129;
+} else {
+var130 = ((val* (*)(val*))(var_mmethod->class->vft[COLOR_model__MProperty__name]))(var_mmethod) /* name on <var_mmethod:MMethod>*/;
+if (varonce131) {
+var132 = varonce131;
+} else {
+var133 = "!=";
+var134 = 2;
+var135 = string__NativeString__to_s_with_length(var133, var134);
+var132 = var135;
+varonce131 = var132;
 }
-var89 = ((val* (*)(val*))(var86->class->vft[COLOR_string__Object__to_s]))(var86) /* to_s on <var86:Array[Object]>*/;
-((void (*)(val*, val*))(var_s->class->vft[COLOR_abstract_collection__Sequence__append]))(var_s, var89) /* append on <var_s:Buffer>*/;
-var90 = ((val* (*)(val*, val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__autobox]))(self, var_a, var_t) /* autobox on <self:SeparateCompilerVisitor>*/;
-var_a = var90;
-if (varonce91) {
-var92 = varonce91;
-} else {
-var93 = ", ";
-var94 = 2;
-var95 = string__NativeString__to_s_with_length(var93, var94);
-var92 = var95;
-varonce91 = var92;
-}
-var96 = NEW_array__Array(&type_array__Arraykernel__Object);
-{ /* var96 = array_instance Array[Object] */
-var97 = 2;
-var98 = NEW_array__NativeArray(var97, &type_array__NativeArraykernel__Object);
-((struct instance_array__NativeArray*)var98)->values[0] = (val*) var92;
-((struct instance_array__NativeArray*)var98)->values[1] = (val*) var_a;
-((void (*)(val*, val*, long))(var96->class->vft[COLOR_array__Array__with_native]))(var96, var98, var97) /* with_native on <var96:Array[Object]>*/;
-CHECK_NEW_array__Array(var96);
-}
-var99 = ((val* (*)(val*))(var96->class->vft[COLOR_string__Object__to_s]))(var96) /* to_s on <var96:Array[Object]>*/;
-((void (*)(val*, val*))(var_ss->class->vft[COLOR_abstract_collection__Sequence__append]))(var_ss, var99) /* append on <var_ss:Buffer>*/;
-CONTINUE_label: (void)0;
-((void (*)(val*))(var58->class->vft[COLOR_abstract_collection__Iterator__next]))(var58) /* next on <var58:Iterator[nullable Object]>*/;
+var136 = ((short int (*)(val*, val*))(var130->class->vft[COLOR_kernel__Object___61d_61d]))(var130, var132) /* == on <var130:String>*/;
+var113 = var136;
 }
-BREAK_label: (void)0;
-var102 = ((val* (*)(val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__compiler]))(self) /* compiler on <self:SeparateCompilerVisitor>*/;
-var103 = ((val* (*)(val*))(var102->class->vft[COLOR_abstract_compiler__AbstractCompiler__modelbuilder]))(var102) /* modelbuilder on <var102:AbstractCompiler(SeparateCompiler)>*/;
-var104 = ((val* (*)(val*))(var103->class->vft[COLOR_modelbuilder__ModelBuilder__toolcontext]))(var103) /* toolcontext on <var103:ModelBuilder>*/;
-var105 = ((val* (*)(val*))(var104->class->vft[COLOR_abstract_compiler__ToolContext__opt_no_check_other]))(var104) /* opt_no_check_other on <var104:ToolContext>*/;
-var106 = ((val* (*)(val*))(var105->class->vft[COLOR_opts__Option__value]))(var105) /* value on <var105:OptionBool>*/;
-var107 = ((struct instance_kernel__Bool*)var106)->value; /* autounbox from nullable Object to Bool */;
-var108 = !var107;
-var_ = var108;
-if (var108){
-var101 = var_;
-} else {
-var109 = ((val* (*)(val*))(var_mmethod->class->vft[COLOR_model__MProperty__name]))(var_mmethod) /* name on <var_mmethod:MMethod>*/;
-if (varonce110) {
-var111 = varonce110;
-} else {
-var112 = "==";
-var113 = 2;
-var114 = string__NativeString__to_s_with_length(var112, var113);
-var111 = var114;
-varonce110 = var111;
-}
-var115 = ((short int (*)(val*, val*))(var109->class->vft[COLOR_kernel__Object___61d_61d]))(var109, var111) /* == on <var109:String>*/;
-var101 = var115;
-}
-var_116 = var101;
-if (var101){
-var100 = var_116;
-} else {
-var117 = ((val* (*)(val*))(var_mmethod->class->vft[COLOR_model__MProperty__name]))(var_mmethod) /* name on <var_mmethod:MMethod>*/;
-if (varonce118) {
-var119 = varonce118;
-} else {
-var120 = "!=";
-var121 = 2;
-var122 = string__NativeString__to_s_with_length(var120, var121);
-var119 = var122;
-varonce118 = var119;
-}
-var123 = ((short int (*)(val*, val*))(var117->class->vft[COLOR_kernel__Object___61d_61d]))(var117, var119) /* == on <var117:String>*/;
-var100 = var123;
-}
-var_consider_null = var100;
-var125 = ((val* (*)(val*))(var_recv->class->vft[COLOR_abstract_compiler__RuntimeVariable__mcasttype]))(var_recv) /* mcasttype on <var_recv:RuntimeVariable>*/;
-/* <var125:MType> isa MNullableType */
+var_consider_null = var113;
+var138 = ((val* (*)(val*))(var_recv->class->vft[COLOR_abstract_compiler__RuntimeVariable__mcasttype]))(var_recv) /* mcasttype on <var_recv:RuntimeVariable>*/;
+/* <var138:MType> isa MNullableType */
 cltype = type_model__MNullableType.color;
 idtype = type_model__MNullableType.id;
-if(cltype >= var125->type->table_size) {
-var126 = 0;
+if(cltype >= var138->type->table_size) {
+var139 = 0;
 } else {
-var126 = var125->type->type_table[cltype] == idtype;
+var139 = var138->type->type_table[cltype] == idtype;
 }
-var_127 = var126;
-if (var126){
-var124 = var_consider_null;
+var_140 = var139;
+if (var139){
+var137 = var_consider_null;
 } else {
-var124 = var_127;
+var137 = var_140;
 }
-var_maybenull = var124;
+var_maybenull = var137;
 if (var_maybenull){
-if (varonce128) {
-var129 = varonce128;
+if (varonce141) {
+var142 = varonce141;
 } else {
-var130 = "if (";
-var131 = 4;
-var132 = string__NativeString__to_s_with_length(var130, var131);
-var129 = var132;
-varonce128 = var129;
+var143 = "if (";
+var144 = 4;
+var145 = string__NativeString__to_s_with_length(var143, var144);
+var142 = var145;
+varonce141 = var142;
 }
-if (varonce133) {
-var134 = varonce133;
+if (varonce146) {
+var147 = varonce146;
 } else {
-var135 = " == NULL) {";
-var136 = 11;
-var137 = string__NativeString__to_s_with_length(var135, var136);
-var134 = var137;
-varonce133 = var134;
-}
-var138 = NEW_array__Array(&type_array__Arraykernel__Object);
-{ /* var138 = array_instance Array[Object] */
-var139 = 3;
-var140 = NEW_array__NativeArray(var139, &type_array__NativeArraykernel__Object);
-((struct instance_array__NativeArray*)var140)->values[0] = (val*) var129;
-((struct instance_array__NativeArray*)var140)->values[1] = (val*) var_recv;
-((struct instance_array__NativeArray*)var140)->values[2] = (val*) var134;
-((void (*)(val*, val*, long))(var138->class->vft[COLOR_array__Array__with_native]))(var138, var140, var139) /* with_native on <var138:Array[Object]>*/;
-CHECK_NEW_array__Array(var138);
+var148 = " == NULL) {";
+var149 = 11;
+var150 = string__NativeString__to_s_with_length(var148, var149);
+var147 = var150;
+varonce146 = var147;
 }
-var141 = ((val* (*)(val*))(var138->class->vft[COLOR_string__Object__to_s]))(var138) /* to_s on <var138:Array[Object]>*/;
-((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var141) /* add on <self:SeparateCompilerVisitor>*/;
-var142 = ((val* (*)(val*))(var_mmethod->class->vft[COLOR_model__MProperty__name]))(var_mmethod) /* name on <var_mmethod:MMethod>*/;
-if (varonce143) {
-var144 = varonce143;
+var151 = NEW_array__Array(&type_array__Arraykernel__Object);
+{ /* var151 = array_instance Array[Object] */
+var152 = 3;
+var153 = NEW_array__NativeArray(var152, &type_array__NativeArraykernel__Object);
+((struct instance_array__NativeArray*)var153)->values[0] = (val*) var142;
+((struct instance_array__NativeArray*)var153)->values[1] = (val*) var_recv;
+((struct instance_array__NativeArray*)var153)->values[2] = (val*) var147;
+((void (*)(val*, val*, long))(var151->class->vft[COLOR_array__Array__with_native]))(var151, var153, var152) /* with_native on <var151:Array[Object]>*/;
+}
+var154 = ((val* (*)(val*))(var151->class->vft[COLOR_string__Object__to_s]))(var151) /* to_s on <var151:Array[Object]>*/;
+((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var154) /* add on <self:SeparateCompilerVisitor>*/;
+var155 = ((val* (*)(val*))(var_mmethod->class->vft[COLOR_model__MProperty__name]))(var_mmethod) /* name on <var_mmethod:MMethod>*/;
+if (varonce156) {
+var157 = varonce156;
 } else {
-var145 = "==";
-var146 = 2;
-var147 = string__NativeString__to_s_with_length(var145, var146);
-var144 = var147;
-varonce143 = var144;
+var158 = "==";
+var159 = 2;
+var160 = string__NativeString__to_s_with_length(var158, var159);
+var157 = var160;
+varonce156 = var157;
 }
-var148 = ((short int (*)(val*, val*))(var142->class->vft[COLOR_kernel__Object___61d_61d]))(var142, var144) /* == on <var142:String>*/;
-if (var148){
-var149 = NULL;
-if (var_res36 == NULL) {
-var150 = 0; /* is null */
+var161 = ((short int (*)(val*, val*))(var155->class->vft[COLOR_kernel__Object___61d_61d]))(var155, var157) /* == on <var155:String>*/;
+if (var161){
+var162 = NULL;
+if (var_res == NULL) {
+var163 = 0; /* is null */
 } else {
-var150 = 1; /* arg is null and recv is not */
+var163 = 1; /* arg is null and recv is not */
 }
-if (!var150) {
+if (!var163) {
 fprintf(stderr, "Runtime error: %s", "Assert failed");
-fprintf(stderr, " (%s:%d)\n", "src/separate_compiler.nit", 1026);
-exit(1);
-}
-var151 = 1;
-var152 = ((val* (*)(val*, long))(var_arguments->class->vft[COLOR_abstract_collection__SequenceRead___91d_93d]))(var_arguments, var151) /* [] on <var_arguments:Array[RuntimeVariable]>*/;
-var_arg = var152;
-var153 = ((val* (*)(val*))(var_arg->class->vft[COLOR_abstract_compiler__RuntimeVariable__mcasttype]))(var_arg) /* mcasttype on <var_arg:RuntimeVariable>*/;
-/* <var153:MType> isa MNullableType */
-cltype155 = type_model__MNullableType.color;
-idtype156 = type_model__MNullableType.id;
-if(cltype155 >= var153->type->table_size) {
-var154 = 0;
-} else {
-var154 = var153->type->type_table[cltype155] == idtype156;
-}
-if (var154){
-if (varonce157) {
-var158 = varonce157;
-} else {
-var159 = " = (";
-var160 = 4;
-var161 = string__NativeString__to_s_with_length(var159, var160);
-var158 = var161;
-varonce157 = var158;
-}
-if (varonce162) {
-var163 = varonce162;
-} else {
-var164 = " == NULL);";
-var165 = 10;
-var166 = string__NativeString__to_s_with_length(var164, var165);
-var163 = var166;
-varonce162 = var163;
+fprintf(stderr, " (%s:%d)\n", "src/separate_compiler.nit", 1047);
+show_backtrace(1);
+}
+var164 = 1;
+var165 = ((val* (*)(val*, long))(var_arguments->class->vft[COLOR_abstract_collection__SequenceRead___91d_93d]))(var_arguments, var164) /* [] on <var_arguments:Array[RuntimeVariable]>*/;
+var_arg = var165;
+var166 = ((val* (*)(val*))(var_arg->class->vft[COLOR_abstract_compiler__RuntimeVariable__mcasttype]))(var_arg) /* mcasttype on <var_arg:RuntimeVariable>*/;
+/* <var166:MType> isa MNullableType */
+cltype168 = type_model__MNullableType.color;
+idtype169 = type_model__MNullableType.id;
+if(cltype168 >= var166->type->table_size) {
+var167 = 0;
+} else {
+var167 = var166->type->type_table[cltype168] == idtype169;
+}
+if (var167){
+if (varonce170) {
+var171 = varonce170;
+} else {
+var172 = " = (";
+var173 = 4;
+var174 = string__NativeString__to_s_with_length(var172, var173);
+var171 = var174;
+varonce170 = var171;
 }
-var167 = NEW_array__Array(&type_array__Arraykernel__Object);
-{ /* var167 = array_instance Array[Object] */
-var168 = 4;
-var169 = NEW_array__NativeArray(var168, &type_array__NativeArraykernel__Object);
-((struct instance_array__NativeArray*)var169)->values[0] = (val*) var_res36;
-((struct instance_array__NativeArray*)var169)->values[1] = (val*) var158;
-((struct instance_array__NativeArray*)var169)->values[2] = (val*) var_arg;
-((struct instance_array__NativeArray*)var169)->values[3] = (val*) var163;
-((void (*)(val*, val*, long))(var167->class->vft[COLOR_array__Array__with_native]))(var167, var169, var168) /* with_native on <var167:Array[Object]>*/;
-CHECK_NEW_array__Array(var167);
-}
-var170 = ((val* (*)(val*))(var167->class->vft[COLOR_string__Object__to_s]))(var167) /* to_s on <var167:Array[Object]>*/;
-((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var170) /* add on <self:SeparateCompilerVisitor>*/;
-} else {
-var171 = ((val* (*)(val*))(var_arg->class->vft[COLOR_abstract_compiler__RuntimeVariable__mcasttype]))(var_arg) /* mcasttype on <var_arg:RuntimeVariable>*/;
-/* <var171:MType> isa MNullType */
-cltype173 = type_model__MNullType.color;
-idtype174 = type_model__MNullType.id;
-if(cltype173 >= var171->type->table_size) {
-var172 = 0;
-} else {
-var172 = var171->type->type_table[cltype173] == idtype174;
-}
-if (var172){
 if (varonce175) {
 var176 = varonce175;
 } else {
-var177 = " = 1; /* is null */";
-var178 = 19;
+var177 = " == NULL);";
+var178 = 10;
 var179 = string__NativeString__to_s_with_length(var177, var178);
 var176 = var179;
 varonce175 = var176;
 }
 var180 = NEW_array__Array(&type_array__Arraykernel__Object);
 { /* var180 = array_instance Array[Object] */
-var181 = 2;
+var181 = 4;
 var182 = NEW_array__NativeArray(var181, &type_array__NativeArraykernel__Object);
-((struct instance_array__NativeArray*)var182)->values[0] = (val*) var_res36;
-((struct instance_array__NativeArray*)var182)->values[1] = (val*) var176;
+((struct instance_array__NativeArray*)var182)->values[0] = (val*) var_res;
+((struct instance_array__NativeArray*)var182)->values[1] = (val*) var171;
+((struct instance_array__NativeArray*)var182)->values[2] = (val*) var_arg;
+((struct instance_array__NativeArray*)var182)->values[3] = (val*) var176;
 ((void (*)(val*, val*, long))(var180->class->vft[COLOR_array__Array__with_native]))(var180, var182, var181) /* with_native on <var180:Array[Object]>*/;
-CHECK_NEW_array__Array(var180);
 }
 var183 = ((val* (*)(val*))(var180->class->vft[COLOR_string__Object__to_s]))(var180) /* to_s on <var180:Array[Object]>*/;
 ((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var183) /* add on <self:SeparateCompilerVisitor>*/;
 } else {
-if (varonce184) {
-var185 = varonce184;
+var184 = ((val* (*)(val*))(var_arg->class->vft[COLOR_abstract_compiler__RuntimeVariable__mcasttype]))(var_arg) /* mcasttype on <var_arg:RuntimeVariable>*/;
+/* <var184:MType> isa MNullType */
+cltype186 = type_model__MNullType.color;
+idtype187 = type_model__MNullType.id;
+if(cltype186 >= var184->type->table_size) {
+var185 = 0;
 } else {
-var186 = " = 0; /* ";
-var187 = 9;
-var188 = string__NativeString__to_s_with_length(var186, var187);
-var185 = var188;
-varonce184 = var185;
+var185 = var184->type->type_table[cltype186] == idtype187;
+}
+if (var185){
+if (varonce188) {
+var189 = varonce188;
+} else {
+var190 = " = 1; /* is null */";
+var191 = 19;
+var192 = string__NativeString__to_s_with_length(var190, var191);
+var189 = var192;
+varonce188 = var189;
+}
+var193 = NEW_array__Array(&type_array__Arraykernel__Object);
+{ /* var193 = array_instance Array[Object] */
+var194 = 2;
+var195 = NEW_array__NativeArray(var194, &type_array__NativeArraykernel__Object);
+((struct instance_array__NativeArray*)var195)->values[0] = (val*) var_res;
+((struct instance_array__NativeArray*)var195)->values[1] = (val*) var189;
+((void (*)(val*, val*, long))(var193->class->vft[COLOR_array__Array__with_native]))(var193, var195, var194) /* with_native on <var193:Array[Object]>*/;
+}
+var196 = ((val* (*)(val*))(var193->class->vft[COLOR_string__Object__to_s]))(var193) /* to_s on <var193:Array[Object]>*/;
+((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var196) /* add on <self:SeparateCompilerVisitor>*/;
+} else {
+if (varonce197) {
+var198 = varonce197;
+} else {
+var199 = " = 0; /* ";
+var200 = 9;
+var201 = string__NativeString__to_s_with_length(var199, var200);
+var198 = var201;
+varonce197 = var198;
 }
-var189 = ((val* (*)(val*))(var_arg->class->vft[COLOR_string__Object__inspect]))(var_arg) /* inspect on <var_arg:RuntimeVariable>*/;
-if (varonce190) {
-var191 = varonce190;
+var202 = ((val* (*)(val*))(var_arg->class->vft[COLOR_string__Object__inspect]))(var_arg) /* inspect on <var_arg:RuntimeVariable>*/;
+if (varonce203) {
+var204 = varonce203;
 } else {
-var192 = " cannot be null */";
-var193 = 18;
-var194 = string__NativeString__to_s_with_length(var192, var193);
-var191 = var194;
-varonce190 = var191;
+var205 = " cannot be null */";
+var206 = 18;
+var207 = string__NativeString__to_s_with_length(var205, var206);
+var204 = var207;
+varonce203 = var204;
 }
-var195 = NEW_array__Array(&type_array__Arraykernel__Object);
-{ /* var195 = array_instance Array[Object] */
-var196 = 4;
-var197 = NEW_array__NativeArray(var196, &type_array__NativeArraykernel__Object);
-((struct instance_array__NativeArray*)var197)->values[0] = (val*) var_res36;
-((struct instance_array__NativeArray*)var197)->values[1] = (val*) var185;
-((struct instance_array__NativeArray*)var197)->values[2] = (val*) var189;
-((struct instance_array__NativeArray*)var197)->values[3] = (val*) var191;
-((void (*)(val*, val*, long))(var195->class->vft[COLOR_array__Array__with_native]))(var195, var197, var196) /* with_native on <var195:Array[Object]>*/;
-CHECK_NEW_array__Array(var195);
+var208 = NEW_array__Array(&type_array__Arraykernel__Object);
+{ /* var208 = array_instance Array[Object] */
+var209 = 4;
+var210 = NEW_array__NativeArray(var209, &type_array__NativeArraykernel__Object);
+((struct instance_array__NativeArray*)var210)->values[0] = (val*) var_res;
+((struct instance_array__NativeArray*)var210)->values[1] = (val*) var198;
+((struct instance_array__NativeArray*)var210)->values[2] = (val*) var202;
+((struct instance_array__NativeArray*)var210)->values[3] = (val*) var204;
+((void (*)(val*, val*, long))(var208->class->vft[COLOR_array__Array__with_native]))(var208, var210, var209) /* with_native on <var208:Array[Object]>*/;
 }
-var198 = ((val* (*)(val*))(var195->class->vft[COLOR_string__Object__to_s]))(var195) /* to_s on <var195:Array[Object]>*/;
-((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var198) /* add on <self:SeparateCompilerVisitor>*/;
+var211 = ((val* (*)(val*))(var208->class->vft[COLOR_string__Object__to_s]))(var208) /* to_s on <var208:Array[Object]>*/;
+((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var211) /* add on <self:SeparateCompilerVisitor>*/;
 }
 }
 } else {
-var199 = ((val* (*)(val*))(var_mmethod->class->vft[COLOR_model__MProperty__name]))(var_mmethod) /* name on <var_mmethod:MMethod>*/;
-if (varonce200) {
-var201 = varonce200;
+var212 = ((val* (*)(val*))(var_mmethod->class->vft[COLOR_model__MProperty__name]))(var_mmethod) /* name on <var_mmethod:MMethod>*/;
+if (varonce213) {
+var214 = varonce213;
 } else {
-var202 = "!=";
-var203 = 2;
-var204 = string__NativeString__to_s_with_length(var202, var203);
-var201 = var204;
-varonce200 = var201;
+var215 = "!=";
+var216 = 2;
+var217 = string__NativeString__to_s_with_length(var215, var216);
+var214 = var217;
+varonce213 = var214;
 }
-var205 = ((short int (*)(val*, val*))(var199->class->vft[COLOR_kernel__Object___61d_61d]))(var199, var201) /* == on <var199:String>*/;
-if (var205){
-var206 = NULL;
-if (var_res36 == NULL) {
-var207 = 0; /* is null */
+var218 = ((short int (*)(val*, val*))(var212->class->vft[COLOR_kernel__Object___61d_61d]))(var212, var214) /* == on <var212:String>*/;
+if (var218){
+var219 = NULL;
+if (var_res == NULL) {
+var220 = 0; /* is null */
 } else {
-var207 = 1; /* arg is null and recv is not */
+var220 = 1; /* arg is null and recv is not */
 }
-if (!var207) {
+if (!var220) {
 fprintf(stderr, "Runtime error: %s", "Assert failed");
-fprintf(stderr, " (%s:%d)\n", "src/separate_compiler.nit", 1036);
-exit(1);
-}
-var208 = 1;
-var209 = ((val* (*)(val*, long))(var_arguments->class->vft[COLOR_abstract_collection__SequenceRead___91d_93d]))(var_arguments, var208) /* [] on <var_arguments:Array[RuntimeVariable]>*/;
-var_arg210 = var209;
-var211 = ((val* (*)(val*))(var_arg210->class->vft[COLOR_abstract_compiler__RuntimeVariable__mcasttype]))(var_arg210) /* mcasttype on <var_arg210:RuntimeVariable>*/;
-/* <var211:MType> isa MNullableType */
-cltype213 = type_model__MNullableType.color;
-idtype214 = type_model__MNullableType.id;
-if(cltype213 >= var211->type->table_size) {
-var212 = 0;
-} else {
-var212 = var211->type->type_table[cltype213] == idtype214;
-}
-if (var212){
-if (varonce215) {
-var216 = varonce215;
-} else {
-var217 = " = (";
-var218 = 4;
-var219 = string__NativeString__to_s_with_length(var217, var218);
-var216 = var219;
-varonce215 = var216;
-}
-if (varonce220) {
-var221 = varonce220;
-} else {
-var222 = " != NULL);";
-var223 = 10;
-var224 = string__NativeString__to_s_with_length(var222, var223);
-var221 = var224;
-varonce220 = var221;
-}
-var225 = NEW_array__Array(&type_array__Arraykernel__Object);
-{ /* var225 = array_instance Array[Object] */
-var226 = 4;
-var227 = NEW_array__NativeArray(var226, &type_array__NativeArraykernel__Object);
-((struct instance_array__NativeArray*)var227)->values[0] = (val*) var_res36;
-((struct instance_array__NativeArray*)var227)->values[1] = (val*) var216;
-((struct instance_array__NativeArray*)var227)->values[2] = (val*) var_arg210;
-((struct instance_array__NativeArray*)var227)->values[3] = (val*) var221;
-((void (*)(val*, val*, long))(var225->class->vft[COLOR_array__Array__with_native]))(var225, var227, var226) /* with_native on <var225:Array[Object]>*/;
-CHECK_NEW_array__Array(var225);
-}
-var228 = ((val* (*)(val*))(var225->class->vft[COLOR_string__Object__to_s]))(var225) /* to_s on <var225:Array[Object]>*/;
-((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var228) /* add on <self:SeparateCompilerVisitor>*/;
-} else {
-var229 = ((val* (*)(val*))(var_arg210->class->vft[COLOR_abstract_compiler__RuntimeVariable__mcasttype]))(var_arg210) /* mcasttype on <var_arg210:RuntimeVariable>*/;
-/* <var229:MType> isa MNullType */
-cltype231 = type_model__MNullType.color;
-idtype232 = type_model__MNullType.id;
-if(cltype231 >= var229->type->table_size) {
-var230 = 0;
-} else {
-var230 = var229->type->type_table[cltype231] == idtype232;
-}
-if (var230){
+fprintf(stderr, " (%s:%d)\n", "src/separate_compiler.nit", 1057);
+show_backtrace(1);
+}
+var221 = 1;
+var222 = ((val* (*)(val*, long))(var_arguments->class->vft[COLOR_abstract_collection__SequenceRead___91d_93d]))(var_arguments, var221) /* [] on <var_arguments:Array[RuntimeVariable]>*/;
+var_arg223 = var222;
+var224 = ((val* (*)(val*))(var_arg223->class->vft[COLOR_abstract_compiler__RuntimeVariable__mcasttype]))(var_arg223) /* mcasttype on <var_arg223:RuntimeVariable>*/;
+/* <var224:MType> isa MNullableType */
+cltype226 = type_model__MNullableType.color;
+idtype227 = type_model__MNullableType.id;
+if(cltype226 >= var224->type->table_size) {
+var225 = 0;
+} else {
+var225 = var224->type->type_table[cltype226] == idtype227;
+}
+if (var225){
+if (varonce228) {
+var229 = varonce228;
+} else {
+var230 = " = (";
+var231 = 4;
+var232 = string__NativeString__to_s_with_length(var230, var231);
+var229 = var232;
+varonce228 = var229;
+}
 if (varonce233) {
 var234 = varonce233;
 } else {
-var235 = " = 0; /* is null */";
-var236 = 19;
+var235 = " != NULL);";
+var236 = 10;
 var237 = string__NativeString__to_s_with_length(var235, var236);
 var234 = var237;
 varonce233 = var234;
 }
 var238 = NEW_array__Array(&type_array__Arraykernel__Object);
 { /* var238 = array_instance Array[Object] */
-var239 = 2;
+var239 = 4;
 var240 = NEW_array__NativeArray(var239, &type_array__NativeArraykernel__Object);
-((struct instance_array__NativeArray*)var240)->values[0] = (val*) var_res36;
-((struct instance_array__NativeArray*)var240)->values[1] = (val*) var234;
+((struct instance_array__NativeArray*)var240)->values[0] = (val*) var_res;
+((struct instance_array__NativeArray*)var240)->values[1] = (val*) var229;
+((struct instance_array__NativeArray*)var240)->values[2] = (val*) var_arg223;
+((struct instance_array__NativeArray*)var240)->values[3] = (val*) var234;
 ((void (*)(val*, val*, long))(var238->class->vft[COLOR_array__Array__with_native]))(var238, var240, var239) /* with_native on <var238:Array[Object]>*/;
-CHECK_NEW_array__Array(var238);
 }
 var241 = ((val* (*)(val*))(var238->class->vft[COLOR_string__Object__to_s]))(var238) /* to_s on <var238:Array[Object]>*/;
 ((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var241) /* add on <self:SeparateCompilerVisitor>*/;
 } else {
-if (varonce242) {
-var243 = varonce242;
-} else {
-var244 = " = 1; /* ";
-var245 = 9;
-var246 = string__NativeString__to_s_with_length(var244, var245);
-var243 = var246;
-varonce242 = var243;
-}
-var247 = ((val* (*)(val*))(var_arg210->class->vft[COLOR_string__Object__inspect]))(var_arg210) /* inspect on <var_arg210:RuntimeVariable>*/;
-if (varonce248) {
-var249 = varonce248;
-} else {
-var250 = " cannot be null */";
-var251 = 18;
-var252 = string__NativeString__to_s_with_length(var250, var251);
-var249 = var252;
-varonce248 = var249;
-}
-var253 = NEW_array__Array(&type_array__Arraykernel__Object);
-{ /* var253 = array_instance Array[Object] */
-var254 = 4;
-var255 = NEW_array__NativeArray(var254, &type_array__NativeArraykernel__Object);
-((struct instance_array__NativeArray*)var255)->values[0] = (val*) var_res36;
-((struct instance_array__NativeArray*)var255)->values[1] = (val*) var243;
-((struct instance_array__NativeArray*)var255)->values[2] = (val*) var247;
-((struct instance_array__NativeArray*)var255)->values[3] = (val*) var249;
-((void (*)(val*, val*, long))(var253->class->vft[COLOR_array__Array__with_native]))(var253, var255, var254) /* with_native on <var253:Array[Object]>*/;
-CHECK_NEW_array__Array(var253);
-}
-var256 = ((val* (*)(val*))(var253->class->vft[COLOR_string__Object__to_s]))(var253) /* to_s on <var253:Array[Object]>*/;
-((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var256) /* add on <self:SeparateCompilerVisitor>*/;
+var242 = ((val* (*)(val*))(var_arg223->class->vft[COLOR_abstract_compiler__RuntimeVariable__mcasttype]))(var_arg223) /* mcasttype on <var_arg223:RuntimeVariable>*/;
+/* <var242:MType> isa MNullType */
+cltype244 = type_model__MNullType.color;
+idtype245 = type_model__MNullType.id;
+if(cltype244 >= var242->type->table_size) {
+var243 = 0;
+} else {
+var243 = var242->type->type_table[cltype244] == idtype245;
+}
+if (var243){
+if (varonce246) {
+var247 = varonce246;
+} else {
+var248 = " = 0; /* is null */";
+var249 = 19;
+var250 = string__NativeString__to_s_with_length(var248, var249);
+var247 = var250;
+varonce246 = var247;
+}
+var251 = NEW_array__Array(&type_array__Arraykernel__Object);
+{ /* var251 = array_instance Array[Object] */
+var252 = 2;
+var253 = NEW_array__NativeArray(var252, &type_array__NativeArraykernel__Object);
+((struct instance_array__NativeArray*)var253)->values[0] = (val*) var_res;
+((struct instance_array__NativeArray*)var253)->values[1] = (val*) var247;
+((void (*)(val*, val*, long))(var251->class->vft[COLOR_array__Array__with_native]))(var251, var253, var252) /* with_native on <var251:Array[Object]>*/;
+}
+var254 = ((val* (*)(val*))(var251->class->vft[COLOR_string__Object__to_s]))(var251) /* to_s on <var251:Array[Object]>*/;
+((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var254) /* add on <self:SeparateCompilerVisitor>*/;
+} else {
+if (varonce255) {
+var256 = varonce255;
+} else {
+var257 = " = 1; /* ";
+var258 = 9;
+var259 = string__NativeString__to_s_with_length(var257, var258);
+var256 = var259;
+varonce255 = var256;
+}
+var260 = ((val* (*)(val*))(var_arg223->class->vft[COLOR_string__Object__inspect]))(var_arg223) /* inspect on <var_arg223:RuntimeVariable>*/;
+if (varonce261) {
+var262 = varonce261;
+} else {
+var263 = " cannot be null */";
+var264 = 18;
+var265 = string__NativeString__to_s_with_length(var263, var264);
+var262 = var265;
+varonce261 = var262;
+}
+var266 = NEW_array__Array(&type_array__Arraykernel__Object);
+{ /* var266 = array_instance Array[Object] */
+var267 = 4;
+var268 = NEW_array__NativeArray(var267, &type_array__NativeArraykernel__Object);
+((struct instance_array__NativeArray*)var268)->values[0] = (val*) var_res;
+((struct instance_array__NativeArray*)var268)->values[1] = (val*) var256;
+((struct instance_array__NativeArray*)var268)->values[2] = (val*) var260;
+((struct instance_array__NativeArray*)var268)->values[3] = (val*) var262;
+((void (*)(val*, val*, long))(var266->class->vft[COLOR_array__Array__with_native]))(var266, var268, var267) /* with_native on <var266:Array[Object]>*/;
+}
+var269 = ((val* (*)(val*))(var266->class->vft[COLOR_string__Object__to_s]))(var266) /* to_s on <var266:Array[Object]>*/;
+((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var269) /* add on <self:SeparateCompilerVisitor>*/;
 }
 }
 } else {
-if (varonce257) {
-var258 = varonce257;
+if (varonce270) {
+var271 = varonce270;
 } else {
-var259 = "Reciever is null";
-var260 = 16;
-var261 = string__NativeString__to_s_with_length(var259, var260);
-var258 = var261;
-varonce257 = var258;
+var272 = "Receiver is null";
+var273 = 16;
+var274 = string__NativeString__to_s_with_length(var272, var273);
+var271 = var274;
+varonce270 = var271;
 }
-((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add_abort]))(self, var258) /* add_abort on <self:SeparateCompilerVisitor>*/;
+((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add_abort]))(self, var271) /* add_abort on <self:SeparateCompilerVisitor>*/;
 }
 }
-if (varonce262) {
-var263 = varonce262;
+if (varonce275) {
+var276 = varonce275;
 } else {
-var264 = "} else {";
-var265 = 8;
-var266 = string__NativeString__to_s_with_length(var264, var265);
-var263 = var266;
-varonce262 = var263;
+var277 = "} else {";
+var278 = 8;
+var279 = string__NativeString__to_s_with_length(var277, var278);
+var276 = var279;
+varonce275 = var276;
 }
-((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var263) /* add on <self:SeparateCompilerVisitor>*/;
+((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var276) /* add on <self:SeparateCompilerVisitor>*/;
 } else {
 }
-var268 = ((val* (*)(val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__compiler]))(self) /* compiler on <self:SeparateCompilerVisitor>*/;
-var269 = ((val* (*)(val*))(var268->class->vft[COLOR_abstract_compiler__AbstractCompiler__modelbuilder]))(var268) /* modelbuilder on <var268:AbstractCompiler(SeparateCompiler)>*/;
-var270 = ((val* (*)(val*))(var269->class->vft[COLOR_modelbuilder__ModelBuilder__toolcontext]))(var269) /* toolcontext on <var269:ModelBuilder>*/;
-var271 = ((val* (*)(val*))(var270->class->vft[COLOR_separate_compiler__ToolContext__opt_no_shortcut_equate]))(var270) /* opt_no_shortcut_equate on <var270:ToolContext>*/;
-var272 = ((val* (*)(val*))(var271->class->vft[COLOR_opts__Option__value]))(var271) /* value on <var271:OptionBool>*/;
-var273 = ((struct instance_kernel__Bool*)var272)->value; /* autounbox from nullable Object to Bool */;
-var274 = !var273;
-var_275 = var274;
-if (var274){
-var277 = ((val* (*)(val*))(var_mmethod->class->vft[COLOR_model__MProperty__name]))(var_mmethod) /* name on <var_mmethod:MMethod>*/;
-if (varonce278) {
-var279 = varonce278;
+var281 = ((val* (*)(val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__compiler]))(self) /* compiler on <self:SeparateCompilerVisitor>*/;
+var282 = ((val* (*)(val*))(var281->class->vft[COLOR_abstract_compiler__AbstractCompiler__modelbuilder]))(var281) /* modelbuilder on <var281:AbstractCompiler(SeparateCompiler)>*/;
+var283 = ((val* (*)(val*))(var282->class->vft[COLOR_modelbuilder__ModelBuilder__toolcontext]))(var282) /* toolcontext on <var282:ModelBuilder>*/;
+var284 = ((val* (*)(val*))(var283->class->vft[COLOR_separate_compiler__ToolContext__opt_no_shortcut_equate]))(var283) /* opt_no_shortcut_equate on <var283:ToolContext>*/;
+var285 = ((val* (*)(val*))(var284->class->vft[COLOR_opts__Option__value]))(var284) /* value on <var284:OptionBool>*/;
+var286 = ((struct instance_kernel__Bool*)var285)->value; /* autounbox from nullable Object to Bool */;
+var287 = !var286;
+var_288 = var287;
+if (var287){
+var290 = ((val* (*)(val*))(var_mmethod->class->vft[COLOR_model__MProperty__name]))(var_mmethod) /* name on <var_mmethod:MMethod>*/;
+if (varonce291) {
+var292 = varonce291;
 } else {
-var280 = "==";
-var281 = 2;
-var282 = string__NativeString__to_s_with_length(var280, var281);
-var279 = var282;
-varonce278 = var279;
+var293 = "==";
+var294 = 2;
+var295 = string__NativeString__to_s_with_length(var293, var294);
+var292 = var295;
+varonce291 = var292;
 }
-var283 = ((short int (*)(val*, val*))(var277->class->vft[COLOR_kernel__Object___61d_61d]))(var277, var279) /* == on <var277:String>*/;
-var_284 = var283;
-if (var283){
-var276 = var_284;
+var296 = ((short int (*)(val*, val*))(var290->class->vft[COLOR_kernel__Object___61d_61d]))(var290, var292) /* == on <var290:String>*/;
+var_297 = var296;
+if (var296){
+var289 = var_297;
 } else {
-var285 = ((val* (*)(val*))(var_mmethod->class->vft[COLOR_model__MProperty__name]))(var_mmethod) /* name on <var_mmethod:MMethod>*/;
-if (varonce286) {
-var287 = varonce286;
+var298 = ((val* (*)(val*))(var_mmethod->class->vft[COLOR_model__MProperty__name]))(var_mmethod) /* name on <var_mmethod:MMethod>*/;
+if (varonce299) {
+var300 = varonce299;
 } else {
-var288 = "!=";
-var289 = 2;
-var290 = string__NativeString__to_s_with_length(var288, var289);
-var287 = var290;
-varonce286 = var287;
+var301 = "!=";
+var302 = 2;
+var303 = string__NativeString__to_s_with_length(var301, var302);
+var300 = var303;
+varonce299 = var300;
 }
-var291 = ((short int (*)(val*, val*))(var285->class->vft[COLOR_kernel__Object___61d_61d]))(var285, var287) /* == on <var285:String>*/;
-var276 = var291;
+var304 = ((short int (*)(val*, val*))(var298->class->vft[COLOR_kernel__Object___61d_61d]))(var298, var300) /* == on <var298:String>*/;
+var289 = var304;
 }
-var267 = var276;
+var280 = var289;
 } else {
-var267 = var_275;
+var280 = var_288;
 }
-if (var267){
-var292 = NULL;
-if (var_res36 == NULL) {
-var293 = 0; /* is null */
+if (var280){
+var305 = NULL;
+if (var_res == NULL) {
+var306 = 0; /* is null */
 } else {
-var293 = 1; /* arg is null and recv is not */
+var306 = 1; /* arg is null and recv is not */
 }
-if (!var293) {
+if (!var306) {
 fprintf(stderr, "Runtime error: %s", "Assert failed");
-fprintf(stderr, " (%s:%d)\n", "src/separate_compiler.nit", 1051);
-exit(1);
-}
-var294 = 1;
-var295 = ((val* (*)(val*, long))(var_arguments->class->vft[COLOR_abstract_collection__SequenceRead___91d_93d]))(var_arguments, var294) /* [] on <var_arguments:Array[RuntimeVariable]>*/;
-var_arg296 = var295;
-var297 = ((val* (*)(val*))(var_arg296->class->vft[COLOR_abstract_compiler__RuntimeVariable__mcasttype]))(var_arg296) /* mcasttype on <var_arg296:RuntimeVariable>*/;
-/* <var297:MType> isa MNullType */
-cltype299 = type_model__MNullType.color;
-idtype300 = type_model__MNullType.id;
-if(cltype299 >= var297->type->table_size) {
-var298 = 0;
-} else {
-var298 = var297->type->type_table[cltype299] == idtype300;
-}
-if (var298){
-var301 = ((val* (*)(val*))(var_mmethod->class->vft[COLOR_model__MProperty__name]))(var_mmethod) /* name on <var_mmethod:MMethod>*/;
-if (varonce302) {
-var303 = varonce302;
-} else {
-var304 = "==";
-var305 = 2;
-var306 = string__NativeString__to_s_with_length(var304, var305);
-var303 = var306;
-varonce302 = var303;
-}
-var307 = ((short int (*)(val*, val*))(var301->class->vft[COLOR_kernel__Object___61d_61d]))(var301, var303) /* == on <var301:String>*/;
-if (var307){
-if (varonce308) {
-var309 = varonce308;
-} else {
-var310 = " = 0; /* arg is null but recv is not */";
-var311 = 39;
-var312 = string__NativeString__to_s_with_length(var310, var311);
-var309 = var312;
-varonce308 = var309;
-}
-var313 = NEW_array__Array(&type_array__Arraykernel__Object);
-{ /* var313 = array_instance Array[Object] */
-var314 = 2;
-var315 = NEW_array__NativeArray(var314, &type_array__NativeArraykernel__Object);
-((struct instance_array__NativeArray*)var315)->values[0] = (val*) var_res36;
-((struct instance_array__NativeArray*)var315)->values[1] = (val*) var309;
-((void (*)(val*, val*, long))(var313->class->vft[COLOR_array__Array__with_native]))(var313, var315, var314) /* with_native on <var313:Array[Object]>*/;
-CHECK_NEW_array__Array(var313);
-}
-var316 = ((val* (*)(val*))(var313->class->vft[COLOR_string__Object__to_s]))(var313) /* to_s on <var313:Array[Object]>*/;
-((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var316) /* add on <self:SeparateCompilerVisitor>*/;
-} else {
-if (varonce317) {
-var318 = varonce317;
-} else {
-var319 = " = 1; /* arg is null and recv is not */";
-var320 = 39;
-var321 = string__NativeString__to_s_with_length(var319, var320);
-var318 = var321;
-varonce317 = var318;
-}
-var322 = NEW_array__Array(&type_array__Arraykernel__Object);
-{ /* var322 = array_instance Array[Object] */
-var323 = 2;
-var324 = NEW_array__NativeArray(var323, &type_array__NativeArraykernel__Object);
-((struct instance_array__NativeArray*)var324)->values[0] = (val*) var_res36;
-((struct instance_array__NativeArray*)var324)->values[1] = (val*) var318;
-((void (*)(val*, val*, long))(var322->class->vft[COLOR_array__Array__with_native]))(var322, var324, var323) /* with_native on <var322:Array[Object]>*/;
-CHECK_NEW_array__Array(var322);
-}
-var325 = ((val* (*)(val*))(var322->class->vft[COLOR_string__Object__to_s]))(var322) /* to_s on <var322:Array[Object]>*/;
-((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var325) /* add on <self:SeparateCompilerVisitor>*/;
+fprintf(stderr, " (%s:%d)\n", "src/separate_compiler.nit", 1072);
+show_backtrace(1);
+}
+var307 = 1;
+var308 = ((val* (*)(val*, long))(var_arguments->class->vft[COLOR_abstract_collection__SequenceRead___91d_93d]))(var_arguments, var307) /* [] on <var_arguments:Array[RuntimeVariable]>*/;
+var_arg309 = var308;
+var310 = ((val* (*)(val*))(var_arg309->class->vft[COLOR_abstract_compiler__RuntimeVariable__mcasttype]))(var_arg309) /* mcasttype on <var_arg309:RuntimeVariable>*/;
+/* <var310:MType> isa MNullType */
+cltype312 = type_model__MNullType.color;
+idtype313 = type_model__MNullType.id;
+if(cltype312 >= var310->type->table_size) {
+var311 = 0;
+} else {
+var311 = var310->type->type_table[cltype312] == idtype313;
+}
+if (var311){
+var314 = ((val* (*)(val*))(var_mmethod->class->vft[COLOR_model__MProperty__name]))(var_mmethod) /* name on <var_mmethod:MMethod>*/;
+if (varonce315) {
+var316 = varonce315;
+} else {
+var317 = "==";
+var318 = 2;
+var319 = string__NativeString__to_s_with_length(var317, var318);
+var316 = var319;
+varonce315 = var316;
+}
+var320 = ((short int (*)(val*, val*))(var314->class->vft[COLOR_kernel__Object___61d_61d]))(var314, var316) /* == on <var314:String>*/;
+if (var320){
+if (varonce321) {
+var322 = varonce321;
+} else {
+var323 = " = 0; /* arg is null but recv is not */";
+var324 = 39;
+var325 = string__NativeString__to_s_with_length(var323, var324);
+var322 = var325;
+varonce321 = var322;
+}
+var326 = NEW_array__Array(&type_array__Arraykernel__Object);
+{ /* var326 = array_instance Array[Object] */
+var327 = 2;
+var328 = NEW_array__NativeArray(var327, &type_array__NativeArraykernel__Object);
+((struct instance_array__NativeArray*)var328)->values[0] = (val*) var_res;
+((struct instance_array__NativeArray*)var328)->values[1] = (val*) var322;
+((void (*)(val*, val*, long))(var326->class->vft[COLOR_array__Array__with_native]))(var326, var328, var327) /* with_native on <var326:Array[Object]>*/;
+}
+var329 = ((val* (*)(val*))(var326->class->vft[COLOR_string__Object__to_s]))(var326) /* to_s on <var326:Array[Object]>*/;
+((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var329) /* add on <self:SeparateCompilerVisitor>*/;
+} else {
+if (varonce330) {
+var331 = varonce330;
+} else {
+var332 = " = 1; /* arg is null and recv is not */";
+var333 = 39;
+var334 = string__NativeString__to_s_with_length(var332, var333);
+var331 = var334;
+varonce330 = var331;
+}
+var335 = NEW_array__Array(&type_array__Arraykernel__Object);
+{ /* var335 = array_instance Array[Object] */
+var336 = 2;
+var337 = NEW_array__NativeArray(var336, &type_array__NativeArraykernel__Object);
+((struct instance_array__NativeArray*)var337)->values[0] = (val*) var_res;
+((struct instance_array__NativeArray*)var337)->values[1] = (val*) var331;
+((void (*)(val*, val*, long))(var335->class->vft[COLOR_array__Array__with_native]))(var335, var337, var336) /* with_native on <var335:Array[Object]>*/;
+}
+var338 = ((val* (*)(val*))(var335->class->vft[COLOR_string__Object__to_s]))(var335) /* to_s on <var335:Array[Object]>*/;
+((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var338) /* add on <self:SeparateCompilerVisitor>*/;
 }
 if (var_maybenull){
-if (varonce326) {
-var327 = varonce326;
+if (varonce339) {
+var340 = varonce339;
 } else {
-var328 = "}";
-var329 = 1;
-var330 = string__NativeString__to_s_with_length(var328, var329);
-var327 = var330;
-varonce326 = var327;
+var341 = "}";
+var342 = 1;
+var343 = string__NativeString__to_s_with_length(var341, var342);
+var340 = var343;
+varonce339 = var340;
 }
-((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var327) /* add on <self:SeparateCompilerVisitor>*/;
+((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var340) /* add on <self:SeparateCompilerVisitor>*/;
 } else {
 }
-var = var_res36;
+var = var_res;
 goto RET_LABEL;
 } else {
 }
 } else {
 }
-var331 = NULL;
+var344 = NULL;
 if (var_ret == NULL) {
-var332 = 1; /* is null */
+var345 = 1; /* is null */
 } else {
-var332 = 0; /* arg is null but recv is not */
+var345 = 0; /* arg is null but recv is not */
 }
-if (var332){
-if (varonce333) {
-var334 = varonce333;
+if (var345){
+if (varonce346) {
+var347 = varonce346;
 } else {
-var335 = "void";
-var336 = 4;
-var337 = string__NativeString__to_s_with_length(var335, var336);
-var334 = var337;
-varonce333 = var334;
+var348 = "void";
+var349 = 4;
+var350 = string__NativeString__to_s_with_length(var348, var349);
+var347 = var350;
+varonce346 = var347;
 }
-var_r = var334;
+var_r = var347;
 } else {
-var338 = ((val* (*)(val*))(var_ret->class->vft[COLOR_abstract_compiler__MType__ctype]))(var_ret) /* ctype on <var_ret:nullable MType(MType)>*/;
-var_r = var338;
+var351 = ((val* (*)(val*))(var_ret->class->vft[COLOR_abstract_compiler__MType__ctype]))(var_ret) /* ctype on <var_ret:nullable MType(MType)>*/;
+var_r = var351;
 }
 ((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__require_declaration]))(self, var_const_color) /* require_declaration on <self:SeparateCompilerVisitor>*/;
-var339 = NEW_array__Array(&type_array__Arraykernel__Object);
-var340 = 15;
-((void (*)(val*, long))(var339->class->vft[COLOR_array__Array__with_capacity]))(var339, var340) /* with_capacity on <var339:Array[Object]>*/;
-CHECK_NEW_array__Array(var339);
-var_341 = var339;
-if (varonce342) {
-var343 = varonce342;
-} else {
-var344 = "((";
-var345 = 2;
-var346 = string__NativeString__to_s_with_length(var344, var345);
-var343 = var346;
-varonce342 = var343;
-}
-((void (*)(val*, val*))(var_341->class->vft[COLOR_abstract_collection__SimpleCollection__add]))(var_341, var343) /* add on <var_341:Array[Object]>*/;
-((void (*)(val*, val*))(var_341->class->vft[COLOR_abstract_collection__SimpleCollection__add]))(var_341, var_r) /* add on <var_341:Array[Object]>*/;
-if (varonce347) {
-var348 = varonce347;
-} else {
-var349 = " (*)(";
-var350 = 5;
-var351 = string__NativeString__to_s_with_length(var349, var350);
-var348 = var351;
-varonce347 = var348;
-}
-((void (*)(val*, val*))(var_341->class->vft[COLOR_abstract_collection__SimpleCollection__add]))(var_341, var348) /* add on <var_341:Array[Object]>*/;
-((void (*)(val*, val*))(var_341->class->vft[COLOR_abstract_collection__SimpleCollection__add]))(var_341, var_s) /* add on <var_341:Array[Object]>*/;
-if (varonce352) {
-var353 = varonce352;
-} else {
-var354 = "))(";
-var355 = 3;
-var356 = string__NativeString__to_s_with_length(var354, var355);
-var353 = var356;
-varonce352 = var353;
-}
-((void (*)(val*, val*))(var_341->class->vft[COLOR_abstract_collection__SimpleCollection__add]))(var_341, var353) /* add on <var_341:Array[Object]>*/;
-var357 = ((val* (*)(val*))(var_arguments->class->vft[COLOR_abstract_collection__Collection__first]))(var_arguments) /* first on <var_arguments:Array[RuntimeVariable]>*/;
-((void (*)(val*, val*))(var_341->class->vft[COLOR_abstract_collection__SimpleCollection__add]))(var_341, var357) /* add on <var_341:Array[Object]>*/;
-if (varonce358) {
-var359 = varonce358;
-} else {
-var360 = "->class->vft[";
-var361 = 13;
-var362 = string__NativeString__to_s_with_length(var360, var361);
-var359 = var362;
-varonce358 = var359;
-}
-((void (*)(val*, val*))(var_341->class->vft[COLOR_abstract_collection__SimpleCollection__add]))(var_341, var359) /* add on <var_341:Array[Object]>*/;
-((void (*)(val*, val*))(var_341->class->vft[COLOR_abstract_collection__SimpleCollection__add]))(var_341, var_const_color) /* add on <var_341:Array[Object]>*/;
-if (varonce363) {
-var364 = varonce363;
-} else {
-var365 = "]))(";
-var366 = 4;
-var367 = string__NativeString__to_s_with_length(var365, var366);
-var364 = var367;
-varonce363 = var364;
-}
-((void (*)(val*, val*))(var_341->class->vft[COLOR_abstract_collection__SimpleCollection__add]))(var_341, var364) /* add on <var_341:Array[Object]>*/;
-((void (*)(val*, val*))(var_341->class->vft[COLOR_abstract_collection__SimpleCollection__add]))(var_341, var_ss) /* add on <var_341:Array[Object]>*/;
-if (varonce368) {
-var369 = varonce368;
-} else {
-var370 = ") /* ";
-var371 = 5;
-var372 = string__NativeString__to_s_with_length(var370, var371);
-var369 = var372;
-varonce368 = var369;
-}
-((void (*)(val*, val*))(var_341->class->vft[COLOR_abstract_collection__SimpleCollection__add]))(var_341, var369) /* add on <var_341:Array[Object]>*/;
-((void (*)(val*, val*))(var_341->class->vft[COLOR_abstract_collection__SimpleCollection__add]))(var_341, var_mmethod) /* add on <var_341:Array[Object]>*/;
-if (varonce373) {
-var374 = varonce373;
-} else {
-var375 = " on ";
-var376 = 4;
-var377 = string__NativeString__to_s_with_length(var375, var376);
-var374 = var377;
-varonce373 = var374;
-}
-((void (*)(val*, val*))(var_341->class->vft[COLOR_abstract_collection__SimpleCollection__add]))(var_341, var374) /* add on <var_341:Array[Object]>*/;
-var378 = ((val* (*)(val*))(var_arguments->class->vft[COLOR_abstract_collection__Collection__first]))(var_arguments) /* first on <var_arguments:Array[RuntimeVariable]>*/;
-var379 = ((val* (*)(val*))(var378->class->vft[COLOR_string__Object__inspect]))(var378) /* inspect on <var378:nullable Object(RuntimeVariable)>*/;
-((void (*)(val*, val*))(var_341->class->vft[COLOR_abstract_collection__SimpleCollection__add]))(var_341, var379) /* add on <var_341:Array[Object]>*/;
-if (varonce380) {
-var381 = varonce380;
-} else {
-var382 = "*/";
-var383 = 2;
-var384 = string__NativeString__to_s_with_length(var382, var383);
-var381 = var384;
-varonce380 = var381;
-}
-((void (*)(val*, val*))(var_341->class->vft[COLOR_abstract_collection__SimpleCollection__add]))(var_341, var381) /* add on <var_341:Array[Object]>*/;
-var385 = ((val* (*)(val*))(var_341->class->vft[COLOR_string__Object__to_s]))(var_341) /* to_s on <var_341:Array[Object]>*/;
-var_call = var385;
-var386 = NULL;
-if (var_res36 == NULL) {
-var387 = 0; /* is null */
-} else {
-var387 = 1; /* arg is null and recv is not */
-}
-if (var387){
-if (varonce388) {
-var389 = varonce388;
-} else {
-var390 = " = ";
-var391 = 3;
-var392 = string__NativeString__to_s_with_length(var390, var391);
-var389 = var392;
-varonce388 = var389;
-}
+var352 = NEW_array__Array(&type_array__Arraykernel__Object);
+var353 = 15;
+((void (*)(val*, long))(var352->class->vft[COLOR_array__Array__with_capacity]))(var352, var353) /* with_capacity on <var352:Array[Object]>*/;
+var_354 = var352;
+if (varonce355) {
+var356 = varonce355;
+} else {
+var357 = "((";
+var358 = 2;
+var359 = string__NativeString__to_s_with_length(var357, var358);
+var356 = var359;
+varonce355 = var356;
+}
+((void (*)(val*, val*))(var_354->class->vft[COLOR_abstract_collection__SimpleCollection__add]))(var_354, var356) /* add on <var_354:Array[Object]>*/;
+((void (*)(val*, val*))(var_354->class->vft[COLOR_abstract_collection__SimpleCollection__add]))(var_354, var_r) /* add on <var_354:Array[Object]>*/;
+if (varonce360) {
+var361 = varonce360;
+} else {
+var362 = " (*)(";
+var363 = 5;
+var364 = string__NativeString__to_s_with_length(var362, var363);
+var361 = var364;
+varonce360 = var361;
+}
+((void (*)(val*, val*))(var_354->class->vft[COLOR_abstract_collection__SimpleCollection__add]))(var_354, var361) /* add on <var_354:Array[Object]>*/;
+((void (*)(val*, val*))(var_354->class->vft[COLOR_abstract_collection__SimpleCollection__add]))(var_354, var_s) /* add on <var_354:Array[Object]>*/;
+if (varonce365) {
+var366 = varonce365;
+} else {
+var367 = "))(";
+var368 = 3;
+var369 = string__NativeString__to_s_with_length(var367, var368);
+var366 = var369;
+varonce365 = var366;
+}
+((void (*)(val*, val*))(var_354->class->vft[COLOR_abstract_collection__SimpleCollection__add]))(var_354, var366) /* add on <var_354:Array[Object]>*/;
+var370 = ((val* (*)(val*))(var_arguments->class->vft[COLOR_abstract_collection__Collection__first]))(var_arguments) /* first on <var_arguments:Array[RuntimeVariable]>*/;
+((void (*)(val*, val*))(var_354->class->vft[COLOR_abstract_collection__SimpleCollection__add]))(var_354, var370) /* add on <var_354:Array[Object]>*/;
+if (varonce371) {
+var372 = varonce371;
+} else {
+var373 = "->class->vft[";
+var374 = 13;
+var375 = string__NativeString__to_s_with_length(var373, var374);
+var372 = var375;
+varonce371 = var372;
+}
+((void (*)(val*, val*))(var_354->class->vft[COLOR_abstract_collection__SimpleCollection__add]))(var_354, var372) /* add on <var_354:Array[Object]>*/;
+((void (*)(val*, val*))(var_354->class->vft[COLOR_abstract_collection__SimpleCollection__add]))(var_354, var_const_color) /* add on <var_354:Array[Object]>*/;
+if (varonce376) {
+var377 = varonce376;
+} else {
+var378 = "]))(";
+var379 = 4;
+var380 = string__NativeString__to_s_with_length(var378, var379);
+var377 = var380;
+varonce376 = var377;
+}
+((void (*)(val*, val*))(var_354->class->vft[COLOR_abstract_collection__SimpleCollection__add]))(var_354, var377) /* add on <var_354:Array[Object]>*/;
+((void (*)(val*, val*))(var_354->class->vft[COLOR_abstract_collection__SimpleCollection__add]))(var_354, var_ss) /* add on <var_354:Array[Object]>*/;
+if (varonce381) {
+var382 = varonce381;
+} else {
+var383 = ") /* ";
+var384 = 5;
+var385 = string__NativeString__to_s_with_length(var383, var384);
+var382 = var385;
+varonce381 = var382;
+}
+((void (*)(val*, val*))(var_354->class->vft[COLOR_abstract_collection__SimpleCollection__add]))(var_354, var382) /* add on <var_354:Array[Object]>*/;
+((void (*)(val*, val*))(var_354->class->vft[COLOR_abstract_collection__SimpleCollection__add]))(var_354, var_mmethod) /* add on <var_354:Array[Object]>*/;
+if (varonce386) {
+var387 = varonce386;
+} else {
+var388 = " on ";
+var389 = 4;
+var390 = string__NativeString__to_s_with_length(var388, var389);
+var387 = var390;
+varonce386 = var387;
+}
+((void (*)(val*, val*))(var_354->class->vft[COLOR_abstract_collection__SimpleCollection__add]))(var_354, var387) /* add on <var_354:Array[Object]>*/;
+var391 = ((val* (*)(val*))(var_arguments->class->vft[COLOR_abstract_collection__Collection__first]))(var_arguments) /* first on <var_arguments:Array[RuntimeVariable]>*/;
+var392 = ((val* (*)(val*))(var391->class->vft[COLOR_string__Object__inspect]))(var391) /* inspect on <var391:nullable Object(RuntimeVariable)>*/;
+((void (*)(val*, val*))(var_354->class->vft[COLOR_abstract_collection__SimpleCollection__add]))(var_354, var392) /* add on <var_354:Array[Object]>*/;
 if (varonce393) {
 var394 = varonce393;
 } else {
-var395 = ";";
-var396 = 1;
+var395 = "*/";
+var396 = 2;
 var397 = string__NativeString__to_s_with_length(var395, var396);
 var394 = var397;
 varonce393 = var394;
 }
-var398 = NEW_array__Array(&type_array__Arraykernel__Object);
-{ /* var398 = array_instance Array[Object] */
-var399 = 4;
-var400 = NEW_array__NativeArray(var399, &type_array__NativeArraykernel__Object);
-((struct instance_array__NativeArray*)var400)->values[0] = (val*) var_res36;
-((struct instance_array__NativeArray*)var400)->values[1] = (val*) var389;
-((struct instance_array__NativeArray*)var400)->values[2] = (val*) var_call;
-((struct instance_array__NativeArray*)var400)->values[3] = (val*) var394;
-((void (*)(val*, val*, long))(var398->class->vft[COLOR_array__Array__with_native]))(var398, var400, var399) /* with_native on <var398:Array[Object]>*/;
-CHECK_NEW_array__Array(var398);
-}
-var401 = ((val* (*)(val*))(var398->class->vft[COLOR_string__Object__to_s]))(var398) /* to_s on <var398:Array[Object]>*/;
-((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var401) /* add on <self:SeparateCompilerVisitor>*/;
-} else {
-if (varonce402) {
-var403 = varonce402;
+((void (*)(val*, val*))(var_354->class->vft[COLOR_abstract_collection__SimpleCollection__add]))(var_354, var394) /* add on <var_354:Array[Object]>*/;
+var398 = ((val* (*)(val*))(var_354->class->vft[COLOR_string__Object__to_s]))(var_354) /* to_s on <var_354:Array[Object]>*/;
+var_call = var398;
+var399 = NULL;
+if (var_res == NULL) {
+var400 = 0; /* is null */
 } else {
-var404 = ";";
-var405 = 1;
-var406 = string__NativeString__to_s_with_length(var404, var405);
-var403 = var406;
-varonce402 = var403;
+var400 = 1; /* arg is null and recv is not */
 }
-var407 = NEW_array__Array(&type_array__Arraykernel__Object);
-{ /* var407 = array_instance Array[Object] */
-var408 = 2;
-var409 = NEW_array__NativeArray(var408, &type_array__NativeArraykernel__Object);
-((struct instance_array__NativeArray*)var409)->values[0] = (val*) var_call;
-((struct instance_array__NativeArray*)var409)->values[1] = (val*) var403;
-((void (*)(val*, val*, long))(var407->class->vft[COLOR_array__Array__with_native]))(var407, var409, var408) /* with_native on <var407:Array[Object]>*/;
-CHECK_NEW_array__Array(var407);
+if (var400){
+if (varonce401) {
+var402 = varonce401;
+} else {
+var403 = " = ";
+var404 = 3;
+var405 = string__NativeString__to_s_with_length(var403, var404);
+var402 = var405;
+varonce401 = var402;
 }
-var410 = ((val* (*)(val*))(var407->class->vft[COLOR_string__Object__to_s]))(var407) /* to_s on <var407:Array[Object]>*/;
-((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var410) /* add on <self:SeparateCompilerVisitor>*/;
+if (varonce406) {
+var407 = varonce406;
+} else {
+var408 = ";";
+var409 = 1;
+var410 = string__NativeString__to_s_with_length(var408, var409);
+var407 = var410;
+varonce406 = var407;
+}
+var411 = NEW_array__Array(&type_array__Arraykernel__Object);
+{ /* var411 = array_instance Array[Object] */
+var412 = 4;
+var413 = NEW_array__NativeArray(var412, &type_array__NativeArraykernel__Object);
+((struct instance_array__NativeArray*)var413)->values[0] = (val*) var_res;
+((struct instance_array__NativeArray*)var413)->values[1] = (val*) var402;
+((struct instance_array__NativeArray*)var413)->values[2] = (val*) var_call;
+((struct instance_array__NativeArray*)var413)->values[3] = (val*) var407;
+((void (*)(val*, val*, long))(var411->class->vft[COLOR_array__Array__with_native]))(var411, var413, var412) /* with_native on <var411:Array[Object]>*/;
+}
+var414 = ((val* (*)(val*))(var411->class->vft[COLOR_string__Object__to_s]))(var411) /* to_s on <var411:Array[Object]>*/;
+((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var414) /* add on <self:SeparateCompilerVisitor>*/;
+} else {
+if (varonce415) {
+var416 = varonce415;
+} else {
+var417 = ";";
+var418 = 1;
+var419 = string__NativeString__to_s_with_length(var417, var418);
+var416 = var419;
+varonce415 = var416;
+}
+var420 = NEW_array__Array(&type_array__Arraykernel__Object);
+{ /* var420 = array_instance Array[Object] */
+var421 = 2;
+var422 = NEW_array__NativeArray(var421, &type_array__NativeArraykernel__Object);
+((struct instance_array__NativeArray*)var422)->values[0] = (val*) var_call;
+((struct instance_array__NativeArray*)var422)->values[1] = (val*) var416;
+((void (*)(val*, val*, long))(var420->class->vft[COLOR_array__Array__with_native]))(var420, var422, var421) /* with_native on <var420:Array[Object]>*/;
+}
+var423 = ((val* (*)(val*))(var420->class->vft[COLOR_string__Object__to_s]))(var420) /* to_s on <var420:Array[Object]>*/;
+((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var423) /* add on <self:SeparateCompilerVisitor>*/;
 }
 if (var_maybenull){
-if (varonce411) {
-var412 = varonce411;
+if (varonce424) {
+var425 = varonce424;
 } else {
-var413 = "}";
-var414 = 1;
-var415 = string__NativeString__to_s_with_length(var413, var414);
-var412 = var415;
-varonce411 = var412;
+var426 = "}";
+var427 = 1;
+var428 = string__NativeString__to_s_with_length(var426, var427);
+var425 = var428;
+varonce424 = var425;
 }
-((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var412) /* add on <self:SeparateCompilerVisitor>*/;
+((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var425) /* add on <self:SeparateCompilerVisitor>*/;
 } else {
 }
-var = var_res36;
+var = var_res;
 goto RET_LABEL;
 RET_LABEL:;
 return var;
@@ -2173,484 +1656,624 @@ val* var /* : nullable RuntimeVariable */;
 val* var_mmethoddef /* var mmethoddef: MMethodDef */;
 val* var_recvtype /* var recvtype: MClassType */;
 val* var_arguments /* var arguments: Array[RuntimeVariable] */;
-val* var1 /* : nullable MSignature */;
-val* var2 /* : nullable MType */;
+long var1 /* : Int */;
+val* var2 /* : nullable MSignature */;
+long var3 /* : Int */;
+long var4 /* : Int */;
+long var5 /* : Int */;
+long var7 /* : Int */;
+short int var8 /* : Bool */;
+short int var10 /* : Bool */;
+static val* varonce;
+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 */;
+long var20 /* : Int */;
+static val* varonce21;
+val* var22 /* : String */;
+char* var23 /* : NativeString */;
+long var24 /* : Int */;
+val* var25 /* : String */;
+val* var26 /* : Array[Object] */;
+long var27 /* : Int */;
+val* var28 /* : NativeArray[Object] */;
+val* var29 /* : Object */;
+val* var30 /* : String */;
+val* var31 /* : nullable MSignature */;
+val* var32 /* : nullable MType */;
 val* var_ret /* var ret: nullable MType */;
-val* var3 /* : MProperty */;
-short int var4 /* : Bool */;
-val* var5 /* : nullable Object */;
-val* var6 /* : MType */;
-val* var7 /* : RuntimeVariable */;
+val* var33 /* : MProperty */;
+short int var34 /* : Bool */;
+val* var35 /* : nullable Object */;
+val* var36 /* : MType */;
+val* var37 /* : RuntimeVariable */;
 val* var_res /* var res: nullable RuntimeVariable */;
-val* var8 /* : null */;
-short int var9 /* : Bool */;
-val* var10 /* : null */;
-val* var11 /* : MClassDef */;
-val* var12 /* : MClassType */;
-val* var13 /* : MClassDef */;
-val* var14 /* : MClassType */;
-val* var15 /* : MClassDef */;
-val* var16 /* : MModule */;
-short int var17 /* : Bool */;
-val* var18 /* : MType */;
-val* var19 /* : RuntimeVariable */;
-short int var20 /* : Bool */;
-short int var21 /* : Bool */;
-val* var22 /* : AbstractCompiler */;
-val* var23 /* : ModelBuilder */;
-val* var24 /* : HashMap[MPropDef, APropdef] */;
-short int var25 /* : Bool */;
+val* var38 /* : null */;
+short int var39 /* : Bool */;
+val* var40 /* : null */;
+val* var41 /* : MClassDef */;
+val* var42 /* : MClassType */;
+val* var43 /* : MClassDef */;
+val* var44 /* : MClassType */;
+val* var45 /* : MClassDef */;
+val* var46 /* : MModule */;
+short int var47 /* : Bool */;
+val* var48 /* : MType */;
+val* var49 /* : RuntimeVariable */;
+short int var50 /* : Bool */;
+short int var51 /* : Bool */;
+val* var52 /* : AbstractCompiler */;
+val* var53 /* : ModelBuilder */;
+val* var54 /* : HashMap[MPropDef, APropdef] */;
+short int var55 /* : Bool */;
 short int var_ /* var : Bool */;
-val* var26 /* : AbstractCompiler */;
-val* var27 /* : ModelBuilder */;
-val* var28 /* : HashMap[MPropDef, APropdef] */;
-val* var29 /* : nullable Object */;
-short int var30 /* : Bool */;
+val* var56 /* : AbstractCompiler */;
+val* var57 /* : ModelBuilder */;
+val* var58 /* : HashMap[MPropDef, APropdef] */;
+val* var59 /* : nullable Object */;
+short int var60 /* : Bool */;
 int cltype;
 int idtype;
-short int var_31 /* var : Bool */;
-val* var32 /* : AbstractCompiler */;
-val* var33 /* : ModelBuilder */;
-val* var34 /* : ToolContext */;
-val* var35 /* : OptionBool */;
-val* var36 /* : nullable Object */;
-short int var37 /* : Bool */;
-short int var38 /* : Bool */;
-val* var39 /* : Frame */;
+short int var_61 /* var : Bool */;
+val* var62 /* : AbstractCompiler */;
+val* var63 /* : ModelBuilder */;
+val* var64 /* : ToolContext */;
+val* var65 /* : OptionBool */;
+val* var66 /* : nullable Object */;
+short int var67 /* : Bool */;
+short int var68 /* : Bool */;
+val* var69 /* : Frame */;
 val* var_frame /* var frame: Frame */;
-static val* varonce;
-val* var40 /* : String */;
-char* var41 /* : NativeString */;
-long var42 /* : Int */;
-val* var43 /* : String */;
-val* var44 /* : String */;
-val* var45 /* : nullable Frame */;
-val* var_old_frame /* var old_frame: nullable Frame */;
-static val* varonce46;
-val* var47 /* : String */;
-char* var48 /* : NativeString */;
-long var49 /* : Int */;
-val* var50 /* : String */;
-static val* varonce51;
-val* var52 /* : String */;
-char* var53 /* : NativeString */;
-long var54 /* : Int */;
-val* var55 /* : String */;
-static val* varonce56;
-val* var57 /* : String */;
-char* var58 /* : NativeString */;
-long var59 /* : Int */;
-val* var60 /* : String */;
-val* var61 /* : String */;
-static val* varonce62;
-val* var63 /* : String */;
-char* var64 /* : NativeString */;
-long var65 /* : Int */;
-val* var66 /* : String */;
-val* var67 /* : Array[Object] */;
-long var68 /* : Int */;
-val* var69 /* : NativeArray[Object] */;
-val* var70 /* : String */;
-val* var71 /* : nullable RuntimeVariable */;
-val* var72 /* : nullable String */;
-static val* varonce73;
+static val* varonce70;
+val* var71 /* : String */;
+char* var72 /* : NativeString */;
+long var73 /* : Int */;
 val* var74 /* : String */;
-char* var75 /* : NativeString */;
-long var76 /* : Int */;
-val* var77 /* : String */;
-val* var78 /* : Array[Object] */;
-long var79 /* : Int */;
-val* var80 /* : NativeArray[Object] */;
+val* var75 /* : String */;
+val* var76 /* : nullable Frame */;
+val* var_old_frame /* var old_frame: nullable Frame */;
+static val* varonce77;
+val* var78 /* : String */;
+char* var79 /* : NativeString */;
+long var80 /* : Int */;
 val* var81 /* : String */;
 static val* varonce82;
 val* var83 /* : String */;
 char* var84 /* : NativeString */;
 long var85 /* : Int */;
 val* var86 /* : String */;
-val* var87 /* : String */;
-val* var88 /* : null */;
-short int var89 /* : Bool */;
-val* var90 /* : String */;
-static val* varonce91;
+static val* varonce87;
+val* var88 /* : String */;
+char* var89 /* : NativeString */;
+long var90 /* : Int */;
+val* var91 /* : String */;
 val* var92 /* : String */;
-char* var93 /* : NativeString */;
-long var94 /* : Int */;
-val* var95 /* : String */;
-static val* varonce96;
+static val* varonce93;
+val* var94 /* : String */;
+char* var95 /* : NativeString */;
+long var96 /* : Int */;
 val* var97 /* : String */;
-char* var98 /* : NativeString */;
+val* var98 /* : Array[Object] */;
 long var99 /* : Int */;
-val* var100 /* : String */;
+val* var100 /* : NativeArray[Object] */;
 val* var101 /* : String */;
-static val* varonce102;
-val* var103 /* : String */;
-char* var104 /* : NativeString */;
-long var105 /* : Int */;
-val* var106 /* : String */;
-val* var107 /* : Array[Object] */;
-long var108 /* : Int */;
-val* var109 /* : NativeArray[Object] */;
-val* var110 /* : String */;
-val* var111 /* : null */;
-static val* varonce112;
-val* var113 /* : String */;
-char* var114 /* : NativeString */;
-long var115 /* : Int */;
-val* var116 /* : String */;
+val* var102 /* : nullable RuntimeVariable */;
+val* var103 /* : nullable String */;
+static val* varonce104;
+val* var105 /* : String */;
+char* var106 /* : NativeString */;
+long var107 /* : Int */;
+val* var108 /* : String */;
+val* var109 /* : Array[Object] */;
+long var110 /* : Int */;
+val* var111 /* : NativeArray[Object] */;
+val* var112 /* : String */;
+static val* varonce113;
+val* var114 /* : String */;
+char* var115 /* : NativeString */;
+long var116 /* : Int */;
 val* var117 /* : String */;
-static val* varonce118;
-val* var119 /* : String */;
-char* var120 /* : NativeString */;
-long var121 /* : Int */;
-val* var122 /* : String */;
-static val* varonce123;
-val* var124 /* : String */;
-char* var125 /* : NativeString */;
-long var126 /* : Int */;
-val* var127 /* : String */;
+val* var118 /* : String */;
+val* var119 /* : null */;
+short int var120 /* : Bool */;
+val* var121 /* : String */;
+static val* varonce122;
+val* var123 /* : String */;
+char* var124 /* : NativeString */;
+long var125 /* : Int */;
+val* var126 /* : String */;
+static val* varonce127;
 val* var128 /* : String */;
-static val* varonce129;
-val* var130 /* : String */;
-char* var131 /* : NativeString */;
-long var132 /* : Int */;
-val* var133 /* : String */;
-val* var134 /* : Array[Object] */;
-long var135 /* : Int */;
-val* var136 /* : NativeArray[Object] */;
+char* var129 /* : NativeString */;
+long var130 /* : Int */;
+val* var131 /* : String */;
+val* var132 /* : String */;
+static val* varonce133;
+val* var134 /* : String */;
+char* var135 /* : NativeString */;
+long var136 /* : Int */;
 val* var137 /* : String */;
+val* var138 /* : Array[Object] */;
+long var139 /* : Int */;
+val* var140 /* : NativeArray[Object] */;
+val* var141 /* : String */;
+val* var142 /* : null */;
+static val* varonce143;
+val* var144 /* : String */;
+char* var145 /* : NativeString */;
+long var146 /* : Int */;
+val* var147 /* : String */;
+val* var148 /* : String */;
+static val* varonce149;
+val* var150 /* : String */;
+char* var151 /* : NativeString */;
+long var152 /* : Int */;
+val* var153 /* : String */;
+static val* varonce154;
+val* var155 /* : String */;
+char* var156 /* : NativeString */;
+long var157 /* : Int */;
+val* var158 /* : String */;
+val* var159 /* : String */;
+static val* varonce160;
+val* var161 /* : String */;
+char* var162 /* : NativeString */;
+long var163 /* : Int */;
+val* var164 /* : String */;
+val* var165 /* : Array[Object] */;
+long var166 /* : Int */;
+val* var167 /* : NativeArray[Object] */;
+val* var168 /* : String */;
 var_mmethoddef = p0;
 var_recvtype = p1;
 var_arguments = p2;
-var1 = ((val* (*)(val*))(var_mmethoddef->class->vft[COLOR_model__MMethodDef__msignature]))(var_mmethoddef) /* msignature on <var_mmethoddef:MMethodDef>*/;
-if (var1 == NULL) {
-fprintf(stderr, "Runtime error: %s", "Reciever is null");
-fprintf(stderr, " (%s:%d)\n", "src/separate_compiler.nit", 1088);
-exit(1);
+var1 = ((long (*)(val*))(var_arguments->class->vft[COLOR_abstract_collection__Collection__length]))(var_arguments) /* length on <var_arguments:Array[RuntimeVariable]>*/;
+var2 = ((val* (*)(val*))(var_mmethoddef->class->vft[COLOR_model__MMethodDef__msignature]))(var_mmethoddef) /* msignature on <var_mmethoddef:MMethodDef>*/;
+if (var2 == NULL) {
+fprintf(stderr, "Runtime error: %s", "Receiver is null");
+fprintf(stderr, " (%s:%d)\n", "src/separate_compiler.nit", 1108);
+show_backtrace(1);
+} else {
+var3 = ((long (*)(val*))(var2->class->vft[COLOR_model__MSignature__arity]))(var2) /* arity on <var2:nullable MSignature>*/;
+}
+var4 = 1;
+{ /* Inline kernel#Int#+ (var3,var4) */
+var7 = var3 + var4;
+var5 = var7;
+goto RET_LABEL6;
+RET_LABEL6:(void)0;
+}
+{ /* Inline kernel#Int#== (var1,var5) */
+var10 = var1 == var5;
+var8 = var10;
+goto RET_LABEL9;
+RET_LABEL9:(void)0;
+}
+if (!var8) {
+if (varonce) {
+var11 = varonce;
 } else {
-var2 = ((val* (*)(val*))(var1->class->vft[COLOR_model__MSignature__return_mtype]))(var1) /* return_mtype on <var1:nullable MSignature>*/;
+var12 = "Invalid arity for ";
+var13 = 18;
+var14 = string__NativeString__to_s_with_length(var12, var13);
+var11 = var14;
+varonce = var11;
 }
-var_ret = var2;
-var3 = ((val* (*)(val*))(var_mmethoddef->class->vft[COLOR_model__MPropDef__mproperty]))(var_mmethoddef) /* mproperty on <var_mmethoddef:MMethodDef>*/;
-var4 = ((short int (*)(val*))(var3->class->vft[COLOR_model__MMethod__is_new]))(var3) /* is_new on <var3:MProperty(MMethod)>*/;
-if (var4){
-var5 = ((val* (*)(val*))(var_arguments->class->vft[COLOR_abstract_collection__Collection__first]))(var_arguments) /* first on <var_arguments:Array[RuntimeVariable]>*/;
-var6 = ((val* (*)(val*))(var5->class->vft[COLOR_abstract_compiler__RuntimeVariable__mtype]))(var5) /* mtype on <var5:nullable Object(RuntimeVariable)>*/;
-var_ret = var6;
-var7 = ((val* (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__new_var]))(self, var_ret) /* new_var on <self:SeparateCompilerVisitor>*/;
-var_res = var7;
+if (varonce15) {
+var16 = varonce15;
 } else {
-var8 = NULL;
-if (var_ret == NULL) {
-var9 = 1; /* is null */
-} else {
-var9 = 0; /* arg is null but recv is not */
-}
-if (var9){
-var10 = NULL;
-var_res = var10;
-} else {
-var11 = ((val* (*)(val*))(var_mmethoddef->class->vft[COLOR_model__MPropDef__mclassdef]))(var_mmethoddef) /* mclassdef on <var_mmethoddef:MMethodDef>*/;
-var12 = ((val* (*)(val*))(var11->class->vft[COLOR_model__MClassDef__bound_mtype]))(var11) /* bound_mtype on <var11:MClassDef>*/;
-var13 = ((val* (*)(val*))(var_mmethoddef->class->vft[COLOR_model__MPropDef__mclassdef]))(var_mmethoddef) /* mclassdef on <var_mmethoddef:MMethodDef>*/;
-var14 = ((val* (*)(val*))(var13->class->vft[COLOR_model__MClassDef__bound_mtype]))(var13) /* bound_mtype on <var13:MClassDef>*/;
-var15 = ((val* (*)(val*))(var_mmethoddef->class->vft[COLOR_model__MPropDef__mclassdef]))(var_mmethoddef) /* mclassdef on <var_mmethoddef:MMethodDef>*/;
-var16 = ((val* (*)(val*))(var15->class->vft[COLOR_model__MClassDef__mmodule]))(var15) /* mmodule on <var15:MClassDef>*/;
-var17 = 1;
-var18 = ((val* (*)(val*, val*, val*, val*, short int))(var_ret->class->vft[COLOR_model__MType__resolve_for]))(var_ret, var12, var14, var16, var17) /* resolve_for on <var_ret:nullable MType(MType)>*/;
-var_ret = var18;
-var19 = ((val* (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__new_var]))(self, var_ret) /* new_var on <self:SeparateCompilerVisitor>*/;
-var_res = var19;
+var17 = ". ";
+var18 = 2;
+var19 = string__NativeString__to_s_with_length(var17, var18);
+var16 = var19;
+varonce15 = var16;
 }
+var20 = ((long (*)(val*))(var_arguments->class->vft[COLOR_abstract_collection__Collection__length]))(var_arguments) /* length on <var_arguments:Array[RuntimeVariable]>*/;
+if (varonce21) {
+var22 = varonce21;
+} else {
+var23 = " arguments given.";
+var24 = 17;
+var25 = string__NativeString__to_s_with_length(var23, var24);
+var22 = var25;
+varonce21 = var22;
 }
-var22 = ((val* (*)(val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__compiler]))(self) /* compiler on <self:SeparateCompilerVisitor>*/;
-var23 = ((val* (*)(val*))(var22->class->vft[COLOR_abstract_compiler__AbstractCompiler__modelbuilder]))(var22) /* modelbuilder on <var22:AbstractCompiler(SeparateCompiler)>*/;
-var24 = ((val* (*)(val*))(var23->class->vft[COLOR_modelize_property__ModelBuilder__mpropdef2npropdef]))(var23) /* mpropdef2npropdef on <var23:ModelBuilder>*/;
-var25 = ((short int (*)(val*, val*))(var24->class->vft[COLOR_abstract_collection__MapRead__has_key]))(var24, var_mmethoddef) /* has_key on <var24:HashMap[MPropDef, APropdef]>*/;
-var_ = var25;
-if (var25){
-var26 = ((val* (*)(val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__compiler]))(self) /* compiler on <self:SeparateCompilerVisitor>*/;
-var27 = ((val* (*)(val*))(var26->class->vft[COLOR_abstract_compiler__AbstractCompiler__modelbuilder]))(var26) /* modelbuilder on <var26:AbstractCompiler(SeparateCompiler)>*/;
-var28 = ((val* (*)(val*))(var27->class->vft[COLOR_modelize_property__ModelBuilder__mpropdef2npropdef]))(var27) /* mpropdef2npropdef on <var27:ModelBuilder>*/;
-var29 = ((val* (*)(val*, val*))(var28->class->vft[COLOR_abstract_collection__MapRead___91d_93d]))(var28, var_mmethoddef) /* [] on <var28:HashMap[MPropDef, APropdef]>*/;
-/* <var29:nullable Object(APropdef)> isa AInternMethPropdef */
+var26 = NEW_array__Array(&type_array__Arraykernel__Object);
+{ /* var26 = array_instance Array[Object] */
+var27 = 5;
+var28 = NEW_array__NativeArray(var27, &type_array__NativeArraykernel__Object);
+((struct instance_array__NativeArray*)var28)->values[0] = (val*) var11;
+((struct instance_array__NativeArray*)var28)->values[1] = (val*) var_mmethoddef;
+((struct instance_array__NativeArray*)var28)->values[2] = (val*) var16;
+var29 = BOX_kernel__Int(var20); /* autobox from Int to Object */
+((struct instance_array__NativeArray*)var28)->values[3] = (val*) var29;
+((struct instance_array__NativeArray*)var28)->values[4] = (val*) var22;
+((void (*)(val*, val*, long))(var26->class->vft[COLOR_array__Array__with_native]))(var26, var28, var27) /* with_native on <var26:Array[Object]>*/;
+}
+var30 = ((val* (*)(val*))(var26->class->vft[COLOR_string__Object__to_s]))(var26) /* to_s on <var26:Array[Object]>*/;
+((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__debug]))(self, var30) /* debug on <self:SeparateCompilerVisitor>*/;
+fprintf(stderr, "Runtime error: %s", "Assert failed");
+fprintf(stderr, " (%s:%d)\n", "src/separate_compiler.nit", 1108);
+show_backtrace(1);
+}
+var31 = ((val* (*)(val*))(var_mmethoddef->class->vft[COLOR_model__MMethodDef__msignature]))(var_mmethoddef) /* msignature on <var_mmethoddef:MMethodDef>*/;
+if (var31 == NULL) {
+fprintf(stderr, "Runtime error: %s", "Receiver is null");
+fprintf(stderr, " (%s:%d)\n", "src/separate_compiler.nit", 1111);
+show_backtrace(1);
+} else {
+var32 = ((val* (*)(val*))(var31->class->vft[COLOR_model__MSignature__return_mtype]))(var31) /* return_mtype on <var31:nullable MSignature>*/;
+}
+var_ret = var32;
+var33 = ((val* (*)(val*))(var_mmethoddef->class->vft[COLOR_model__MPropDef__mproperty]))(var_mmethoddef) /* mproperty on <var_mmethoddef:MMethodDef>*/;
+var34 = ((short int (*)(val*))(var33->class->vft[COLOR_model__MMethod__is_new]))(var33) /* is_new on <var33:MProperty(MMethod)>*/;
+if (var34){
+var35 = ((val* (*)(val*))(var_arguments->class->vft[COLOR_abstract_collection__Collection__first]))(var_arguments) /* first on <var_arguments:Array[RuntimeVariable]>*/;
+var36 = ((val* (*)(val*))(var35->class->vft[COLOR_abstract_compiler__RuntimeVariable__mtype]))(var35) /* mtype on <var35:nullable Object(RuntimeVariable)>*/;
+var_ret = var36;
+var37 = ((val* (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__new_var]))(self, var_ret) /* new_var on <self:SeparateCompilerVisitor>*/;
+var_res = var37;
+} else {
+var38 = NULL;
+if (var_ret == NULL) {
+var39 = 1; /* is null */
+} else {
+var39 = 0; /* arg is null but recv is not */
+}
+if (var39){
+var40 = NULL;
+var_res = var40;
+} else {
+var41 = ((val* (*)(val*))(var_mmethoddef->class->vft[COLOR_model__MPropDef__mclassdef]))(var_mmethoddef) /* mclassdef on <var_mmethoddef:MMethodDef>*/;
+var42 = ((val* (*)(val*))(var41->class->vft[COLOR_model__MClassDef__bound_mtype]))(var41) /* bound_mtype on <var41:MClassDef>*/;
+var43 = ((val* (*)(val*))(var_mmethoddef->class->vft[COLOR_model__MPropDef__mclassdef]))(var_mmethoddef) /* mclassdef on <var_mmethoddef:MMethodDef>*/;
+var44 = ((val* (*)(val*))(var43->class->vft[COLOR_model__MClassDef__bound_mtype]))(var43) /* bound_mtype on <var43:MClassDef>*/;
+var45 = ((val* (*)(val*))(var_mmethoddef->class->vft[COLOR_model__MPropDef__mclassdef]))(var_mmethoddef) /* mclassdef on <var_mmethoddef:MMethodDef>*/;
+var46 = ((val* (*)(val*))(var45->class->vft[COLOR_model__MClassDef__mmodule]))(var45) /* mmodule on <var45:MClassDef>*/;
+var47 = 1;
+var48 = ((val* (*)(val*, val*, val*, val*, short int))(var_ret->class->vft[COLOR_model__MType__resolve_for]))(var_ret, var42, var44, var46, var47) /* resolve_for on <var_ret:nullable MType(MType)>*/;
+var_ret = var48;
+var49 = ((val* (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__new_var]))(self, var_ret) /* new_var on <self:SeparateCompilerVisitor>*/;
+var_res = var49;
+}
+}
+var52 = ((val* (*)(val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__compiler]))(self) /* compiler on <self:SeparateCompilerVisitor>*/;
+var53 = ((val* (*)(val*))(var52->class->vft[COLOR_abstract_compiler__AbstractCompiler__modelbuilder]))(var52) /* modelbuilder on <var52:AbstractCompiler(SeparateCompiler)>*/;
+var54 = ((val* (*)(val*))(var53->class->vft[COLOR_modelize_property__ModelBuilder__mpropdef2npropdef]))(var53) /* mpropdef2npropdef on <var53:ModelBuilder>*/;
+var55 = ((short int (*)(val*, val*))(var54->class->vft[COLOR_abstract_collection__MapRead__has_key]))(var54, var_mmethoddef) /* has_key on <var54:HashMap[MPropDef, APropdef]>*/;
+var_ = var55;
+if (var55){
+var56 = ((val* (*)(val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__compiler]))(self) /* compiler on <self:SeparateCompilerVisitor>*/;
+var57 = ((val* (*)(val*))(var56->class->vft[COLOR_abstract_compiler__AbstractCompiler__modelbuilder]))(var56) /* modelbuilder on <var56:AbstractCompiler(SeparateCompiler)>*/;
+var58 = ((val* (*)(val*))(var57->class->vft[COLOR_modelize_property__ModelBuilder__mpropdef2npropdef]))(var57) /* mpropdef2npropdef on <var57:ModelBuilder>*/;
+var59 = ((val* (*)(val*, val*))(var58->class->vft[COLOR_abstract_collection__MapRead___91d_93d]))(var58, var_mmethoddef) /* [] on <var58:HashMap[MPropDef, APropdef]>*/;
+/* <var59:nullable Object(APropdef)> isa AInternMethPropdef */
 cltype = type_parser_nodes__AInternMethPropdef.color;
 idtype = type_parser_nodes__AInternMethPropdef.id;
-if(cltype >= var29->type->table_size) {
-var30 = 0;
-} else {
-var30 = var29->type->type_table[cltype] == idtype;
-}
-var21 = var30;
+if(cltype >= var59->type->table_size) {
+var60 = 0;
 } else {
-var21 = var_;
+var60 = var59->type->type_table[cltype] == idtype;
 }
-var_31 = var21;
-if (var21){
-var32 = ((val* (*)(val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__compiler]))(self) /* compiler on <self:SeparateCompilerVisitor>*/;
-var33 = ((val* (*)(val*))(var32->class->vft[COLOR_abstract_compiler__AbstractCompiler__modelbuilder]))(var32) /* modelbuilder on <var32:AbstractCompiler(SeparateCompiler)>*/;
-var34 = ((val* (*)(val*))(var33->class->vft[COLOR_modelbuilder__ModelBuilder__toolcontext]))(var33) /* toolcontext on <var33:ModelBuilder>*/;
-var35 = ((val* (*)(val*))(var34->class->vft[COLOR_separate_compiler__ToolContext__opt_no_inline_intern]))(var34) /* opt_no_inline_intern on <var34:ToolContext>*/;
-var36 = ((val* (*)(val*))(var35->class->vft[COLOR_opts__Option__value]))(var35) /* value on <var35:OptionBool>*/;
-var37 = ((struct instance_kernel__Bool*)var36)->value; /* autounbox from nullable Object to Bool */;
-var38 = !var37;
-var20 = var38;
+var51 = var60;
 } else {
-var20 = var_31;
+var51 = var_;
 }
-if (var20){
-var39 = NEW_abstract_compiler__Frame(&type_abstract_compiler__Frame);
-((void (*)(val*, val*, val*, val*, val*))(var39->class->vft[COLOR_abstract_compiler__Frame__init]))(var39, self, var_mmethoddef, var_recvtype, var_arguments) /* init on <var39:Frame>*/;
-CHECK_NEW_abstract_compiler__Frame(var39);
-var_frame = var39;
-if (varonce) {
-var40 = varonce;
+var_61 = var51;
+if (var51){
+var62 = ((val* (*)(val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__compiler]))(self) /* compiler on <self:SeparateCompilerVisitor>*/;
+var63 = ((val* (*)(val*))(var62->class->vft[COLOR_abstract_compiler__AbstractCompiler__modelbuilder]))(var62) /* modelbuilder on <var62:AbstractCompiler(SeparateCompiler)>*/;
+var64 = ((val* (*)(val*))(var63->class->vft[COLOR_modelbuilder__ModelBuilder__toolcontext]))(var63) /* toolcontext on <var63:ModelBuilder>*/;
+var65 = ((val* (*)(val*))(var64->class->vft[COLOR_separate_compiler__ToolContext__opt_no_inline_intern]))(var64) /* opt_no_inline_intern on <var64:ToolContext>*/;
+var66 = ((val* (*)(val*))(var65->class->vft[COLOR_opts__Option__value]))(var65) /* value on <var65:OptionBool>*/;
+var67 = ((struct instance_kernel__Bool*)var66)->value; /* autounbox from nullable Object to Bool */;
+var68 = !var67;
+var50 = var68;
 } else {
-var41 = "RET_LABEL";
-var42 = 9;
-var43 = string__NativeString__to_s_with_length(var41, var42);
-var40 = var43;
-varonce = var40;
+var50 = var_61;
 }
-var44 = ((val* (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__get_name]))(self, var40) /* get_name on <self:SeparateCompilerVisitor>*/;
-((void (*)(val*, val*))(var_frame->class->vft[COLOR_abstract_compiler__Frame__returnlabel_61d]))(var_frame, var44) /* returnlabel= on <var_frame:Frame>*/;
+if (var50){
+var69 = NEW_abstract_compiler__Frame(&type_abstract_compiler__Frame);
+((void (*)(val*, val*, val*, val*, val*))(var69->class->vft[COLOR_abstract_compiler__Frame__init]))(var69, self, var_mmethoddef, var_recvtype, var_arguments) /* init on <var69:Frame>*/;
+var_frame = var69;
+if (varonce70) {
+var71 = varonce70;
+} else {
+var72 = "RET_LABEL";
+var73 = 9;
+var74 = string__NativeString__to_s_with_length(var72, var73);
+var71 = var74;
+varonce70 = var71;
+}
+var75 = ((val* (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__get_name]))(self, var71) /* get_name on <self:SeparateCompilerVisitor>*/;
+((void (*)(val*, val*))(var_frame->class->vft[COLOR_abstract_compiler__Frame__returnlabel_61d]))(var_frame, var75) /* returnlabel= on <var_frame:Frame>*/;
 ((void (*)(val*, val*))(var_frame->class->vft[COLOR_abstract_compiler__Frame__returnvar_61d]))(var_frame, var_res) /* returnvar= on <var_frame:Frame>*/;
-var45 = ((val* (*)(val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__frame]))(self) /* frame on <self:SeparateCompilerVisitor>*/;
-var_old_frame = var45;
+var76 = ((val* (*)(val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__frame]))(self) /* frame on <self:SeparateCompilerVisitor>*/;
+var_old_frame = var76;
 ((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__frame_61d]))(self, var_frame) /* frame= on <self:SeparateCompilerVisitor>*/;
-if (varonce46) {
-var47 = varonce46;
+if (varonce77) {
+var78 = varonce77;
 } else {
-var48 = "{ /* Inline ";
-var49 = 12;
-var50 = string__NativeString__to_s_with_length(var48, var49);
-var47 = var50;
-varonce46 = var47;
+var79 = "{ /* Inline ";
+var80 = 12;
+var81 = string__NativeString__to_s_with_length(var79, var80);
+var78 = var81;
+varonce77 = var78;
 }
-if (varonce51) {
-var52 = varonce51;
+if (varonce82) {
+var83 = varonce82;
 } else {
-var53 = " (";
-var54 = 2;
-var55 = string__NativeString__to_s_with_length(var53, var54);
-var52 = var55;
-varonce51 = var52;
+var84 = " (";
+var85 = 2;
+var86 = string__NativeString__to_s_with_length(var84, var85);
+var83 = var86;
+varonce82 = var83;
 }
-if (varonce56) {
-var57 = varonce56;
+if (varonce87) {
+var88 = varonce87;
 } else {
-var58 = ",";
-var59 = 1;
-var60 = string__NativeString__to_s_with_length(var58, var59);
-var57 = var60;
-varonce56 = var57;
+var89 = ",";
+var90 = 1;
+var91 = string__NativeString__to_s_with_length(var89, var90);
+var88 = var91;
+varonce87 = var88;
 }
-var61 = ((val* (*)(val*, val*))(var_arguments->class->vft[COLOR_string__Collection__join]))(var_arguments, var57) /* join on <var_arguments:Array[RuntimeVariable]>*/;
-if (varonce62) {
-var63 = varonce62;
+var92 = ((val* (*)(val*, val*))(var_arguments->class->vft[COLOR_string__Collection__join]))(var_arguments, var88) /* join on <var_arguments:Array[RuntimeVariable]>*/;
+if (varonce93) {
+var94 = varonce93;
 } else {
-var64 = ") */";
-var65 = 4;
-var66 = string__NativeString__to_s_with_length(var64, var65);
-var63 = var66;
-varonce62 = var63;
+var95 = ") */";
+var96 = 4;
+var97 = string__NativeString__to_s_with_length(var95, var96);
+var94 = var97;
+varonce93 = var94;
 }
-var67 = NEW_array__Array(&type_array__Arraykernel__Object);
-{ /* var67 = array_instance Array[Object] */
-var68 = 5;
-var69 = NEW_array__NativeArray(var68, &type_array__NativeArraykernel__Object);
-((struct instance_array__NativeArray*)var69)->values[0] = (val*) var47;
-((struct instance_array__NativeArray*)var69)->values[1] = (val*) var_mmethoddef;
-((struct instance_array__NativeArray*)var69)->values[2] = (val*) var52;
-((struct instance_array__NativeArray*)var69)->values[3] = (val*) var61;
-((struct instance_array__NativeArray*)var69)->values[4] = (val*) var63;
-((void (*)(val*, val*, long))(var67->class->vft[COLOR_array__Array__with_native]))(var67, var69, var68) /* with_native on <var67:Array[Object]>*/;
-CHECK_NEW_array__Array(var67);
-}
-var70 = ((val* (*)(val*))(var67->class->vft[COLOR_string__Object__to_s]))(var67) /* to_s on <var67:Array[Object]>*/;
-((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var70) /* add on <self:SeparateCompilerVisitor>*/;
-var71 = ((val* (*)(val*, val*, val*))(var_mmethoddef->class->vft[COLOR_abstract_compiler__MMethodDef__compile_inside_to_c]))(var_mmethoddef, self, var_arguments) /* compile_inside_to_c on <var_mmethoddef:MMethodDef>*/;
-var71;
-var72 = ((val* (*)(val*))(var_frame->class->vft[COLOR_abstract_compiler__Frame__returnlabel]))(var_frame) /* returnlabel on <var_frame:Frame>*/;
-if (var72 == NULL) {
+var98 = NEW_array__Array(&type_array__Arraykernel__Object);
+{ /* var98 = array_instance Array[Object] */
+var99 = 5;
+var100 = NEW_array__NativeArray(var99, &type_array__NativeArraykernel__Object);
+((struct instance_array__NativeArray*)var100)->values[0] = (val*) var78;
+((struct instance_array__NativeArray*)var100)->values[1] = (val*) var_mmethoddef;
+((struct instance_array__NativeArray*)var100)->values[2] = (val*) var83;
+((struct instance_array__NativeArray*)var100)->values[3] = (val*) var92;
+((struct instance_array__NativeArray*)var100)->values[4] = (val*) var94;
+((void (*)(val*, val*, long))(var98->class->vft[COLOR_array__Array__with_native]))(var98, var100, var99) /* with_native on <var98:Array[Object]>*/;
+}
+var101 = ((val* (*)(val*))(var98->class->vft[COLOR_string__Object__to_s]))(var98) /* to_s on <var98:Array[Object]>*/;
+((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var101) /* add on <self:SeparateCompilerVisitor>*/;
+var102 = ((val* (*)(val*, val*, val*))(var_mmethoddef->class->vft[COLOR_abstract_compiler__MMethodDef__compile_inside_to_c]))(var_mmethoddef, self, var_arguments) /* compile_inside_to_c on <var_mmethoddef:MMethodDef>*/;
+var102;
+var103 = ((val* (*)(val*))(var_frame->class->vft[COLOR_abstract_compiler__Frame__returnlabel]))(var_frame) /* returnlabel on <var_frame:Frame>*/;
+if (var103 == NULL) {
 fprintf(stderr, "Runtime error: %s", "Cast failed");
-fprintf(stderr, " (%s:%d)\n", "src/separate_compiler.nit", 1109);
-exit(1);
+fprintf(stderr, " (%s:%d)\n", "src/separate_compiler.nit", 1132);
+show_backtrace(1);
 }
-if (varonce73) {
-var74 = varonce73;
+if (varonce104) {
+var105 = varonce104;
 } else {
-var75 = ":(void)0;";
-var76 = 9;
-var77 = string__NativeString__to_s_with_length(var75, var76);
-var74 = var77;
-varonce73 = var74;
+var106 = ":(void)0;";
+var107 = 9;
+var108 = string__NativeString__to_s_with_length(var106, var107);
+var105 = var108;
+varonce104 = var105;
 }
-var78 = NEW_array__Array(&type_array__Arraykernel__Object);
-{ /* var78 = array_instance Array[Object] */
-var79 = 2;
-var80 = NEW_array__NativeArray(var79, &type_array__NativeArraykernel__Object);
-((struct instance_array__NativeArray*)var80)->values[0] = (val*) var72;
-((struct instance_array__NativeArray*)var80)->values[1] = (val*) var74;
-((void (*)(val*, val*, long))(var78->class->vft[COLOR_array__Array__with_native]))(var78, var80, var79) /* with_native on <var78:Array[Object]>*/;
-CHECK_NEW_array__Array(var78);
+var109 = NEW_array__Array(&type_array__Arraykernel__Object);
+{ /* var109 = array_instance Array[Object] */
+var110 = 2;
+var111 = NEW_array__NativeArray(var110, &type_array__NativeArraykernel__Object);
+((struct instance_array__NativeArray*)var111)->values[0] = (val*) var103;
+((struct instance_array__NativeArray*)var111)->values[1] = (val*) var105;
+((void (*)(val*, val*, long))(var109->class->vft[COLOR_array__Array__with_native]))(var109, var111, var110) /* with_native on <var109:Array[Object]>*/;
 }
-var81 = ((val* (*)(val*))(var78->class->vft[COLOR_string__Object__to_s]))(var78) /* to_s on <var78:Array[Object]>*/;
-((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var81) /* add on <self:SeparateCompilerVisitor>*/;
-if (varonce82) {
-var83 = varonce82;
+var112 = ((val* (*)(val*))(var109->class->vft[COLOR_string__Object__to_s]))(var109) /* to_s on <var109:Array[Object]>*/;
+((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var112) /* add on <self:SeparateCompilerVisitor>*/;
+if (varonce113) {
+var114 = varonce113;
 } else {
-var84 = "}";
-var85 = 1;
-var86 = string__NativeString__to_s_with_length(var84, var85);
-var83 = var86;
-varonce82 = var83;
+var115 = "}";
+var116 = 1;
+var117 = string__NativeString__to_s_with_length(var115, var116);
+var114 = var117;
+varonce113 = var114;
 }
-((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var83) /* add on <self:SeparateCompilerVisitor>*/;
+((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var114) /* add on <self:SeparateCompilerVisitor>*/;
 ((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__frame_61d]))(self, var_old_frame) /* frame= on <self:SeparateCompilerVisitor>*/;
 var = var_res;
 goto RET_LABEL;
 } else {
 }
 ((void (*)(val*, val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__adapt_signature]))(self, var_mmethoddef, var_arguments) /* adapt_signature on <self:SeparateCompilerVisitor>*/;
-var87 = ((val* (*)(val*))(var_mmethoddef->class->vft[COLOR_abstract_compiler__MPropDef__c_name]))(var_mmethoddef) /* c_name on <var_mmethoddef:MMethodDef>*/;
-((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__require_declaration]))(self, var87) /* require_declaration on <self:SeparateCompilerVisitor>*/;
-var88 = NULL;
+var118 = ((val* (*)(val*))(var_mmethoddef->class->vft[COLOR_abstract_compiler__MPropDef__c_name]))(var_mmethoddef) /* c_name on <var_mmethoddef:MMethodDef>*/;
+((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__require_declaration]))(self, var118) /* require_declaration on <self:SeparateCompilerVisitor>*/;
+var119 = NULL;
 if (var_res == NULL) {
-var89 = 1; /* is null */
+var120 = 1; /* is null */
 } else {
-var89 = 0; /* arg is null but recv is not */
+var120 = 0; /* arg is null but recv is not */
 }
-if (var89){
-var90 = ((val* (*)(val*))(var_mmethoddef->class->vft[COLOR_abstract_compiler__MPropDef__c_name]))(var_mmethoddef) /* c_name on <var_mmethoddef:MMethodDef>*/;
-if (varonce91) {
-var92 = varonce91;
+if (var120){
+var121 = ((val* (*)(val*))(var_mmethoddef->class->vft[COLOR_abstract_compiler__MPropDef__c_name]))(var_mmethoddef) /* c_name on <var_mmethoddef:MMethodDef>*/;
+if (varonce122) {
+var123 = varonce122;
 } else {
-var93 = "(";
-var94 = 1;
-var95 = string__NativeString__to_s_with_length(var93, var94);
-var92 = var95;
-varonce91 = var92;
+var124 = "(";
+var125 = 1;
+var126 = string__NativeString__to_s_with_length(var124, var125);
+var123 = var126;
+varonce122 = var123;
 }
-if (varonce96) {
-var97 = varonce96;
+if (varonce127) {
+var128 = varonce127;
 } else {
-var98 = ", ";
-var99 = 2;
-var100 = string__NativeString__to_s_with_length(var98, var99);
-var97 = var100;
-varonce96 = var97;
+var129 = ", ";
+var130 = 2;
+var131 = string__NativeString__to_s_with_length(var129, var130);
+var128 = var131;
+varonce127 = var128;
 }
-var101 = ((val* (*)(val*, val*))(var_arguments->class->vft[COLOR_string__Collection__join]))(var_arguments, var97) /* join on <var_arguments:Array[RuntimeVariable]>*/;
-if (varonce102) {
-var103 = varonce102;
+var132 = ((val* (*)(val*, val*))(var_arguments->class->vft[COLOR_string__Collection__join]))(var_arguments, var128) /* join on <var_arguments:Array[RuntimeVariable]>*/;
+if (varonce133) {
+var134 = varonce133;
 } else {
-var104 = ");";
-var105 = 2;
-var106 = string__NativeString__to_s_with_length(var104, var105);
-var103 = var106;
-varonce102 = var103;
+var135 = ");";
+var136 = 2;
+var137 = string__NativeString__to_s_with_length(var135, var136);
+var134 = var137;
+varonce133 = var134;
+}
+var138 = NEW_array__Array(&type_array__Arraykernel__Object);
+{ /* var138 = array_instance Array[Object] */
+var139 = 4;
+var140 = NEW_array__NativeArray(var139, &type_array__NativeArraykernel__Object);
+((struct instance_array__NativeArray*)var140)->values[0] = (val*) var121;
+((struct instance_array__NativeArray*)var140)->values[1] = (val*) var123;
+((struct instance_array__NativeArray*)var140)->values[2] = (val*) var132;
+((struct instance_array__NativeArray*)var140)->values[3] = (val*) var134;
+((void (*)(val*, val*, long))(var138->class->vft[COLOR_array__Array__with_native]))(var138, var140, var139) /* with_native on <var138:Array[Object]>*/;
 }
-var107 = NEW_array__Array(&type_array__Arraykernel__Object);
-{ /* var107 = array_instance Array[Object] */
-var108 = 4;
-var109 = NEW_array__NativeArray(var108, &type_array__NativeArraykernel__Object);
-((struct instance_array__NativeArray*)var109)->values[0] = (val*) var90;
-((struct instance_array__NativeArray*)var109)->values[1] = (val*) var92;
-((struct instance_array__NativeArray*)var109)->values[2] = (val*) var101;
-((struct instance_array__NativeArray*)var109)->values[3] = (val*) var103;
-((void (*)(val*, val*, long))(var107->class->vft[COLOR_array__Array__with_native]))(var107, var109, var108) /* with_native on <var107:Array[Object]>*/;
-CHECK_NEW_array__Array(var107);
-}
-var110 = ((val* (*)(val*))(var107->class->vft[COLOR_string__Object__to_s]))(var107) /* to_s on <var107:Array[Object]>*/;
-((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var110) /* add on <self:SeparateCompilerVisitor>*/;
-var111 = NULL;
-var = var111;
+var141 = ((val* (*)(val*))(var138->class->vft[COLOR_string__Object__to_s]))(var138) /* to_s on <var138:Array[Object]>*/;
+((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var141) /* add on <self:SeparateCompilerVisitor>*/;
+var142 = NULL;
+var = var142;
 goto RET_LABEL;
 } else {
-if (varonce112) {
-var113 = varonce112;
+if (varonce143) {
+var144 = varonce143;
 } else {
-var114 = " = ";
-var115 = 3;
-var116 = string__NativeString__to_s_with_length(var114, var115);
-var113 = var116;
-varonce112 = var113;
+var145 = " = ";
+var146 = 3;
+var147 = string__NativeString__to_s_with_length(var145, var146);
+var144 = var147;
+varonce143 = var144;
 }
-var117 = ((val* (*)(val*))(var_mmethoddef->class->vft[COLOR_abstract_compiler__MPropDef__c_name]))(var_mmethoddef) /* c_name on <var_mmethoddef:MMethodDef>*/;
-if (varonce118) {
-var119 = varonce118;
-} else {
-var120 = "(";
-var121 = 1;
-var122 = string__NativeString__to_s_with_length(var120, var121);
-var119 = var122;
-varonce118 = var119;
+var148 = ((val* (*)(val*))(var_mmethoddef->class->vft[COLOR_abstract_compiler__MPropDef__c_name]))(var_mmethoddef) /* c_name on <var_mmethoddef:MMethodDef>*/;
+if (varonce149) {
+var150 = varonce149;
+} else {
+var151 = "(";
+var152 = 1;
+var153 = string__NativeString__to_s_with_length(var151, var152);
+var150 = var153;
+varonce149 = var150;
+}
+if (varonce154) {
+var155 = varonce154;
+} else {
+var156 = ", ";
+var157 = 2;
+var158 = string__NativeString__to_s_with_length(var156, var157);
+var155 = var158;
+varonce154 = var155;
+}
+var159 = ((val* (*)(val*, val*))(var_arguments->class->vft[COLOR_string__Collection__join]))(var_arguments, var155) /* join on <var_arguments:Array[RuntimeVariable]>*/;
+if (varonce160) {
+var161 = varonce160;
+} else {
+var162 = ");";
+var163 = 2;
+var164 = string__NativeString__to_s_with_length(var162, var163);
+var161 = var164;
+varonce160 = var161;
+}
+var165 = NEW_array__Array(&type_array__Arraykernel__Object);
+{ /* var165 = array_instance Array[Object] */
+var166 = 6;
+var167 = NEW_array__NativeArray(var166, &type_array__NativeArraykernel__Object);
+((struct instance_array__NativeArray*)var167)->values[0] = (val*) var_res;
+((struct instance_array__NativeArray*)var167)->values[1] = (val*) var144;
+((struct instance_array__NativeArray*)var167)->values[2] = (val*) var148;
+((struct instance_array__NativeArray*)var167)->values[3] = (val*) var150;
+((struct instance_array__NativeArray*)var167)->values[4] = (val*) var159;
+((struct instance_array__NativeArray*)var167)->values[5] = (val*) var161;
+((void (*)(val*, val*, long))(var165->class->vft[COLOR_array__Array__with_native]))(var165, var167, var166) /* with_native on <var165:Array[Object]>*/;
+}
+var168 = ((val* (*)(val*))(var165->class->vft[COLOR_string__Object__to_s]))(var165) /* to_s on <var165:Array[Object]>*/;
+((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var168) /* add on <self:SeparateCompilerVisitor>*/;
 }
-if (varonce123) {
-var124 = varonce123;
-} else {
-var125 = ", ";
-var126 = 2;
-var127 = string__NativeString__to_s_with_length(var125, var126);
-var124 = var127;
-varonce123 = var124;
+var = var_res;
+goto RET_LABEL;
+RET_LABEL:;
+return var;
 }
-var128 = ((val* (*)(val*, val*))(var_arguments->class->vft[COLOR_string__Collection__join]))(var_arguments, var124) /* join on <var_arguments:Array[RuntimeVariable]>*/;
-if (varonce129) {
-var130 = varonce129;
-} else {
-var131 = ");";
-var132 = 2;
-var133 = string__NativeString__to_s_with_length(var131, var132);
-var130 = var133;
-varonce129 = var130;
+/* method separate_compiler#SeparateCompilerVisitor#call for (self: Object, MMethodDef, MClassType, Array[RuntimeVariable]): nullable RuntimeVariable */
+val* VIRTUAL_separate_compiler__SeparateCompilerVisitor__call(val* self, val* p0, val* p1, val* p2) {
+val* var /* : nullable RuntimeVariable */;
+val* var1 /* : nullable RuntimeVariable */;
+var1 = separate_compiler__SeparateCompilerVisitor__call(self, p0, p1, p2);
+var = var1;
+RET_LABEL:;
+return var;
 }
-var134 = NEW_array__Array(&type_array__Arraykernel__Object);
-{ /* var134 = array_instance Array[Object] */
-var135 = 6;
-var136 = NEW_array__NativeArray(var135, &type_array__NativeArraykernel__Object);
-((struct instance_array__NativeArray*)var136)->values[0] = (val*) var_res;
-((struct instance_array__NativeArray*)var136)->values[1] = (val*) var113;
-((struct instance_array__NativeArray*)var136)->values[2] = (val*) var117;
-((struct instance_array__NativeArray*)var136)->values[3] = (val*) var119;
-((struct instance_array__NativeArray*)var136)->values[4] = (val*) var128;
-((struct instance_array__NativeArray*)var136)->values[5] = (val*) var130;
-((void (*)(val*, val*, long))(var134->class->vft[COLOR_array__Array__with_native]))(var134, var136, var135) /* with_native on <var134:Array[Object]>*/;
-CHECK_NEW_array__Array(var134);
-}
-var137 = ((val* (*)(val*))(var134->class->vft[COLOR_string__Object__to_s]))(var134) /* to_s on <var134:Array[Object]>*/;
-((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var137) /* add on <self:SeparateCompilerVisitor>*/;
+/* method separate_compiler#SeparateCompilerVisitor#supercall for (self: SeparateCompilerVisitor, MMethodDef, MClassType, Array[RuntimeVariable]): nullable RuntimeVariable */
+val* separate_compiler__SeparateCompilerVisitor__supercall(val* self, val* p0, val* p1, val* p2) {
+val* var /* : nullable RuntimeVariable */;
+val* var_m /* var m: MMethodDef */;
+val* var_recvtype /* var recvtype: MClassType */;
+val* var_arguments /* var arguments: Array[RuntimeVariable] */;
+val* var1 /* : nullable Object */;
+val* var2 /* : MType */;
+val* var3 /* : String */;
+static val* varonce;
+val* var4 /* : String */;
+char* var5 /* : NativeString */;
+long var6 /* : Int */;
+val* var7 /* : String */;
+short int var8 /* : Bool */;
+val* var9 /* : AbstractCompiler */;
+val* var10 /* : MModule */;
+val* var_main /* var main: MModule */;
+val* var11 /* : AbstractCompiler */;
+val* var12 /* : AbstractCompiler */;
+val* var13 /* : MModule */;
+val* var14 /* : nullable RuntimeVariable */;
+val* var_res /* var res: nullable RuntimeVariable */;
+val* var15 /* : AbstractCompiler */;
+val* var16 /* : MProperty */;
+val* var17 /* : String */;
+val* var18 /* : nullable RuntimeVariable */;
+var_m = p0;
+var_recvtype = p1;
+var_arguments = p2;
+var1 = ((val* (*)(val*))(var_arguments->class->vft[COLOR_abstract_collection__Collection__first]))(var_arguments) /* first on <var_arguments:Array[RuntimeVariable]>*/;
+var2 = ((val* (*)(val*))(var1->class->vft[COLOR_abstract_compiler__RuntimeVariable__mcasttype]))(var1) /* mcasttype on <var1:nullable Object(RuntimeVariable)>*/;
+var3 = ((val* (*)(val*))(var2->class->vft[COLOR_abstract_compiler__MType__ctype]))(var2) /* ctype on <var2:MType>*/;
+if (varonce) {
+var4 = varonce;
+} else {
+var5 = "val*";
+var6 = 4;
+var7 = string__NativeString__to_s_with_length(var5, var6);
+var4 = var7;
+varonce = var4;
 }
+var8 = ((short int (*)(val*, val*))(var3->class->vft[COLOR_kernel__Object___33d_61d]))(var3, var4) /* != on <var3:String>*/;
+if (var8){
+var9 = ((val* (*)(val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__compiler]))(self) /* compiler on <self:SeparateCompilerVisitor>*/;
+var10 = ((val* (*)(val*))(var9->class->vft[COLOR_abstract_compiler__AbstractCompiler__mainmodule]))(var9) /* mainmodule on <var9:AbstractCompiler(SeparateCompiler)>*/;
+var_main = var10;
+var11 = ((val* (*)(val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__compiler]))(self) /* compiler on <self:SeparateCompilerVisitor>*/;
+var12 = ((val* (*)(val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__compiler]))(self) /* compiler on <self:SeparateCompilerVisitor>*/;
+var13 = ((val* (*)(val*))(var12->class->vft[COLOR_abstract_compiler__AbstractCompiler__realmainmodule]))(var12) /* realmainmodule on <var12:AbstractCompiler(SeparateCompiler)>*/;
+((void (*)(val*, val*))(var11->class->vft[COLOR_abstract_compiler__AbstractCompiler__mainmodule_61d]))(var11, var13) /* mainmodule= on <var11:AbstractCompiler(SeparateCompiler)>*/;
+var14 = ((val* (*)(val*, val*, val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__monomorphic_super_send]))(self, var_m, var_recvtype, var_arguments) /* monomorphic_super_send on <self:SeparateCompilerVisitor>*/;
+var_res = var14;
+var15 = ((val* (*)(val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__compiler]))(self) /* compiler on <self:SeparateCompilerVisitor>*/;
+((void (*)(val*, val*))(var15->class->vft[COLOR_abstract_compiler__AbstractCompiler__mainmodule_61d]))(var15, var_main) /* mainmodule= on <var15:AbstractCompiler(SeparateCompiler)>*/;
 var = var_res;
 goto RET_LABEL;
-RET_LABEL:;
-return var;
-}
-/* method separate_compiler#SeparateCompilerVisitor#call for (self: Object, MMethodDef, MClassType, Array[RuntimeVariable]): nullable RuntimeVariable */
-val* VIRTUAL_separate_compiler__SeparateCompilerVisitor__call(val* self, val* p0, val* p1, val* p2) {
-val* var /* : nullable RuntimeVariable */;
-val* var1 /* : nullable RuntimeVariable */;
-var1 = separate_compiler__SeparateCompilerVisitor__call(self, p0, p1, p2);
-var = var1;
-RET_LABEL:;
-return var;
+} else {
 }
-/* method separate_compiler#SeparateCompilerVisitor#supercall for (self: SeparateCompilerVisitor, MMethodDef, MClassType, Array[RuntimeVariable]): nullable RuntimeVariable */
-val* separate_compiler__SeparateCompilerVisitor__supercall(val* self, val* p0, val* p1, val* p2) {
-val* var /* : nullable RuntimeVariable */;
-val* var_m /* var m: MMethodDef */;
-val* var_recvtype /* var recvtype: MClassType */;
-val* var_arguments /* var arguments: Array[RuntimeVariable] */;
-val* var1 /* : MProperty */;
-val* var2 /* : String */;
-val* var3 /* : nullable RuntimeVariable */;
-var_m = p0;
-var_recvtype = p1;
-var_arguments = p2;
-var1 = ((val* (*)(val*))(var_m->class->vft[COLOR_model__MPropDef__mproperty]))(var_m) /* mproperty on <var_m:MMethodDef>*/;
-var2 = ((val* (*)(val*))(var_m->class->vft[COLOR_separate_compiler__MPropDef__const_color]))(var_m) /* const_color on <var_m:MMethodDef>*/;
-var3 = ((val* (*)(val*, val*, val*, val*))(self->class->vft[COLOR_separate_compiler__SeparateCompilerVisitor__table_send]))(self, var1, var_arguments, var2) /* table_send on <self:SeparateCompilerVisitor>*/;
-var = var3;
+var16 = ((val* (*)(val*))(var_m->class->vft[COLOR_model__MPropDef__mproperty]))(var_m) /* mproperty on <var_m:MMethodDef>*/;
+var17 = ((val* (*)(val*))(var_m->class->vft[COLOR_separate_compiler__MPropDef__const_color]))(var_m) /* const_color on <var_m:MMethodDef>*/;
+var18 = ((val* (*)(val*, val*, val*, val*))(self->class->vft[COLOR_separate_compiler__SeparateCompilerVisitor__table_send]))(self, var16, var_arguments, var17) /* table_send on <self:SeparateCompilerVisitor>*/;
+var = var18;
 goto RET_LABEL;
 RET_LABEL:;
 return var;
@@ -2694,11 +2317,9 @@ var4 = ((val* (*)(val*))(var3->class->vft[COLOR_model__MClassDef__bound_mtype]))
 var5 = NEW_array__Array(&type_array__Arrayabstract_compiler__RuntimeVariable);
 var6 = 1;
 ((void (*)(val*, long))(var5->class->vft[COLOR_array__Array__with_capacity]))(var5, var6) /* with_capacity on <var5:Array[RuntimeVariable]>*/;
-CHECK_NEW_array__Array(var5);
 var_ = var5;
 ((void (*)(val*, val*))(var_->class->vft[COLOR_abstract_collection__Sequence__push]))(var_, var_recv) /* push on <var_:Array[RuntimeVariable]>*/;
 ((void (*)(val*, val*, val*, val*, val*))(var2->class->vft[COLOR_abstract_compiler__Frame__init]))(var2, self, var_mpropdef, var4, var_) /* init on <var2:Frame>*/;
-CHECK_NEW_abstract_compiler__Frame(var2);
 var_frame = var2;
 ((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__frame_61d]))(self, var_frame) /* frame= on <self:SeparateCompilerVisitor>*/;
 var7 = ((val* (*)(val*, val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__array_instance]))(self, var_varargs, var_elttype) /* array_instance on <self:SeparateCompilerVisitor>*/;
@@ -2866,8 +2487,8 @@ var3 = ((val* (*)(val*))(var_a->class->vft[COLOR_model__MProperty__intro]))(var_
 var4 = ((val* (*)(val*))(var3->class->vft[COLOR_model__MAttributeDef__static_mtype]))(var3) /* static_mtype on <var3:MPropDef(MAttributeDef)>*/;
 if (var4 == NULL) {
 fprintf(stderr, "Runtime error: %s", "Cast failed");
-fprintf(stderr, " (%s:%d)\n", "src/separate_compiler.nit", 1159);
-exit(1);
+fprintf(stderr, " (%s:%d)\n", "src/separate_compiler.nit", 1191);
+show_backtrace(1);
 }
 var_mtype = var4;
 var5 = ((val* (*)(val*))(var_a->class->vft[COLOR_model__MProperty__intro]))(var_a) /* intro on <var_a:MAttribute>*/;
@@ -2927,7 +2548,6 @@ var30 = NEW_array__NativeArray(var29, &type_array__NativeArraykernel__Object);
 ((struct instance_array__NativeArray*)var30)->values[4] = (val*) var22;
 ((struct instance_array__NativeArray*)var30)->values[5] = (val*) var24;
 ((void (*)(val*, val*, long))(var28->class->vft[COLOR_array__Array__with_native]))(var28, var30, var29) /* with_native on <var28:Array[Object]>*/;
-CHECK_NEW_array__Array(var28);
 }
 var31 = ((val* (*)(val*))(var28->class->vft[COLOR_string__Object__to_s]))(var28) /* to_s on <var28:Array[Object]>*/;
 ((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var31) /* add on <self:SeparateCompilerVisitor>*/;
@@ -3006,7 +2626,6 @@ var68 = NEW_array__NativeArray(var67, &type_array__NativeArraykernel__Object);
 ((struct instance_array__NativeArray*)var68)->values[8] = (val*) var60;
 ((struct instance_array__NativeArray*)var68)->values[9] = (val*) var62;
 ((void (*)(val*, val*, long))(var66->class->vft[COLOR_array__Array__with_native]))(var66, var68, var67) /* with_native on <var66:Array[Object]>*/;
-CHECK_NEW_array__Array(var66);
 }
 var69 = ((val* (*)(val*))(var66->class->vft[COLOR_string__Object__to_s]))(var66) /* to_s on <var66:Array[Object]>*/;
 ((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var69) /* add on <self:SeparateCompilerVisitor>*/;
@@ -3085,7 +2704,6 @@ var106 = NEW_array__NativeArray(var105, &type_array__NativeArraykernel__Object);
 ((struct instance_array__NativeArray*)var106)->values[8] = (val*) var98;
 ((struct instance_array__NativeArray*)var106)->values[9] = (val*) var100;
 ((void (*)(val*, val*, long))(var104->class->vft[COLOR_array__Array__with_native]))(var104, var106, var105) /* with_native on <var104:Array[Object]>*/;
-CHECK_NEW_array__Array(var104);
 }
 var107 = ((val* (*)(val*))(var104->class->vft[COLOR_string__Object__to_s]))(var104) /* to_s on <var104:Array[Object]>*/;
 ((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var107) /* add on <self:SeparateCompilerVisitor>*/;
@@ -3129,7 +2747,6 @@ var126 = NEW_array__NativeArray(var125, &type_array__NativeArraykernel__Object);
 ((struct instance_array__NativeArray*)var126)->values[4] = (val*) var118;
 ((struct instance_array__NativeArray*)var126)->values[5] = (val*) var120;
 ((void (*)(val*, val*, long))(var124->class->vft[COLOR_array__Array__with_native]))(var124, var126, var125) /* with_native on <var124:Array[Object]>*/;
-CHECK_NEW_array__Array(var124);
 }
 var127 = ((val* (*)(val*))(var124->class->vft[COLOR_string__Object__to_s]))(var124) /* to_s on <var124:Array[Object]>*/;
 ((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var127) /* add on <self:SeparateCompilerVisitor>*/;
@@ -3348,8 +2965,8 @@ var1 = ((val* (*)(val*))(var_a->class->vft[COLOR_model__MProperty__intro]))(var_
 var2 = ((val* (*)(val*))(var1->class->vft[COLOR_model__MAttributeDef__static_mtype]))(var1) /* static_mtype on <var1:MPropDef(MAttributeDef)>*/;
 if (var2 == NULL) {
 fprintf(stderr, "Runtime error: %s", "Cast failed");
-fprintf(stderr, " (%s:%d)\n", "src/separate_compiler.nit", 1187);
-exit(1);
+fprintf(stderr, " (%s:%d)\n", "src/separate_compiler.nit", 1219);
+show_backtrace(1);
 }
 var_ret = var2;
 var3 = ((val* (*)(val*))(var_a->class->vft[COLOR_model__MProperty__intro]))(var_a) /* intro on <var_a:MAttribute>*/;
@@ -3438,7 +3055,6 @@ var48 = NEW_array__NativeArray(var47, &type_array__NativeArraykernel__Object);
 ((struct instance_array__NativeArray*)var48)->values[8] = (val*) var40;
 ((struct instance_array__NativeArray*)var48)->values[9] = (val*) var42;
 ((void (*)(val*, val*, long))(var46->class->vft[COLOR_array__Array__with_native]))(var46, var48, var47) /* with_native on <var46:Array[Object]>*/;
-CHECK_NEW_array__Array(var46);
 }
 var49 = ((val* (*)(val*))(var46->class->vft[COLOR_string__Object__to_s]))(var46) /* to_s on <var46:Array[Object]>*/;
 ((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var49) /* add on <self:SeparateCompilerVisitor>*/;
@@ -3491,7 +3107,6 @@ var72 = NEW_array__NativeArray(var71, &type_array__NativeArraykernel__Object);
 ((struct instance_array__NativeArray*)var72)->values[1] = (val*) var_res;
 ((struct instance_array__NativeArray*)var72)->values[2] = (val*) var66;
 ((void (*)(val*, val*, long))(var70->class->vft[COLOR_array__Array__with_native]))(var70, var72, var71) /* with_native on <var70:Array[Object]>*/;
-CHECK_NEW_array__Array(var70);
 }
 var73 = ((val* (*)(val*))(var70->class->vft[COLOR_string__Object__to_s]))(var70) /* to_s on <var70:Array[Object]>*/;
 ((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var73) /* add on <self:SeparateCompilerVisitor>*/;
@@ -3512,7 +3127,6 @@ var82 = NEW_array__NativeArray(var81, &type_array__NativeArraykernel__Object);
 ((struct instance_array__NativeArray*)var82)->values[0] = (val*) var75;
 ((struct instance_array__NativeArray*)var82)->values[1] = (val*) var79;
 ((void (*)(val*, val*, long))(var80->class->vft[COLOR_array__Array__with_native]))(var80, var82, var81) /* with_native on <var80:Array[Object]>*/;
-CHECK_NEW_array__Array(var80);
 }
 var83 = ((val* (*)(val*))(var80->class->vft[COLOR_string__Object__to_s]))(var80) /* to_s on <var80:Array[Object]>*/;
 ((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add_abort]))(self, var83) /* add_abort on <self:SeparateCompilerVisitor>*/;
@@ -3608,7 +3222,6 @@ var127 = NEW_array__NativeArray(var126, &type_array__NativeArraykernel__Object);
 ((struct instance_array__NativeArray*)var127)->values[10] = (val*) var119;
 ((struct instance_array__NativeArray*)var127)->values[11] = (val*) var121;
 ((void (*)(val*, val*, long))(var125->class->vft[COLOR_array__Array__with_native]))(var125, var127, var126) /* with_native on <var125:Array[Object]>*/;
-CHECK_NEW_array__Array(var125);
 }
 var128 = ((val* (*)(val*))(var125->class->vft[COLOR_string__Object__to_s]))(var125) /* to_s on <var125:Array[Object]>*/;
 ((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var128) /* add on <self:SeparateCompilerVisitor>*/;
@@ -3678,7 +3291,6 @@ var163 = NEW_array__NativeArray(var162, &type_array__NativeArraykernel__Object);
 ((struct instance_array__NativeArray*)var163)->values[1] = (val*) var_res91;
 ((struct instance_array__NativeArray*)var163)->values[2] = (val*) var157;
 ((void (*)(val*, val*, long))(var161->class->vft[COLOR_array__Array__with_native]))(var161, var163, var162) /* with_native on <var161:Array[Object]>*/;
-CHECK_NEW_array__Array(var161);
 }
 var164 = ((val* (*)(val*))(var161->class->vft[COLOR_string__Object__to_s]))(var161) /* to_s on <var161:Array[Object]>*/;
 ((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var164) /* add on <self:SeparateCompilerVisitor>*/;
@@ -3699,7 +3311,6 @@ var173 = NEW_array__NativeArray(var172, &type_array__NativeArraykernel__Object);
 ((struct instance_array__NativeArray*)var173)->values[0] = (val*) var166;
 ((struct instance_array__NativeArray*)var173)->values[1] = (val*) var170;
 ((void (*)(val*, val*, long))(var171->class->vft[COLOR_array__Array__with_native]))(var171, var173, var172) /* with_native on <var171:Array[Object]>*/;
-CHECK_NEW_array__Array(var171);
 }
 var174 = ((val* (*)(val*))(var171->class->vft[COLOR_string__Object__to_s]))(var171) /* to_s on <var171:Array[Object]>*/;
 ((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add_abort]))(self, var174) /* add_abort on <self:SeparateCompilerVisitor>*/;
@@ -3943,8 +3554,8 @@ var = ((val* (*)(val*))(var_a->class->vft[COLOR_model__MProperty__intro]))(var_a
 var1 = ((val* (*)(val*))(var->class->vft[COLOR_model__MAttributeDef__static_mtype]))(var) /* static_mtype on <var:MPropDef(MAttributeDef)>*/;
 if (var1 == NULL) {
 fprintf(stderr, "Runtime error: %s", "Cast failed");
-fprintf(stderr, " (%s:%d)\n", "src/separate_compiler.nit", 1230);
-exit(1);
+fprintf(stderr, " (%s:%d)\n", "src/separate_compiler.nit", 1262);
+show_backtrace(1);
 }
 var_mtype = var1;
 var2 = ((val* (*)(val*))(var_a->class->vft[COLOR_model__MProperty__intro]))(var_a) /* intro on <var_a:MAttribute>*/;
@@ -3970,7 +3581,6 @@ if (var16){
 var17 = NEW_array__Array(&type_array__Arraykernel__Object);
 var18 = 5;
 ((void (*)(val*, long))(var17->class->vft[COLOR_array__Array__with_capacity]))(var17, var18) /* with_capacity on <var17:Array[Object]>*/;
-CHECK_NEW_array__Array(var17);
 var_ = var17;
 if (varonce) {
 var19 = varonce;
@@ -4029,8 +3639,8 @@ var42 = var_mtype->type->type_table[cltype] == idtype;
 }
 if (!var42) {
 fprintf(stderr, "Runtime error: %s", "Assert failed");
-fprintf(stderr, " (%s:%d)\n", "src/separate_compiler.nit", 1241);
-exit(1);
+fprintf(stderr, " (%s:%d)\n", "src/separate_compiler.nit", 1273);
+show_backtrace(1);
 }
 if (varonce43) {
 var44 = varonce43;
@@ -4058,7 +3668,6 @@ var55 = NEW_array__NativeArray(var54, &type_array__NativeArraykernel__Object);
 ((struct instance_array__NativeArray*)var55)->values[1] = (val*) var_attr;
 ((struct instance_array__NativeArray*)var55)->values[2] = (val*) var49;
 ((void (*)(val*, val*, long))(var53->class->vft[COLOR_array__Array__with_native]))(var53, var55, var54) /* with_native on <var53:Array[Object]>*/;
-CHECK_NEW_array__Array(var53);
 }
 var56 = ((val* (*)(val*))(var53->class->vft[COLOR_string__Object__to_s]))(var53) /* to_s on <var53:Array[Object]>*/;
 ((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var56) /* add on <self:SeparateCompilerVisitor>*/;
@@ -4071,7 +3680,7 @@ var61 = string__NativeString__to_s_with_length(var59, var60);
 var58 = var61;
 varonce57 = var58;
 }
-var62 = ((val* (*)(val*))(var_mtype->class->vft[COLOR_abstract_compiler__MType__c_name]))(var_mtype) /* c_name on <var_mtype:MType(MClassType)>*/;
+var62 = ((val* (*)(val*))(var_mtype->class->vft[COLOR_separate_compiler__MType__c_instance_name]))(var_mtype) /* c_instance_name on <var_mtype:MType(MClassType)>*/;
 if (varonce63) {
 var64 = varonce63;
 } else {
@@ -4134,7 +3743,6 @@ var91 = NEW_array__NativeArray(var90, &type_array__NativeArraykernel__Object);
 ((struct instance_array__NativeArray*)var91)->values[9] = (val*) var83;
 ((struct instance_array__NativeArray*)var91)->values[10] = (val*) var85;
 ((void (*)(val*, val*, long))(var89->class->vft[COLOR_array__Array__with_native]))(var89, var91, var90) /* with_native on <var89:Array[Object]>*/;
-CHECK_NEW_array__Array(var89);
 }
 var92 = ((val* (*)(val*))(var89->class->vft[COLOR_string__Object__to_s]))(var89) /* to_s on <var89:Array[Object]>*/;
 ((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var92) /* add on <self:SeparateCompilerVisitor>*/;
@@ -4202,7 +3810,6 @@ var124 = NEW_array__NativeArray(var123, &type_array__NativeArraykernel__Object);
 ((struct instance_array__NativeArray*)var124)->values[6] = (val*) var116;
 ((struct instance_array__NativeArray*)var124)->values[7] = (val*) var118;
 ((void (*)(val*, val*, long))(var122->class->vft[COLOR_array__Array__with_native]))(var122, var124, var123) /* with_native on <var122:Array[Object]>*/;
-CHECK_NEW_array__Array(var122);
 }
 var125 = ((val* (*)(val*))(var122->class->vft[COLOR_string__Object__to_s]))(var122) /* to_s on <var122:Array[Object]>*/;
 ((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var125) /* add on <self:SeparateCompilerVisitor>*/;
@@ -4267,96 +3874,484 @@ var154 = NEW_array__NativeArray(var153, &type_array__NativeArraykernel__Object);
 ((struct instance_array__NativeArray*)var154)->values[6] = (val*) var146;
 ((struct instance_array__NativeArray*)var154)->values[7] = (val*) var148;
 ((void (*)(val*, val*, long))(var152->class->vft[COLOR_array__Array__with_native]))(var152, var154, var153) /* with_native on <var152:Array[Object]>*/;
-CHECK_NEW_array__Array(var152);
 }
 var155 = ((val* (*)(val*))(var152->class->vft[COLOR_string__Object__to_s]))(var152) /* to_s on <var152:Array[Object]>*/;
 ((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var155) /* add on <self:SeparateCompilerVisitor>*/;
 }
 } else {
-if (varonce156) {
-var157 = varonce156;
+if (varonce156) {
+var157 = varonce156;
+} else {
+var158 = "->attrs[";
+var159 = 8;
+var160 = string__NativeString__to_s_with_length(var158, var159);
+var157 = var160;
+varonce156 = var157;
+}
+var161 = ((val* (*)(val*))(var_a->class->vft[COLOR_separate_compiler__MProperty__const_color]))(var_a) /* const_color on <var_a:MAttribute>*/;
+if (varonce162) {
+var163 = varonce162;
+} else {
+var164 = "].";
+var165 = 2;
+var166 = string__NativeString__to_s_with_length(var164, var165);
+var163 = var166;
+varonce162 = var163;
+}
+var167 = ((val* (*)(val*))(var_mtype->class->vft[COLOR_abstract_compiler__MType__ctypename]))(var_mtype) /* ctypename on <var_mtype:MType>*/;
+if (varonce168) {
+var169 = varonce168;
+} else {
+var170 = " = ";
+var171 = 3;
+var172 = string__NativeString__to_s_with_length(var170, var171);
+var169 = var172;
+varonce168 = var169;
+}
+if (varonce173) {
+var174 = varonce173;
+} else {
+var175 = "; /* ";
+var176 = 5;
+var177 = string__NativeString__to_s_with_length(var175, var176);
+var174 = var177;
+varonce173 = var174;
+}
+if (varonce178) {
+var179 = varonce178;
+} else {
+var180 = " on ";
+var181 = 4;
+var182 = string__NativeString__to_s_with_length(var180, var181);
+var179 = var182;
+varonce178 = var179;
+}
+var183 = ((val* (*)(val*))(var_recv->class->vft[COLOR_string__Object__inspect]))(var_recv) /* inspect on <var_recv:RuntimeVariable>*/;
+if (varonce184) {
+var185 = varonce184;
+} else {
+var186 = " */";
+var187 = 3;
+var188 = string__NativeString__to_s_with_length(var186, var187);
+var185 = var188;
+varonce184 = var185;
+}
+var189 = NEW_array__Array(&type_array__Arraykernel__Object);
+{ /* var189 = array_instance Array[Object] */
+var190 = 12;
+var191 = NEW_array__NativeArray(var190, &type_array__NativeArraykernel__Object);
+((struct instance_array__NativeArray*)var191)->values[0] = (val*) var_recv;
+((struct instance_array__NativeArray*)var191)->values[1] = (val*) var157;
+((struct instance_array__NativeArray*)var191)->values[2] = (val*) var161;
+((struct instance_array__NativeArray*)var191)->values[3] = (val*) var163;
+((struct instance_array__NativeArray*)var191)->values[4] = (val*) var167;
+((struct instance_array__NativeArray*)var191)->values[5] = (val*) var169;
+((struct instance_array__NativeArray*)var191)->values[6] = (val*) var_value;
+((struct instance_array__NativeArray*)var191)->values[7] = (val*) var174;
+((struct instance_array__NativeArray*)var191)->values[8] = (val*) var_a;
+((struct instance_array__NativeArray*)var191)->values[9] = (val*) var179;
+((struct instance_array__NativeArray*)var191)->values[10] = (val*) var183;
+((struct instance_array__NativeArray*)var191)->values[11] = (val*) var185;
+((void (*)(val*, val*, long))(var189->class->vft[COLOR_array__Array__with_native]))(var189, var191, var190) /* with_native on <var189:Array[Object]>*/;
+}
+var192 = ((val* (*)(val*))(var189->class->vft[COLOR_string__Object__to_s]))(var189) /* to_s on <var189:Array[Object]>*/;
+((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var192) /* add on <self:SeparateCompilerVisitor>*/;
+}
+RET_LABEL:;
+}
+/* method separate_compiler#SeparateCompilerVisitor#write_attribute for (self: Object, MAttribute, RuntimeVariable, RuntimeVariable) */
+void VIRTUAL_separate_compiler__SeparateCompilerVisitor__write_attribute(val* self, val* p0, val* p1, val* p2) {
+separate_compiler__SeparateCompilerVisitor__write_attribute(self, p0, p1, p2);
+RET_LABEL:;
+}
+/* method separate_compiler#SeparateCompilerVisitor#hardening_live_open_type for (self: SeparateCompilerVisitor, MType) */
+void separate_compiler__SeparateCompilerVisitor__hardening_live_open_type(val* self, val* p0) {
+val* var_mtype /* var mtype: MType */;
+val* var /* : AbstractCompiler */;
+val* var1 /* : ModelBuilder */;
+val* var2 /* : ToolContext */;
+val* var3 /* : OptionBool */;
+val* var4 /* : nullable Object */;
+short int var5 /* : Bool */;
+short int var6 /* : Bool */;
+val* var7 /* : String */;
+val* var8 /* : String */;
+val* var_col /* var col: String */;
+static val* varonce;
+val* var9 /* : String */;
+char* var10 /* : NativeString */;
+long var11 /* : Int */;
+val* var12 /* : String */;
+static val* varonce13;
+val* var14 /* : String */;
+char* var15 /* : NativeString */;
+long var16 /* : Int */;
+val* var17 /* : String */;
+val* var18 /* : Array[Object] */;
+long var19 /* : Int */;
+val* var20 /* : NativeArray[Object] */;
+val* var21 /* : String */;
+static val* varonce22;
+val* var23 /* : String */;
+char* var24 /* : NativeString */;
+long var25 /* : Int */;
+val* var26 /* : String */;
+val* var27 /* : String */;
+val* var28 /* : String */;
+static val* varonce29;
+val* var30 /* : String */;
+char* var31 /* : NativeString */;
+long var32 /* : Int */;
+val* var33 /* : String */;
+val* var34 /* : Array[Object] */;
+long var35 /* : Int */;
+val* var36 /* : NativeArray[Object] */;
+val* var37 /* : String */;
+static val* varonce38;
+val* var39 /* : String */;
+char* var40 /* : NativeString */;
+long var41 /* : Int */;
+val* var42 /* : String */;
+static val* varonce43;
+val* var44 /* : String */;
+char* var45 /* : NativeString */;
+long var46 /* : Int */;
+val* var47 /* : String */;
+var_mtype = p0;
+var = ((val* (*)(val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__compiler]))(self) /* compiler on <self:SeparateCompilerVisitor>*/;
+var1 = ((val* (*)(val*))(var->class->vft[COLOR_abstract_compiler__AbstractCompiler__modelbuilder]))(var) /* modelbuilder on <var:AbstractCompiler(SeparateCompiler)>*/;
+var2 = ((val* (*)(val*))(var1->class->vft[COLOR_modelbuilder__ModelBuilder__toolcontext]))(var1) /* toolcontext on <var1:ModelBuilder>*/;
+var3 = ((val* (*)(val*))(var2->class->vft[COLOR_abstract_compiler__ToolContext__opt_hardening]))(var2) /* opt_hardening on <var2:ToolContext>*/;
+var4 = ((val* (*)(val*))(var3->class->vft[COLOR_opts__Option__value]))(var3) /* value on <var3:OptionBool>*/;
+var5 = ((struct instance_kernel__Bool*)var4)->value; /* autounbox from nullable Object to Bool */;
+var6 = !var5;
+if (var6){
+goto RET_LABEL;
+} else {
+}
+var7 = ((val* (*)(val*))(var_mtype->class->vft[COLOR_separate_compiler__MType__const_color]))(var_mtype) /* const_color on <var_mtype:MType>*/;
+((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__require_declaration]))(self, var7) /* require_declaration on <self:SeparateCompilerVisitor>*/;
+var8 = ((val* (*)(val*))(var_mtype->class->vft[COLOR_separate_compiler__MType__const_color]))(var_mtype) /* const_color on <var_mtype:MType>*/;
+var_col = var8;
+if (varonce) {
+var9 = varonce;
+} else {
+var10 = "if(";
+var11 = 3;
+var12 = string__NativeString__to_s_with_length(var10, var11);
+var9 = var12;
+varonce = var9;
+}
+if (varonce13) {
+var14 = varonce13;
+} else {
+var15 = " == -1) {";
+var16 = 9;
+var17 = string__NativeString__to_s_with_length(var15, var16);
+var14 = var17;
+varonce13 = var14;
+}
+var18 = NEW_array__Array(&type_array__Arraykernel__Object);
+{ /* var18 = array_instance Array[Object] */
+var19 = 3;
+var20 = NEW_array__NativeArray(var19, &type_array__NativeArraykernel__Object);
+((struct instance_array__NativeArray*)var20)->values[0] = (val*) var9;
+((struct instance_array__NativeArray*)var20)->values[1] = (val*) var_col;
+((struct instance_array__NativeArray*)var20)->values[2] = (val*) var14;
+((void (*)(val*, val*, long))(var18->class->vft[COLOR_array__Array__with_native]))(var18, var20, var19) /* with_native on <var18:Array[Object]>*/;
+}
+var21 = ((val* (*)(val*))(var18->class->vft[COLOR_string__Object__to_s]))(var18) /* to_s on <var18:Array[Object]>*/;
+((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var21) /* add on <self:SeparateCompilerVisitor>*/;
+if (varonce22) {
+var23 = varonce22;
+} else {
+var24 = "fprintf(stderr, \"Resolution of a dead open type: %s\\n\", \"";
+var25 = 57;
+var26 = string__NativeString__to_s_with_length(var24, var25);
+var23 = var26;
+varonce22 = var23;
+}
+var27 = ((val* (*)(val*))(var_mtype->class->vft[COLOR_string__Object__to_s]))(var_mtype) /* to_s on <var_mtype:MType>*/;
+var28 = ((val* (*)(val*))(var27->class->vft[COLOR_string__AbstractString__escape_to_c]))(var27) /* escape_to_c on <var27:String>*/;
+if (varonce29) {
+var30 = varonce29;
+} else {
+var31 = "\");";
+var32 = 3;
+var33 = string__NativeString__to_s_with_length(var31, var32);
+var30 = var33;
+varonce29 = var30;
+}
+var34 = NEW_array__Array(&type_array__Arraykernel__Object);
+{ /* var34 = array_instance Array[Object] */
+var35 = 3;
+var36 = NEW_array__NativeArray(var35, &type_array__NativeArraykernel__Object);
+((struct instance_array__NativeArray*)var36)->values[0] = (val*) var23;
+((struct instance_array__NativeArray*)var36)->values[1] = (val*) var28;
+((struct instance_array__NativeArray*)var36)->values[2] = (val*) var30;
+((void (*)(val*, val*, long))(var34->class->vft[COLOR_array__Array__with_native]))(var34, var36, var35) /* with_native on <var34:Array[Object]>*/;
+}
+var37 = ((val* (*)(val*))(var34->class->vft[COLOR_string__Object__to_s]))(var34) /* to_s on <var34:Array[Object]>*/;
+((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var37) /* add on <self:SeparateCompilerVisitor>*/;
+if (varonce38) {
+var39 = varonce38;
+} else {
+var40 = "open type dead";
+var41 = 14;
+var42 = string__NativeString__to_s_with_length(var40, var41);
+var39 = var42;
+varonce38 = var39;
+}
+((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add_abort]))(self, var39) /* add_abort on <self:SeparateCompilerVisitor>*/;
+if (varonce43) {
+var44 = varonce43;
+} else {
+var45 = "}";
+var46 = 1;
+var47 = string__NativeString__to_s_with_length(var45, var46);
+var44 = var47;
+varonce43 = var44;
+}
+((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var44) /* add on <self:SeparateCompilerVisitor>*/;
+RET_LABEL:;
+}
+/* method separate_compiler#SeparateCompilerVisitor#hardening_live_open_type for (self: Object, MType) */
+void VIRTUAL_separate_compiler__SeparateCompilerVisitor__hardening_live_open_type(val* self, val* p0) {
+separate_compiler__SeparateCompilerVisitor__hardening_live_open_type(self, p0);
+RET_LABEL:;
+}
+/* method separate_compiler#SeparateCompilerVisitor#hardening_cast_type for (self: SeparateCompilerVisitor, String) */
+void separate_compiler__SeparateCompilerVisitor__hardening_cast_type(val* self, val* p0) {
+val* var_t /* var t: String */;
+val* var /* : AbstractCompiler */;
+val* var1 /* : ModelBuilder */;
+val* var2 /* : ToolContext */;
+val* var3 /* : OptionBool */;
+val* var4 /* : nullable Object */;
+short int var5 /* : Bool */;
+short int var6 /* : Bool */;
+static val* varonce;
+val* var7 /* : String */;
+char* var8 /* : NativeString */;
+long var9 /* : Int */;
+val* var10 /* : String */;
+static val* varonce11;
+val* var12 /* : String */;
+char* var13 /* : NativeString */;
+long var14 /* : Int */;
+val* var15 /* : String */;
+val* var16 /* : Array[Object] */;
+long var17 /* : Int */;
+val* var18 /* : NativeArray[Object] */;
+val* var19 /* : String */;
+static val* varonce20;
+val* var21 /* : String */;
+char* var22 /* : NativeString */;
+long var23 /* : Int */;
+val* var24 /* : String */;
+static val* varonce25;
+val* var26 /* : String */;
+char* var27 /* : NativeString */;
+long var28 /* : Int */;
+val* var29 /* : String */;
+static val* varonce30;
+val* var31 /* : String */;
+char* var32 /* : NativeString */;
+long var33 /* : Int */;
+val* var34 /* : String */;
+static val* varonce35;
+val* var36 /* : String */;
+char* var37 /* : NativeString */;
+long var38 /* : Int */;
+val* var39 /* : String */;
+static val* varonce40;
+val* var41 /* : String */;
+char* var42 /* : NativeString */;
+long var43 /* : Int */;
+val* var44 /* : String */;
+val* var45 /* : Array[Object] */;
+long var46 /* : Int */;
+val* var47 /* : NativeArray[Object] */;
+val* var48 /* : String */;
+static val* varonce49;
+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 */;
+val* var59 /* : Array[Object] */;
+long var60 /* : Int */;
+val* var61 /* : NativeArray[Object] */;
+val* var62 /* : String */;
+static val* varonce63;
+val* var64 /* : String */;
+char* var65 /* : NativeString */;
+long var66 /* : Int */;
+val* var67 /* : String */;
+static val* varonce68;
+val* var69 /* : String */;
+char* var70 /* : NativeString */;
+long var71 /* : Int */;
+val* var72 /* : String */;
+var_t = p0;
+var = ((val* (*)(val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__compiler]))(self) /* compiler on <self:SeparateCompilerVisitor>*/;
+var1 = ((val* (*)(val*))(var->class->vft[COLOR_abstract_compiler__AbstractCompiler__modelbuilder]))(var) /* modelbuilder on <var:AbstractCompiler(SeparateCompiler)>*/;
+var2 = ((val* (*)(val*))(var1->class->vft[COLOR_modelbuilder__ModelBuilder__toolcontext]))(var1) /* toolcontext on <var1:ModelBuilder>*/;
+var3 = ((val* (*)(val*))(var2->class->vft[COLOR_abstract_compiler__ToolContext__opt_hardening]))(var2) /* opt_hardening on <var2:ToolContext>*/;
+var4 = ((val* (*)(val*))(var3->class->vft[COLOR_opts__Option__value]))(var3) /* value on <var3:OptionBool>*/;
+var5 = ((struct instance_kernel__Bool*)var4)->value; /* autounbox from nullable Object to Bool */;
+var6 = !var5;
+if (var6){
+goto RET_LABEL;
+} else {
+}
+if (varonce) {
+var7 = varonce;
+} else {
+var8 = "if(";
+var9 = 3;
+var10 = string__NativeString__to_s_with_length(var8, var9);
+var7 = var10;
+varonce = var7;
+}
+if (varonce11) {
+var12 = varonce11;
 } else {
-var158 = "->attrs[";
-var159 = 8;
-var160 = string__NativeString__to_s_with_length(var158, var159);
-var157 = var160;
-varonce156 = var157;
+var13 = " == NULL) {";
+var14 = 11;
+var15 = string__NativeString__to_s_with_length(var13, var14);
+var12 = var15;
+varonce11 = var12;
 }
-var161 = ((val* (*)(val*))(var_a->class->vft[COLOR_separate_compiler__MProperty__const_color]))(var_a) /* const_color on <var_a:MAttribute>*/;
-if (varonce162) {
-var163 = varonce162;
+var16 = NEW_array__Array(&type_array__Arraykernel__Object);
+{ /* var16 = array_instance Array[Object] */
+var17 = 3;
+var18 = NEW_array__NativeArray(var17, &type_array__NativeArraykernel__Object);
+((struct instance_array__NativeArray*)var18)->values[0] = (val*) var7;
+((struct instance_array__NativeArray*)var18)->values[1] = (val*) var_t;
+((struct instance_array__NativeArray*)var18)->values[2] = (val*) var12;
+((void (*)(val*, val*, long))(var16->class->vft[COLOR_array__Array__with_native]))(var16, var18, var17) /* with_native on <var16:Array[Object]>*/;
+}
+var19 = ((val* (*)(val*))(var16->class->vft[COLOR_string__Object__to_s]))(var16) /* to_s on <var16:Array[Object]>*/;
+((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var19) /* add on <self:SeparateCompilerVisitor>*/;
+if (varonce20) {
+var21 = varonce20;
 } else {
-var164 = "].";
-var165 = 2;
-var166 = string__NativeString__to_s_with_length(var164, var165);
-var163 = var166;
-varonce162 = var163;
+var22 = "cast type null";
+var23 = 14;
+var24 = string__NativeString__to_s_with_length(var22, var23);
+var21 = var24;
+varonce20 = var21;
 }
-var167 = ((val* (*)(val*))(var_mtype->class->vft[COLOR_abstract_compiler__MType__ctypename]))(var_mtype) /* ctypename on <var_mtype:MType>*/;
-if (varonce168) {
-var169 = varonce168;
+((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add_abort]))(self, var21) /* add_abort on <self:SeparateCompilerVisitor>*/;
+if (varonce25) {
+var26 = varonce25;
 } else {
-var170 = " = ";
-var171 = 3;
-var172 = string__NativeString__to_s_with_length(var170, var171);
-var169 = var172;
-varonce168 = var169;
+var27 = "}";
+var28 = 1;
+var29 = string__NativeString__to_s_with_length(var27, var28);
+var26 = var29;
+varonce25 = var26;
 }
-if (varonce173) {
-var174 = varonce173;
+((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var26) /* add on <self:SeparateCompilerVisitor>*/;
+if (varonce30) {
+var31 = varonce30;
 } else {
-var175 = "; /* ";
-var176 = 5;
-var177 = string__NativeString__to_s_with_length(var175, var176);
-var174 = var177;
-varonce173 = var174;
+var32 = "if(";
+var33 = 3;
+var34 = string__NativeString__to_s_with_length(var32, var33);
+var31 = var34;
+varonce30 = var31;
 }
-if (varonce178) {
-var179 = varonce178;
+if (varonce35) {
+var36 = varonce35;
 } else {
-var180 = " on ";
-var181 = 4;
-var182 = string__NativeString__to_s_with_length(var180, var181);
-var179 = var182;
-varonce178 = var179;
+var37 = "->id == -1 || ";
+var38 = 14;
+var39 = string__NativeString__to_s_with_length(var37, var38);
+var36 = var39;
+varonce35 = var36;
 }
-var183 = ((val* (*)(val*))(var_recv->class->vft[COLOR_string__Object__inspect]))(var_recv) /* inspect on <var_recv:RuntimeVariable>*/;
-if (varonce184) {
-var185 = varonce184;
+if (varonce40) {
+var41 = varonce40;
 } else {
-var186 = " */";
-var187 = 3;
-var188 = string__NativeString__to_s_with_length(var186, var187);
-var185 = var188;
-varonce184 = var185;
+var42 = "->color == -1) {";
+var43 = 16;
+var44 = string__NativeString__to_s_with_length(var42, var43);
+var41 = var44;
+varonce40 = var41;
 }
-var189 = NEW_array__Array(&type_array__Arraykernel__Object);
-{ /* var189 = array_instance Array[Object] */
-var190 = 12;
-var191 = NEW_array__NativeArray(var190, &type_array__NativeArraykernel__Object);
-((struct instance_array__NativeArray*)var191)->values[0] = (val*) var_recv;
-((struct instance_array__NativeArray*)var191)->values[1] = (val*) var157;
-((struct instance_array__NativeArray*)var191)->values[2] = (val*) var161;
-((struct instance_array__NativeArray*)var191)->values[3] = (val*) var163;
-((struct instance_array__NativeArray*)var191)->values[4] = (val*) var167;
-((struct instance_array__NativeArray*)var191)->values[5] = (val*) var169;
-((struct instance_array__NativeArray*)var191)->values[6] = (val*) var_value;
-((struct instance_array__NativeArray*)var191)->values[7] = (val*) var174;
-((struct instance_array__NativeArray*)var191)->values[8] = (val*) var_a;
-((struct instance_array__NativeArray*)var191)->values[9] = (val*) var179;
-((struct instance_array__NativeArray*)var191)->values[10] = (val*) var183;
-((struct instance_array__NativeArray*)var191)->values[11] = (val*) var185;
-((void (*)(val*, val*, long))(var189->class->vft[COLOR_array__Array__with_native]))(var189, var191, var190) /* with_native on <var189:Array[Object]>*/;
-CHECK_NEW_array__Array(var189);
+var45 = NEW_array__Array(&type_array__Arraykernel__Object);
+{ /* var45 = array_instance Array[Object] */
+var46 = 5;
+var47 = NEW_array__NativeArray(var46, &type_array__NativeArraykernel__Object);
+((struct instance_array__NativeArray*)var47)->values[0] = (val*) var31;
+((struct instance_array__NativeArray*)var47)->values[1] = (val*) var_t;
+((struct instance_array__NativeArray*)var47)->values[2] = (val*) var36;
+((struct instance_array__NativeArray*)var47)->values[3] = (val*) var_t;
+((struct instance_array__NativeArray*)var47)->values[4] = (val*) var41;
+((void (*)(val*, val*, long))(var45->class->vft[COLOR_array__Array__with_native]))(var45, var47, var46) /* with_native on <var45:Array[Object]>*/;
 }
-var192 = ((val* (*)(val*))(var189->class->vft[COLOR_string__Object__to_s]))(var189) /* to_s on <var189:Array[Object]>*/;
-((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var192) /* add on <self:SeparateCompilerVisitor>*/;
+var48 = ((val* (*)(val*))(var45->class->vft[COLOR_string__Object__to_s]))(var45) /* to_s on <var45:Array[Object]>*/;
+((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var48) /* add on <self:SeparateCompilerVisitor>*/;
+if (varonce49) {
+var50 = varonce49;
+} else {
+var51 = "fprintf(stderr, \"Try to cast on a dead cast type: %s\\n\", ";
+var52 = 57;
+var53 = string__NativeString__to_s_with_length(var51, var52);
+var50 = var53;
+varonce49 = var50;
+}
+if (varonce54) {
+var55 = varonce54;
+} else {
+var56 = "->name);";
+var57 = 8;
+var58 = string__NativeString__to_s_with_length(var56, var57);
+var55 = var58;
+varonce54 = var55;
+}
+var59 = NEW_array__Array(&type_array__Arraykernel__Object);
+{ /* var59 = array_instance Array[Object] */
+var60 = 3;
+var61 = NEW_array__NativeArray(var60, &type_array__NativeArraykernel__Object);
+((struct instance_array__NativeArray*)var61)->values[0] = (val*) var50;
+((struct instance_array__NativeArray*)var61)->values[1] = (val*) var_t;
+((struct instance_array__NativeArray*)var61)->values[2] = (val*) var55;
+((void (*)(val*, val*, long))(var59->class->vft[COLOR_array__Array__with_native]))(var59, var61, var60) /* with_native on <var59:Array[Object]>*/;
+}
+var62 = ((val* (*)(val*))(var59->class->vft[COLOR_string__Object__to_s]))(var59) /* to_s on <var59:Array[Object]>*/;
+((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var62) /* add on <self:SeparateCompilerVisitor>*/;
+if (varonce63) {
+var64 = varonce63;
+} else {
+var65 = "cast type dead";
+var66 = 14;
+var67 = string__NativeString__to_s_with_length(var65, var66);
+var64 = var67;
+varonce63 = var64;
+}
+((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add_abort]))(self, var64) /* add_abort on <self:SeparateCompilerVisitor>*/;
+if (varonce68) {
+var69 = varonce68;
+} else {
+var70 = "}";
+var71 = 1;
+var72 = string__NativeString__to_s_with_length(var70, var71);
+var69 = var72;
+varonce68 = var69;
 }
+((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var69) /* add on <self:SeparateCompilerVisitor>*/;
 RET_LABEL:;
 }
-/* method separate_compiler#SeparateCompilerVisitor#write_attribute for (self: Object, MAttribute, RuntimeVariable, RuntimeVariable) */
-void VIRTUAL_separate_compiler__SeparateCompilerVisitor__write_attribute(val* self, val* p0, val* p1, val* p2) {
-separate_compiler__SeparateCompilerVisitor__write_attribute(self, p0, p1, p2);
+/* method separate_compiler#SeparateCompilerVisitor#hardening_cast_type for (self: Object, String) */
+void VIRTUAL_separate_compiler__SeparateCompilerVisitor__hardening_cast_type(val* self, val* p0) {
+separate_compiler__SeparateCompilerVisitor__hardening_cast_type(self, p0);
 RET_LABEL:;
 }
 /* method separate_compiler#SeparateCompilerVisitor#init_instance for (self: SeparateCompilerVisitor, MClassType): RuntimeVariable */
@@ -4518,7 +4513,6 @@ var9 = NEW_array__NativeArray(var8, &type_array__NativeArraykernel__Object);
 ((struct instance_array__NativeArray*)var9)->values[0] = (val*) var1;
 ((struct instance_array__NativeArray*)var9)->values[1] = (val*) var6;
 ((void (*)(val*, val*, long))(var7->class->vft[COLOR_array__Array__with_native]))(var7, var9, var8) /* with_native on <var7:Array[Object]>*/;
-CHECK_NEW_array__Array(var7);
 }
 var10 = ((val* (*)(val*))(var7->class->vft[COLOR_string__Object__to_s]))(var7) /* to_s on <var7:Array[Object]>*/;
 ((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__require_declaration]))(self, var10) /* require_declaration on <self:SeparateCompilerVisitor>*/;
@@ -4540,11 +4534,12 @@ var12 = var14;
 var12 = var_;
 }
 if (var12){
+((void (*)(val*, val*))(self->class->vft[COLOR_separate_compiler__SeparateCompilerVisitor__hardening_live_open_type]))(self, var_mtype) /* hardening_live_open_type on <self:SeparateCompilerVisitor>*/;
 var15 = ((val* (*)(val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__frame]))(self) /* frame on <self:SeparateCompilerVisitor>*/;
 if (var15 == NULL) {
-fprintf(stderr, "Runtime error: %s", "Reciever is null");
-fprintf(stderr, " (%s:%d)\n", "src/separate_compiler.nit", 1264);
-exit(1);
+fprintf(stderr, "Runtime error: %s", "Receiver is null");
+fprintf(stderr, " (%s:%d)\n", "src/separate_compiler.nit", 1322);
+show_backtrace(1);
 } else {
 var16 = ((val* (*)(val*))(var15->class->vft[COLOR_abstract_compiler__Frame__mpropdef]))(var15) /* mpropdef on <var15:nullable Frame>*/;
 }
@@ -4552,9 +4547,9 @@ var17 = ((val* (*)(val*))(var16->class->vft[COLOR_model__MPropDef__mclassdef]))(
 ((void (*)(val*, val*, val*))(self->class->vft[COLOR_separate_compiler__SeparateCompilerVisitor__link_unresolved_type]))(self, var17, var_mtype) /* link_unresolved_type on <self:SeparateCompilerVisitor>*/;
 var18 = ((val* (*)(val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__frame]))(self) /* frame on <self:SeparateCompilerVisitor>*/;
 if (var18 == NULL) {
-fprintf(stderr, "Runtime error: %s", "Reciever is null");
-fprintf(stderr, " (%s:%d)\n", "src/separate_compiler.nit", 1265);
-exit(1);
+fprintf(stderr, "Runtime error: %s", "Receiver is null");
+fprintf(stderr, " (%s:%d)\n", "src/separate_compiler.nit", 1323);
+show_backtrace(1);
 } else {
 var19 = ((val* (*)(val*))(var18->class->vft[COLOR_abstract_compiler__Frame__arguments]))(var18) /* arguments on <var18:nullable Frame>*/;
 }
@@ -4643,7 +4638,6 @@ var65 = NEW_array__NativeArray(var64, &type_array__NativeArraykernel__Object);
 ((struct instance_array__NativeArray*)var65)->values[7] = (val*) var57;
 ((struct instance_array__NativeArray*)var65)->values[8] = (val*) var59;
 ((void (*)(val*, val*, long))(var63->class->vft[COLOR_array__Array__with_native]))(var63, var65, var64) /* with_native on <var63:Array[Object]>*/;
-CHECK_NEW_array__Array(var63);
 }
 var66 = ((val* (*)(val*))(var63->class->vft[COLOR_string__Object__to_s]))(var63) /* to_s on <var63:Array[Object]>*/;
 var67 = ((val* (*)(val*, val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__new_expr]))(self, var66, var_mtype) /* new_expr on <self:SeparateCompilerVisitor>*/;
@@ -4701,7 +4695,6 @@ var93 = NEW_array__NativeArray(var92, &type_array__NativeArraykernel__Object);
 ((struct instance_array__NativeArray*)var93)->values[5] = (val*) var85;
 ((struct instance_array__NativeArray*)var93)->values[6] = (val*) var87;
 ((void (*)(val*, val*, long))(var91->class->vft[COLOR_array__Array__with_native]))(var91, var93, var92) /* with_native on <var91:Array[Object]>*/;
-CHECK_NEW_array__Array(var91);
 }
 var94 = ((val* (*)(val*))(var91->class->vft[COLOR_string__Object__to_s]))(var91) /* to_s on <var91:Array[Object]>*/;
 var95 = ((val* (*)(val*, val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__new_expr]))(self, var94, var_mtype) /* new_expr on <self:SeparateCompilerVisitor>*/;
@@ -4727,195 +4720,67 @@ var103 = NEW_array__Array(&type_array__Arraykernel__Object);
 var104 = 2;
 var105 = NEW_array__NativeArray(var104, &type_array__NativeArraykernel__Object);
 ((struct instance_array__NativeArray*)var105)->values[0] = (val*) var98;
-((struct instance_array__NativeArray*)var105)->values[1] = (val*) var102;
-((void (*)(val*, val*, long))(var103->class->vft[COLOR_array__Array__with_native]))(var103, var105, var104) /* with_native on <var103:Array[Object]>*/;
-CHECK_NEW_array__Array(var103);
-}
-var106 = ((val* (*)(val*))(var103->class->vft[COLOR_string__Object__to_s]))(var103) /* to_s on <var103:Array[Object]>*/;
-((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__require_declaration]))(self, var106) /* require_declaration on <self:SeparateCompilerVisitor>*/;
-if (varonce107) {
-var108 = varonce107;
-} else {
-var109 = "NEW_";
-var110 = 4;
-var111 = string__NativeString__to_s_with_length(var109, var110);
-var108 = var111;
-varonce107 = var108;
-}
-var112 = ((val* (*)(val*))(var_mtype->class->vft[COLOR_model__MClassType__mclass]))(var_mtype) /* mclass on <var_mtype:MClassType>*/;
-var113 = ((val* (*)(val*))(var112->class->vft[COLOR_abstract_compiler__MClass__c_name]))(var112) /* c_name on <var112:MClass>*/;
-if (varonce114) {
-var115 = varonce114;
-} else {
-var116 = "(&type_";
-var117 = 7;
-var118 = string__NativeString__to_s_with_length(var116, var117);
-var115 = var118;
-varonce114 = var115;
-}
-var119 = ((val* (*)(val*))(var_mtype->class->vft[COLOR_abstract_compiler__MType__c_name]))(var_mtype) /* c_name on <var_mtype:MClassType>*/;
-if (varonce120) {
-var121 = varonce120;
-} else {
-var122 = ")";
-var123 = 1;
-var124 = string__NativeString__to_s_with_length(var122, var123);
-var121 = var124;
-varonce120 = var121;
-}
-var125 = NEW_array__Array(&type_array__Arraykernel__Object);
-{ /* var125 = array_instance Array[Object] */
-var126 = 5;
-var127 = NEW_array__NativeArray(var126, &type_array__NativeArraykernel__Object);
-((struct instance_array__NativeArray*)var127)->values[0] = (val*) var108;
-((struct instance_array__NativeArray*)var127)->values[1] = (val*) var113;
-((struct instance_array__NativeArray*)var127)->values[2] = (val*) var115;
-((struct instance_array__NativeArray*)var127)->values[3] = (val*) var119;
-((struct instance_array__NativeArray*)var127)->values[4] = (val*) var121;
-((void (*)(val*, val*, long))(var125->class->vft[COLOR_array__Array__with_native]))(var125, var127, var126) /* with_native on <var125:Array[Object]>*/;
-CHECK_NEW_array__Array(var125);
-}
-var128 = ((val* (*)(val*))(var125->class->vft[COLOR_string__Object__to_s]))(var125) /* to_s on <var125:Array[Object]>*/;
-var129 = ((val* (*)(val*, val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__new_expr]))(self, var128, var_mtype) /* new_expr on <self:SeparateCompilerVisitor>*/;
-var = var129;
-goto RET_LABEL;
-RET_LABEL:;
-return var;
-}
-/* method separate_compiler#SeparateCompilerVisitor#init_instance for (self: Object, MClassType): RuntimeVariable */
-val* VIRTUAL_separate_compiler__SeparateCompilerVisitor__init_instance(val* self, val* p0) {
-val* var /* : RuntimeVariable */;
-val* var1 /* : RuntimeVariable */;
-var1 = separate_compiler__SeparateCompilerVisitor__init_instance(self, p0);
-var = var1;
-RET_LABEL:;
-return var;
-}
-/* method separate_compiler#SeparateCompilerVisitor#check_init_instance for (self: SeparateCompilerVisitor, RuntimeVariable, MClassType) */
-void separate_compiler__SeparateCompilerVisitor__check_init_instance(val* self, val* p0, val* p1) {
-val* var_value /* var value: RuntimeVariable */;
-val* var_mtype /* var mtype: MClassType */;
-val* var /* : AbstractCompiler */;
-val* var1 /* : ModelBuilder */;
-val* var2 /* : ToolContext */;
-val* var3 /* : OptionBool */;
-val* var4 /* : nullable Object */;
-short int var5 /* : Bool */;
-static val* varonce;
-val* var6 /* : String */;
-char* var7 /* : NativeString */;
-long var8 /* : Int */;
-val* var9 /* : String */;
-val* var10 /* : MClass */;
-val* var11 /* : String */;
-val* var12 /* : Array[Object] */;
-long var13 /* : Int */;
-val* var14 /* : NativeArray[Object] */;
-val* var15 /* : String */;
-static val* varonce16;
-val* var17 /* : String */;
-char* var18 /* : NativeString */;
-long var19 /* : Int */;
-val* var20 /* : String */;
-val* var21 /* : MClass */;
-val* var22 /* : String */;
-static val* varonce23;
-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* var33 /* : Array[Object] */;
-long var34 /* : Int */;
-val* var35 /* : NativeArray[Object] */;
-val* var36 /* : String */;
-var_value = p0;
-var_mtype = p1;
-var = ((val* (*)(val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__compiler]))(self) /* compiler on <self:SeparateCompilerVisitor>*/;
-var1 = ((val* (*)(val*))(var->class->vft[COLOR_abstract_compiler__AbstractCompiler__modelbuilder]))(var) /* modelbuilder on <var:AbstractCompiler(SeparateCompiler)>*/;
-var2 = ((val* (*)(val*))(var1->class->vft[COLOR_modelbuilder__ModelBuilder__toolcontext]))(var1) /* toolcontext on <var1:ModelBuilder>*/;
-var3 = ((val* (*)(val*))(var2->class->vft[COLOR_abstract_compiler__ToolContext__opt_no_check_initialization]))(var2) /* opt_no_check_initialization on <var2:ToolContext>*/;
-var4 = ((val* (*)(val*))(var3->class->vft[COLOR_opts__Option__value]))(var3) /* value on <var3:OptionBool>*/;
-var5 = ((struct instance_kernel__Bool*)var4)->value; /* autounbox from nullable Object to Bool */;
-if (var5){
-goto RET_LABEL;
-} else {
-}
-if (varonce) {
-var6 = varonce;
-} else {
-var7 = "CHECK_NEW_";
-var8 = 10;
-var9 = string__NativeString__to_s_with_length(var7, var8);
-var6 = var9;
-varonce = var6;
+((struct instance_array__NativeArray*)var105)->values[1] = (val*) var102;
+((void (*)(val*, val*, long))(var103->class->vft[COLOR_array__Array__with_native]))(var103, var105, var104) /* with_native on <var103:Array[Object]>*/;
 }
-var10 = ((val* (*)(val*))(var_mtype->class->vft[COLOR_model__MClassType__mclass]))(var_mtype) /* mclass on <var_mtype:MClassType>*/;
-var11 = ((val* (*)(val*))(var10->class->vft[COLOR_abstract_compiler__MClass__c_name]))(var10) /* c_name on <var10:MClass>*/;
-var12 = NEW_array__Array(&type_array__Arraykernel__Object);
-{ /* var12 = array_instance Array[Object] */
-var13 = 2;
-var14 = NEW_array__NativeArray(var13, &type_array__NativeArraykernel__Object);
-((struct instance_array__NativeArray*)var14)->values[0] = (val*) var6;
-((struct instance_array__NativeArray*)var14)->values[1] = (val*) var11;
-((void (*)(val*, val*, long))(var12->class->vft[COLOR_array__Array__with_native]))(var12, var14, var13) /* with_native on <var12:Array[Object]>*/;
-CHECK_NEW_array__Array(var12);
-}
-var15 = ((val* (*)(val*))(var12->class->vft[COLOR_string__Object__to_s]))(var12) /* to_s on <var12:Array[Object]>*/;
-((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__require_declaration]))(self, var15) /* require_declaration on <self:SeparateCompilerVisitor>*/;
-if (varonce16) {
-var17 = varonce16;
+var106 = ((val* (*)(val*))(var103->class->vft[COLOR_string__Object__to_s]))(var103) /* to_s on <var103:Array[Object]>*/;
+((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__require_declaration]))(self, var106) /* require_declaration on <self:SeparateCompilerVisitor>*/;
+if (varonce107) {
+var108 = varonce107;
 } else {
-var18 = "CHECK_NEW_";
-var19 = 10;
-var20 = string__NativeString__to_s_with_length(var18, var19);
-var17 = var20;
-varonce16 = var17;
+var109 = "NEW_";
+var110 = 4;
+var111 = string__NativeString__to_s_with_length(var109, var110);
+var108 = var111;
+varonce107 = var108;
 }
-var21 = ((val* (*)(val*))(var_mtype->class->vft[COLOR_model__MClassType__mclass]))(var_mtype) /* mclass on <var_mtype:MClassType>*/;
-var22 = ((val* (*)(val*))(var21->class->vft[COLOR_abstract_compiler__MClass__c_name]))(var21) /* c_name on <var21:MClass>*/;
-if (varonce23) {
-var24 = varonce23;
+var112 = ((val* (*)(val*))(var_mtype->class->vft[COLOR_model__MClassType__mclass]))(var_mtype) /* mclass on <var_mtype:MClassType>*/;
+var113 = ((val* (*)(val*))(var112->class->vft[COLOR_abstract_compiler__MClass__c_name]))(var112) /* c_name on <var112:MClass>*/;
+if (varonce114) {
+var115 = varonce114;
 } else {
-var25 = "(";
-var26 = 1;
-var27 = string__NativeString__to_s_with_length(var25, var26);
-var24 = var27;
-varonce23 = var24;
+var116 = "(&type_";
+var117 = 7;
+var118 = string__NativeString__to_s_with_length(var116, var117);
+var115 = var118;
+varonce114 = var115;
 }
-if (varonce28) {
-var29 = varonce28;
+var119 = ((val* (*)(val*))(var_mtype->class->vft[COLOR_abstract_compiler__MType__c_name]))(var_mtype) /* c_name on <var_mtype:MClassType>*/;
+if (varonce120) {
+var121 = varonce120;
 } else {
-var30 = ");";
-var31 = 2;
-var32 = string__NativeString__to_s_with_length(var30, var31);
-var29 = var32;
-varonce28 = var29;
+var122 = ")";
+var123 = 1;
+var124 = string__NativeString__to_s_with_length(var122, var123);
+var121 = var124;
+varonce120 = var121;
+}
+var125 = NEW_array__Array(&type_array__Arraykernel__Object);
+{ /* var125 = array_instance Array[Object] */
+var126 = 5;
+var127 = NEW_array__NativeArray(var126, &type_array__NativeArraykernel__Object);
+((struct instance_array__NativeArray*)var127)->values[0] = (val*) var108;
+((struct instance_array__NativeArray*)var127)->values[1] = (val*) var113;
+((struct instance_array__NativeArray*)var127)->values[2] = (val*) var115;
+((struct instance_array__NativeArray*)var127)->values[3] = (val*) var119;
+((struct instance_array__NativeArray*)var127)->values[4] = (val*) var121;
+((void (*)(val*, val*, long))(var125->class->vft[COLOR_array__Array__with_native]))(var125, var127, var126) /* with_native on <var125:Array[Object]>*/;
 }
-var33 = NEW_array__Array(&type_array__Arraykernel__Object);
-{ /* var33 = array_instance Array[Object] */
-var34 = 5;
-var35 = NEW_array__NativeArray(var34, &type_array__NativeArraykernel__Object);
-((struct instance_array__NativeArray*)var35)->values[0] = (val*) var17;
-((struct instance_array__NativeArray*)var35)->values[1] = (val*) var22;
-((struct instance_array__NativeArray*)var35)->values[2] = (val*) var24;
-((struct instance_array__NativeArray*)var35)->values[3] = (val*) var_value;
-((struct instance_array__NativeArray*)var35)->values[4] = (val*) var29;
-((void (*)(val*, val*, long))(var33->class->vft[COLOR_array__Array__with_native]))(var33, var35, var34) /* with_native on <var33:Array[Object]>*/;
-CHECK_NEW_array__Array(var33);
-}
-var36 = ((val* (*)(val*))(var33->class->vft[COLOR_string__Object__to_s]))(var33) /* to_s on <var33:Array[Object]>*/;
-((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var36) /* add on <self:SeparateCompilerVisitor>*/;
+var128 = ((val* (*)(val*))(var125->class->vft[COLOR_string__Object__to_s]))(var125) /* to_s on <var125:Array[Object]>*/;
+var129 = ((val* (*)(val*, val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__new_expr]))(self, var128, var_mtype) /* new_expr on <self:SeparateCompilerVisitor>*/;
+var = var129;
+goto RET_LABEL;
 RET_LABEL:;
+return var;
 }
-/* method separate_compiler#SeparateCompilerVisitor#check_init_instance for (self: Object, RuntimeVariable, MClassType) */
-void VIRTUAL_separate_compiler__SeparateCompilerVisitor__check_init_instance(val* self, val* p0, val* p1) {
-separate_compiler__SeparateCompilerVisitor__check_init_instance(self, p0, p1);
+/* method separate_compiler#SeparateCompilerVisitor#init_instance for (self: Object, MClassType): RuntimeVariable */
+val* VIRTUAL_separate_compiler__SeparateCompilerVisitor__init_instance(val* self, val* p0) {
+val* var /* : RuntimeVariable */;
+val* var1 /* : RuntimeVariable */;
+var1 = separate_compiler__SeparateCompilerVisitor__init_instance(self, p0);
+var = var1;
 RET_LABEL:;
+return var;
 }
 /* method separate_compiler#SeparateCompilerVisitor#type_test for (self: SeparateCompilerVisitor, RuntimeVariable, MType, String): RuntimeVariable */
 val* separate_compiler__SeparateCompilerVisitor__type_test(val* self, val* p0, val* p1, val* p2) {
@@ -5301,163 +5166,163 @@ val* var362 /* : Array[Object] */;
 long var363 /* : Int */;
 val* var364 /* : NativeArray[Object] */;
 val* var365 /* : String */;
-val* var366 /* : ModelBuilder */;
-val* var367 /* : ToolContext */;
-val* var368 /* : OptionBool */;
-val* var369 /* : nullable Object */;
-short int var370 /* : Bool */;
-val* var371 /* : AbstractCompiler */;
-val* var372 /* : HashMap[String, Int] */;
-val* var_373 /* var : HashMap[String, Int] */;
-val* var_374 /* var : String */;
-val* var375 /* : nullable Object */;
-long var376 /* : Int */;
-long var377 /* : Int */;
-long var379 /* : Int */;
-long var380 /* : Int */;
-val* var381 /* : nullable Object */;
-static val* varonce382;
-val* var383 /* : String */;
-char* var384 /* : NativeString */;
-long var385 /* : Int */;
-val* var386 /* : String */;
-static val* varonce387;
-val* var388 /* : String */;
-char* var389 /* : NativeString */;
-long var390 /* : Int */;
-val* var391 /* : String */;
-val* var392 /* : Array[Object] */;
-long var393 /* : Int */;
-val* var394 /* : NativeArray[Object] */;
-val* var395 /* : String */;
-static val* varonce396;
-val* var397 /* : String */;
-char* var398 /* : NativeString */;
-long var399 /* : Int */;
-val* var400 /* : String */;
-static val* varonce401;
-val* var402 /* : String */;
-char* var403 /* : NativeString */;
-long var404 /* : Int */;
-val* var405 /* : String */;
+static val* varonce366;
+val* var367 /* : String */;
+char* var368 /* : NativeString */;
+long var369 /* : Int */;
+val* var370 /* : String */;
+val* var371 /* : String */;
+static val* varonce372;
+val* var373 /* : String */;
+char* var374 /* : NativeString */;
+long var375 /* : Int */;
+val* var376 /* : String */;
+val* var377 /* : Array[Object] */;
+long var378 /* : Int */;
+val* var379 /* : NativeArray[Object] */;
+val* var380 /* : String */;
+val* var381 /* : ModelBuilder */;
+val* var382 /* : ToolContext */;
+val* var383 /* : OptionBool */;
+val* var384 /* : nullable Object */;
+short int var385 /* : Bool */;
+val* var386 /* : AbstractCompiler */;
+val* var387 /* : HashMap[String, Int] */;
+val* var_388 /* var : HashMap[String, Int] */;
+val* var_389 /* var : String */;
+val* var390 /* : nullable Object */;
+long var391 /* : Int */;
+long var392 /* : Int */;
+long var394 /* : Int */;
+long var395 /* : Int */;
+val* var396 /* : nullable Object */;
+static val* varonce397;
+val* var398 /* : String */;
+char* var399 /* : NativeString */;
+long var400 /* : Int */;
+val* var401 /* : String */;
+static val* varonce402;
+val* var403 /* : String */;
+char* var404 /* : NativeString */;
+long var405 /* : Int */;
 val* var406 /* : String */;
-static val* varonce407;
-val* var408 /* : String */;
-char* var409 /* : NativeString */;
-long var410 /* : Int */;
-val* var411 /* : String */;
-val* var412 /* : Array[Object] */;
-long var413 /* : Int */;
-val* var414 /* : NativeArray[Object] */;
+val* var407 /* : Array[Object] */;
+long var408 /* : Int */;
+val* var409 /* : NativeArray[Object] */;
+val* var410 /* : String */;
+static val* varonce411;
+val* var412 /* : String */;
+char* var413 /* : NativeString */;
+long var414 /* : Int */;
 val* var415 /* : String */;
 static val* varonce416;
 val* var417 /* : String */;
 char* var418 /* : NativeString */;
 long var419 /* : Int */;
 val* var420 /* : String */;
-static val* varonce421;
-val* var422 /* : String */;
-char* var423 /* : NativeString */;
-long var424 /* : Int */;
-val* var425 /* : String */;
-val* var426 /* : Array[Object] */;
-long var427 /* : Int */;
-val* var428 /* : NativeArray[Object] */;
-val* var429 /* : String */;
-static val* varonce430;
-val* var431 /* : String */;
-char* var432 /* : NativeString */;
-long var433 /* : Int */;
-val* var434 /* : String */;
-static val* varonce435;
-val* var436 /* : String */;
-char* var437 /* : NativeString */;
-long var438 /* : Int */;
-val* var439 /* : String */;
-val* var440 /* : Array[Object] */;
-long var441 /* : Int */;
-val* var442 /* : NativeArray[Object] */;
-val* var443 /* : String */;
-static val* varonce444;
-val* var445 /* : String */;
-char* var446 /* : NativeString */;
-long var447 /* : Int */;
-val* var448 /* : String */;
+val* var421 /* : String */;
+static val* varonce422;
+val* var423 /* : String */;
+char* var424 /* : NativeString */;
+long var425 /* : Int */;
+val* var426 /* : String */;
+val* var427 /* : Array[Object] */;
+long var428 /* : Int */;
+val* var429 /* : NativeArray[Object] */;
+val* var430 /* : String */;
+static val* varonce431;
+val* var432 /* : String */;
+char* var433 /* : NativeString */;
+long var434 /* : Int */;
+val* var435 /* : String */;
+static val* varonce436;
+val* var437 /* : String */;
+char* var438 /* : NativeString */;
+long var439 /* : Int */;
+val* var440 /* : String */;
+val* var441 /* : Array[Object] */;
+long var442 /* : Int */;
+val* var443 /* : NativeArray[Object] */;
+val* var444 /* : String */;
+static val* varonce445;
+val* var446 /* : String */;
+char* var447 /* : NativeString */;
+long var448 /* : Int */;
 val* var449 /* : String */;
-val* var_value_type_info /* var value_type_info: String */;
-short int var450 /* : Bool */;
-val* var451 /* : ModelBuilder */;
-val* var452 /* : ToolContext */;
-val* var453 /* : OptionBool */;
-val* var454 /* : nullable Object */;
-short int var455 /* : Bool */;
-short int var_456 /* var : Bool */;
-val* var457 /* : ModelBuilder */;
-val* var458 /* : ToolContext */;
-val* var459 /* : OptionBool */;
-val* var460 /* : nullable Object */;
-short int var461 /* : Bool */;
-static val* varonce462;
+static val* varonce450;
+val* var451 /* : String */;
+char* var452 /* : NativeString */;
+long var453 /* : Int */;
+val* var454 /* : String */;
+val* var455 /* : Array[Object] */;
+long var456 /* : Int */;
+val* var457 /* : NativeArray[Object] */;
+val* var458 /* : String */;
+static val* varonce459;
+val* var460 /* : String */;
+char* var461 /* : NativeString */;
+long var462 /* : Int */;
 val* var463 /* : String */;
-char* var464 /* : NativeString */;
-long var465 /* : Int */;
-val* var466 /* : String */;
-static val* varonce467;
-val* var468 /* : String */;
-char* var469 /* : NativeString */;
-long var470 /* : Int */;
-val* var471 /* : String */;
-static val* varonce472;
-val* var473 /* : String */;
-char* var474 /* : NativeString */;
-long var475 /* : Int */;
-val* var476 /* : String */;
-val* var477 /* : Array[Object] */;
-long var478 /* : Int */;
-val* var479 /* : NativeArray[Object] */;
-val* var480 /* : String */;
-static val* varonce481;
-val* var482 /* : String */;
-char* var483 /* : NativeString */;
-long var484 /* : Int */;
-val* var485 /* : String */;
-static val* varonce486;
-val* var487 /* : String */;
-char* var488 /* : NativeString */;
-long var489 /* : Int */;
-val* var490 /* : String */;
-static val* varonce491;
-val* var492 /* : String */;
-char* var493 /* : NativeString */;
-long var494 /* : Int */;
+val* var464 /* : String */;
+val* var_value_type_info /* var value_type_info: String */;
+short int var465 /* : Bool */;
+val* var466 /* : ModelBuilder */;
+val* var467 /* : ToolContext */;
+val* var468 /* : OptionBool */;
+val* var469 /* : nullable Object */;
+short int var470 /* : Bool */;
+short int var_471 /* var : Bool */;
+val* var472 /* : ModelBuilder */;
+val* var473 /* : ToolContext */;
+val* var474 /* : OptionBool */;
+val* var475 /* : nullable Object */;
+short int var476 /* : Bool */;
+static val* varonce477;
+val* var478 /* : String */;
+char* var479 /* : NativeString */;
+long var480 /* : Int */;
+val* var481 /* : String */;
+static val* varonce482;
+val* var483 /* : String */;
+char* var484 /* : NativeString */;
+long var485 /* : Int */;
+val* var486 /* : String */;
+static val* varonce487;
+val* var488 /* : String */;
+char* var489 /* : NativeString */;
+long var490 /* : Int */;
+val* var491 /* : String */;
+val* var492 /* : Array[Object] */;
+long var493 /* : Int */;
+val* var494 /* : NativeArray[Object] */;
 val* var495 /* : String */;
-val* var496 /* : Array[Object] */;
-long var497 /* : Int */;
-val* var498 /* : NativeArray[Object] */;
-val* var499 /* : String */;
-static val* varonce500;
-val* var501 /* : String */;
-char* var502 /* : NativeString */;
-long var503 /* : Int */;
-val* var504 /* : String */;
-val* var505 /* : Array[Object] */;
-long var506 /* : Int */;
-val* var507 /* : NativeArray[Object] */;
-val* var508 /* : String */;
-static val* varonce509;
+static val* varonce496;
+val* var497 /* : String */;
+char* var498 /* : NativeString */;
+long var499 /* : Int */;
+val* var500 /* : String */;
+static val* varonce501;
+val* var502 /* : String */;
+char* var503 /* : NativeString */;
+long var504 /* : Int */;
+val* var505 /* : String */;
+static val* varonce506;
+val* var507 /* : String */;
+char* var508 /* : NativeString */;
+long var509 /* : Int */;
 val* var510 /* : String */;
-char* var511 /* : NativeString */;
+val* var511 /* : Array[Object] */;
 long var512 /* : Int */;
-val* var513 /* : String */;
-static val* varonce514;
-val* var515 /* : String */;
-char* var516 /* : NativeString */;
-long var517 /* : Int */;
-val* var518 /* : String */;
-static val* varonce519;
-val* var520 /* : String */;
-char* var521 /* : NativeString */;
-long var522 /* : Int */;
+val* var513 /* : NativeArray[Object] */;
+val* var514 /* : String */;
+static val* varonce515;
+val* var516 /* : String */;
+char* var517 /* : NativeString */;
+long var518 /* : Int */;
+val* var519 /* : String */;
+val* var520 /* : Array[Object] */;
+long var521 /* : Int */;
+val* var522 /* : NativeArray[Object] */;
 val* var523 /* : String */;
 static val* varonce524;
 val* var525 /* : String */;
@@ -5469,20 +5334,35 @@ val* var530 /* : String */;
 char* var531 /* : NativeString */;
 long var532 /* : Int */;
 val* var533 /* : String */;
-val* var534 /* : Array[Object] */;
-long var535 /* : Int */;
-val* var536 /* : NativeArray[Object] */;
-val* var537 /* : String */;
-static val* varonce538;
-val* var539 /* : String */;
-char* var540 /* : NativeString */;
-long var541 /* : Int */;
-val* var542 /* : String */;
-static val* varonce543;
-val* var544 /* : String */;
-char* var545 /* : NativeString */;
-long var546 /* : Int */;
-val* var547 /* : String */;
+static val* varonce534;
+val* var535 /* : String */;
+char* var536 /* : NativeString */;
+long var537 /* : Int */;
+val* var538 /* : String */;
+static val* varonce539;
+val* var540 /* : String */;
+char* var541 /* : NativeString */;
+long var542 /* : Int */;
+val* var543 /* : String */;
+static val* varonce544;
+val* var545 /* : String */;
+char* var546 /* : NativeString */;
+long var547 /* : Int */;
+val* var548 /* : String */;
+val* var549 /* : Array[Object] */;
+long var550 /* : Int */;
+val* var551 /* : NativeArray[Object] */;
+val* var552 /* : String */;
+static val* varonce553;
+val* var554 /* : String */;
+char* var555 /* : NativeString */;
+long var556 /* : Int */;
+val* var557 /* : String */;
+static val* varonce558;
+val* var559 /* : String */;
+char* var560 /* : NativeString */;
+long var561 /* : Int */;
+val* var562 /* : String */;
 var_value = p0;
 var_mtype = p1;
 var_tag = p2;
@@ -5524,7 +5404,6 @@ var18 = NEW_array__NativeArray(var17, &type_array__NativeArraykernel__Object);
 ((struct instance_array__NativeArray*)var18)->values[3] = (val*) var_mtype;
 ((struct instance_array__NativeArray*)var18)->values[4] = (val*) var12;
 ((void (*)(val*, val*, long))(var16->class->vft[COLOR_array__Array__with_native]))(var16, var18, var17) /* with_native on <var16:Array[Object]>*/;
-CHECK_NEW_array__Array(var16);
 }
 var19 = ((val* (*)(val*))(var16->class->vft[COLOR_string__Object__to_s]))(var16) /* to_s on <var16:Array[Object]>*/;
 ((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var19) /* add on <self:SeparateCompilerVisitor>*/;
@@ -5532,9 +5411,9 @@ var20 = ((val* (*)(val*))(self->class->vft[COLOR_abstract_compiler__AbstractComp
 var_compiler = var20;
 var21 = ((val* (*)(val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__frame]))(self) /* frame on <self:SeparateCompilerVisitor>*/;
 if (var21 == NULL) {
-fprintf(stderr, "Runtime error: %s", "Reciever is null");
-fprintf(stderr, " (%s:%d)\n", "src/separate_compiler.nit", 1291);
-exit(1);
+fprintf(stderr, "Runtime error: %s", "Receiver is null");
+fprintf(stderr, " (%s:%d)\n", "src/separate_compiler.nit", 1342);
+show_backtrace(1);
 } else {
 var22 = ((val* (*)(val*))(var21->class->vft[COLOR_abstract_compiler__Frame__arguments]))(var21) /* arguments on <var21:nullable Frame>*/;
 }
@@ -5582,7 +5461,6 @@ var45 = NEW_array__NativeArray(var44, &type_array__NativeArraykernel__Object);
 ((struct instance_array__NativeArray*)var45)->values[1] = (val*) var_cltype;
 ((struct instance_array__NativeArray*)var45)->values[2] = (val*) var39;
 ((void (*)(val*, val*, long))(var43->class->vft[COLOR_array__Array__with_native]))(var43, var45, var44) /* with_native on <var43:Array[Object]>*/;
-CHECK_NEW_array__Array(var43);
 }
 var46 = ((val* (*)(val*))(var43->class->vft[COLOR_string__Object__to_s]))(var43) /* to_s on <var43:Array[Object]>*/;
 ((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add_decl]))(self, var46) /* add_decl on <self:SeparateCompilerVisitor>*/;
@@ -5623,7 +5501,6 @@ var65 = NEW_array__NativeArray(var64, &type_array__NativeArraykernel__Object);
 ((struct instance_array__NativeArray*)var65)->values[1] = (val*) var_idtype;
 ((struct instance_array__NativeArray*)var65)->values[2] = (val*) var59;
 ((void (*)(val*, val*, long))(var63->class->vft[COLOR_array__Array__with_native]))(var63, var65, var64) /* with_native on <var63:Array[Object]>*/;
-CHECK_NEW_array__Array(var63);
 }
 var66 = ((val* (*)(val*))(var63->class->vft[COLOR_string__Object__to_s]))(var63) /* to_s on <var63:Array[Object]>*/;
 ((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add_decl]))(self, var66) /* add_decl on <self:SeparateCompilerVisitor>*/;
@@ -5666,9 +5543,9 @@ var_accept_null = var76;
 var80 = ((val* (*)(val*))(var_value->class->vft[COLOR_abstract_compiler__RuntimeVariable__mcasttype]))(var_value) /* mcasttype on <var_value:RuntimeVariable>*/;
 var81 = ((val* (*)(val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__frame]))(self) /* frame on <self:SeparateCompilerVisitor>*/;
 if (var81 == NULL) {
-fprintf(stderr, "Runtime error: %s", "Reciever is null");
-fprintf(stderr, " (%s:%d)\n", "src/separate_compiler.nit", 1309);
-exit(1);
+fprintf(stderr, "Runtime error: %s", "Receiver is null");
+fprintf(stderr, " (%s:%d)\n", "src/separate_compiler.nit", 1360);
+show_backtrace(1);
 } else {
 var82 = ((val* (*)(val*))(var81->class->vft[COLOR_abstract_compiler__Frame__mpropdef]))(var81) /* mpropdef on <var81:nullable Frame>*/;
 }
@@ -5676,9 +5553,9 @@ var83 = ((val* (*)(val*))(var82->class->vft[COLOR_model__MPropDef__mclassdef]))(
 var84 = ((val* (*)(val*))(var83->class->vft[COLOR_model__MClassDef__mmodule]))(var83) /* mmodule on <var83:MClassDef>*/;
 var85 = ((val* (*)(val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__frame]))(self) /* frame on <self:SeparateCompilerVisitor>*/;
 if (var85 == NULL) {
-fprintf(stderr, "Runtime error: %s", "Reciever is null");
-fprintf(stderr, " (%s:%d)\n", "src/separate_compiler.nit", 1309);
-exit(1);
+fprintf(stderr, "Runtime error: %s", "Receiver is null");
+fprintf(stderr, " (%s:%d)\n", "src/separate_compiler.nit", 1360);
+show_backtrace(1);
 } else {
 var86 = ((val* (*)(val*))(var85->class->vft[COLOR_abstract_compiler__Frame__mpropdef]))(var85) /* mpropdef on <var85:nullable Frame>*/;
 }
@@ -5725,7 +5602,6 @@ var108 = NEW_array__NativeArray(var107, &type_array__NativeArraykernel__Object);
 ((struct instance_array__NativeArray*)var108)->values[4] = (val*) var_mtype;
 ((struct instance_array__NativeArray*)var108)->values[5] = (val*) var102;
 ((void (*)(val*, val*, long))(var106->class->vft[COLOR_array__Array__with_native]))(var106, var108, var107) /* with_native on <var106:Array[Object]>*/;
-CHECK_NEW_array__Array(var106);
 }
 var109 = ((val* (*)(val*))(var106->class->vft[COLOR_string__Object__to_s]))(var106) /* to_s on <var106:Array[Object]>*/;
 ((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var109) /* add on <self:SeparateCompilerVisitor>*/;
@@ -5776,7 +5652,6 @@ var137 = NEW_array__NativeArray(var136, &type_array__NativeArraykernel__Object);
 ((struct instance_array__NativeArray*)var137)->values[1] = (val*) var_tag;
 ((struct instance_array__NativeArray*)var137)->values[2] = (val*) var131;
 ((void (*)(val*, val*, long))(var135->class->vft[COLOR_array__Array__with_native]))(var135, var137, var136) /* with_native on <var135:Array[Object]>*/;
-CHECK_NEW_array__Array(var135);
 }
 var138 = ((val* (*)(val*))(var135->class->vft[COLOR_string__Object__to_s]))(var135) /* to_s on <var135:Array[Object]>*/;
 ((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var138) /* add on <self:SeparateCompilerVisitor>*/;
@@ -5825,21 +5700,21 @@ var158 = NEW_array__NativeArray(var157, &type_array__NativeArraykernel__Object);
 ((struct instance_array__NativeArray*)var158)->values[1] = (val*) var_type_struct;
 ((struct instance_array__NativeArray*)var158)->values[2] = (val*) var152;
 ((void (*)(val*, val*, long))(var156->class->vft[COLOR_array__Array__with_native]))(var156, var158, var157) /* with_native on <var156:Array[Object]>*/;
-CHECK_NEW_array__Array(var156);
 }
 var159 = ((val* (*)(val*))(var156->class->vft[COLOR_string__Object__to_s]))(var156) /* to_s on <var156:Array[Object]>*/;
 ((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add_decl]))(self, var159) /* add_decl on <self:SeparateCompilerVisitor>*/;
+((void (*)(val*, val*))(self->class->vft[COLOR_separate_compiler__SeparateCompilerVisitor__hardening_live_open_type]))(self, var_mtype) /* hardening_live_open_type on <self:SeparateCompilerVisitor>*/;
 var160 = ((val* (*)(val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__frame]))(self) /* frame on <self:SeparateCompilerVisitor>*/;
 if (var160 == NULL) {
-fprintf(stderr, "Runtime error: %s", "Reciever is null");
-fprintf(stderr, " (%s:%d)\n", "src/separate_compiler.nit", 1323);
-exit(1);
+fprintf(stderr, "Runtime error: %s", "Receiver is null");
+fprintf(stderr, " (%s:%d)\n", "src/separate_compiler.nit", 1375);
+show_backtrace(1);
 } else {
 var161 = ((val* (*)(val*))(var160->class->vft[COLOR_abstract_compiler__Frame__mpropdef]))(var160) /* mpropdef on <var160:nullable Frame>*/;
 }
 var162 = ((val* (*)(val*))(var161->class->vft[COLOR_model__MPropDef__mclassdef]))(var161) /* mclassdef on <var161:MPropDef>*/;
-((void (*)(val*, val*, val*))(self->class->vft[COLOR_separate_compiler__SeparateCompilerVisitor__link_unresolved_type]))(self, var162, var_ntype) /* link_unresolved_type on <self:SeparateCompilerVisitor>*/;
-var163 = ((val* (*)(val*))(var_ntype->class->vft[COLOR_separate_compiler__MType__const_color]))(var_ntype) /* const_color on <var_ntype:MType>*/;
+((void (*)(val*, val*, val*))(self->class->vft[COLOR_separate_compiler__SeparateCompilerVisitor__link_unresolved_type]))(self, var162, var_mtype) /* link_unresolved_type on <self:SeparateCompilerVisitor>*/;
+var163 = ((val* (*)(val*))(var_mtype->class->vft[COLOR_separate_compiler__MType__const_color]))(var_mtype) /* const_color on <var_mtype:MType>*/;
 ((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__require_declaration]))(self, var163) /* require_declaration on <self:SeparateCompilerVisitor>*/;
 var165 = ((val* (*)(val*))(var_compiler->class->vft[COLOR_abstract_compiler__AbstractCompiler__modelbuilder]))(var_compiler) /* modelbuilder on <var_compiler:SeparateCompiler>*/;
 var166 = ((val* (*)(val*))(var165->class->vft[COLOR_modelbuilder__ModelBuilder__toolcontext]))(var165) /* toolcontext on <var165:ModelBuilder>*/;
@@ -5885,7 +5760,7 @@ var190 = string__NativeString__to_s_with_length(var188, var189);
 var187 = var190;
 varonce186 = var187;
 }
-var191 = ((val* (*)(val*))(var_ntype->class->vft[COLOR_separate_compiler__MType__const_color]))(var_ntype) /* const_color on <var_ntype:MType>*/;
+var191 = ((val* (*)(val*))(var_mtype->class->vft[COLOR_separate_compiler__MType__const_color]))(var_mtype) /* const_color on <var_mtype:MType>*/;
 if (varonce192) {
 var193 = varonce192;
 } else {
@@ -5908,7 +5783,6 @@ var199 = NEW_array__NativeArray(var198, &type_array__NativeArraykernel__Object);
 ((struct instance_array__NativeArray*)var199)->values[6] = (val*) var191;
 ((struct instance_array__NativeArray*)var199)->values[7] = (val*) var193;
 ((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*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var200) /* add on <self:SeparateCompilerVisitor>*/;
@@ -5931,7 +5805,7 @@ var210 = string__NativeString__to_s_with_length(var208, var209);
 var207 = var210;
 varonce206 = var207;
 }
-var211 = ((val* (*)(val*))(var_ntype->class->vft[COLOR_separate_compiler__MType__const_color]))(var_ntype) /* const_color on <var_ntype:MType>*/;
+var211 = ((val* (*)(val*))(var_mtype->class->vft[COLOR_separate_compiler__MType__const_color]))(var_mtype) /* const_color on <var_mtype:MType>*/;
 if (varonce212) {
 var213 = varonce212;
 } else {
@@ -5952,7 +5826,6 @@ var219 = NEW_array__NativeArray(var218, &type_array__NativeArraykernel__Object);
 ((struct instance_array__NativeArray*)var219)->values[4] = (val*) var211;
 ((struct instance_array__NativeArray*)var219)->values[5] = (val*) var213;
 ((void (*)(val*, val*, long))(var217->class->vft[COLOR_array__Array__with_native]))(var217, var219, var218) /* with_native on <var217:Array[Object]>*/;
-CHECK_NEW_array__Array(var217);
 }
 var220 = ((val* (*)(val*))(var217->class->vft[COLOR_string__Object__to_s]))(var217) /* to_s on <var217:Array[Object]>*/;
 ((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var220) /* add on <self:SeparateCompilerVisitor>*/;
@@ -6004,12 +5877,12 @@ var249 = NEW_array__NativeArray(var248, &type_array__NativeArraykernel__Object);
 ((struct instance_array__NativeArray*)var249)->values[1] = (val*) var_tag;
 ((struct instance_array__NativeArray*)var249)->values[2] = (val*) var243;
 ((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*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var250) /* add on <self:SeparateCompilerVisitor>*/;
 } else {
 }
+((void (*)(val*, val*))(self->class->vft[COLOR_separate_compiler__SeparateCompilerVisitor__hardening_cast_type]))(self, var_type_struct) /* hardening_cast_type on <self:SeparateCompilerVisitor>*/;
 if (varonce251) {
 var252 = varonce251;
 } else {
@@ -6037,7 +5910,6 @@ var263 = NEW_array__NativeArray(var262, &type_array__NativeArraykernel__Object);
 ((struct instance_array__NativeArray*)var263)->values[2] = (val*) var_type_struct;
 ((struct instance_array__NativeArray*)var263)->values[3] = (val*) var257;
 ((void (*)(val*, val*, long))(var261->class->vft[COLOR_array__Array__with_native]))(var261, var263, var262) /* with_native on <var261:Array[Object]>*/;
-CHECK_NEW_array__Array(var261);
 }
 var264 = ((val* (*)(val*))(var261->class->vft[COLOR_string__Object__to_s]))(var261) /* to_s on <var261:Array[Object]>*/;
 ((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var264) /* add on <self:SeparateCompilerVisitor>*/;
@@ -6068,7 +5940,6 @@ var277 = NEW_array__NativeArray(var276, &type_array__NativeArraykernel__Object);
 ((struct instance_array__NativeArray*)var277)->values[2] = (val*) var_type_struct;
 ((struct instance_array__NativeArray*)var277)->values[3] = (val*) var271;
 ((void (*)(val*, val*, long))(var275->class->vft[COLOR_array__Array__with_native]))(var275, var277, var276) /* with_native on <var275:Array[Object]>*/;
-CHECK_NEW_array__Array(var275);
 }
 var278 = ((val* (*)(val*))(var275->class->vft[COLOR_string__Object__to_s]))(var275) /* to_s on <var275:Array[Object]>*/;
 ((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var278) /* add on <self:SeparateCompilerVisitor>*/;
@@ -6126,7 +5997,6 @@ var305 = NEW_array__NativeArray(var304, &type_array__NativeArraykernel__Object);
 ((struct instance_array__NativeArray*)var305)->values[1] = (val*) var_is_nullable;
 ((struct instance_array__NativeArray*)var305)->values[2] = (val*) var299;
 ((void (*)(val*, val*, long))(var303->class->vft[COLOR_array__Array__with_native]))(var303, var305, var304) /* with_native on <var303:Array[Object]>*/;
-CHECK_NEW_array__Array(var303);
 }
 var306 = ((val* (*)(val*))(var303->class->vft[COLOR_string__Object__to_s]))(var303) /* to_s on <var303:Array[Object]>*/;
 ((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add_decl]))(self, var306) /* add_decl on <self:SeparateCompilerVisitor>*/;
@@ -6157,7 +6027,6 @@ var319 = NEW_array__NativeArray(var318, &type_array__NativeArraykernel__Object);
 ((struct instance_array__NativeArray*)var319)->values[2] = (val*) var_type_struct;
 ((struct instance_array__NativeArray*)var319)->values[3] = (val*) var313;
 ((void (*)(val*, val*, long))(var317->class->vft[COLOR_array__Array__with_native]))(var317, var319, var318) /* with_native on <var317:Array[Object]>*/;
-CHECK_NEW_array__Array(var317);
 }
 var320 = ((val* (*)(val*))(var317->class->vft[COLOR_string__Object__to_s]))(var317) /* to_s on <var317:Array[Object]>*/;
 ((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var320) /* add on <self:SeparateCompilerVisitor>*/;
@@ -6194,15 +6063,14 @@ var334 = NEW_array__NativeArray(var333, &type_array__NativeArraykernel__Object);
 ((struct instance_array__NativeArray*)var334)->values[0] = (val*) var327;
 ((struct instance_array__NativeArray*)var334)->values[1] = (val*) var331;
 ((void (*)(val*, val*, long))(var332->class->vft[COLOR_array__Array__with_native]))(var332, var334, var333) /* with_native on <var332:Array[Object]>*/;
-CHECK_NEW_array__Array(var332);
 }
 var335 = ((val* (*)(val*))(var332->class->vft[COLOR_string__Object__to_s]))(var332) /* to_s on <var332:Array[Object]>*/;
 ((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__require_declaration]))(self, var335) /* require_declaration on <self:SeparateCompilerVisitor>*/;
 if (varonce336) {
 var337 = varonce336;
 } else {
-var338 = " = type_";
-var339 = 8;
+var338 = "(&type_";
+var339 = 7;
 var340 = string__NativeString__to_s_with_length(var338, var339);
 var337 = var340;
 varonce336 = var337;
@@ -6211,25 +6079,23 @@ var341 = ((val* (*)(val*))(var_mtype->class->vft[COLOR_abstract_compiler__MType_
 if (varonce342) {
 var343 = varonce342;
 } else {
-var344 = ".color;";
-var345 = 7;
+var344 = ")";
+var345 = 1;
 var346 = string__NativeString__to_s_with_length(var344, var345);
 var343 = var346;
 varonce342 = var343;
 }
 var347 = NEW_array__Array(&type_array__Arraykernel__Object);
 { /* var347 = array_instance Array[Object] */
-var348 = 4;
+var348 = 3;
 var349 = NEW_array__NativeArray(var348, &type_array__NativeArraykernel__Object);
-((struct instance_array__NativeArray*)var349)->values[0] = (val*) var_cltype;
-((struct instance_array__NativeArray*)var349)->values[1] = (val*) var337;
-((struct instance_array__NativeArray*)var349)->values[2] = (val*) var341;
-((struct instance_array__NativeArray*)var349)->values[3] = (val*) var343;
+((struct instance_array__NativeArray*)var349)->values[0] = (val*) var337;
+((struct instance_array__NativeArray*)var349)->values[1] = (val*) var341;
+((struct instance_array__NativeArray*)var349)->values[2] = (val*) var343;
 ((void (*)(val*, val*, long))(var347->class->vft[COLOR_array__Array__with_native]))(var347, var349, var348) /* with_native on <var347:Array[Object]>*/;
-CHECK_NEW_array__Array(var347);
 }
 var350 = ((val* (*)(val*))(var347->class->vft[COLOR_string__Object__to_s]))(var347) /* to_s on <var347:Array[Object]>*/;
-((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var350) /* add on <self:SeparateCompilerVisitor>*/;
+((void (*)(val*, val*))(self->class->vft[COLOR_separate_compiler__SeparateCompilerVisitor__hardening_cast_type]))(self, var350) /* hardening_cast_type on <self:SeparateCompilerVisitor>*/;
 if (varonce351) {
 var352 = varonce351;
 } else {
@@ -6243,8 +6109,8 @@ var356 = ((val* (*)(val*))(var_mtype->class->vft[COLOR_abstract_compiler__MType_
 if (varonce357) {
 var358 = varonce357;
 } else {
-var359 = ".id;";
-var360 = 4;
+var359 = ".color;";
+var360 = 7;
 var361 = string__NativeString__to_s_with_length(var359, var360);
 var358 = var361;
 varonce357 = var358;
@@ -6253,395 +6119,417 @@ var362 = NEW_array__Array(&type_array__Arraykernel__Object);
 { /* var362 = array_instance Array[Object] */
 var363 = 4;
 var364 = NEW_array__NativeArray(var363, &type_array__NativeArraykernel__Object);
-((struct instance_array__NativeArray*)var364)->values[0] = (val*) var_idtype;
+((struct instance_array__NativeArray*)var364)->values[0] = (val*) var_cltype;
 ((struct instance_array__NativeArray*)var364)->values[1] = (val*) var352;
 ((struct instance_array__NativeArray*)var364)->values[2] = (val*) var356;
 ((struct instance_array__NativeArray*)var364)->values[3] = (val*) var358;
 ((void (*)(val*, val*, long))(var362->class->vft[COLOR_array__Array__with_native]))(var362, var364, var363) /* with_native on <var362:Array[Object]>*/;
-CHECK_NEW_array__Array(var362);
 }
 var365 = ((val* (*)(val*))(var362->class->vft[COLOR_string__Object__to_s]))(var362) /* to_s on <var362:Array[Object]>*/;
 ((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var365) /* add on <self:SeparateCompilerVisitor>*/;
-var366 = ((val* (*)(val*))(var_compiler->class->vft[COLOR_abstract_compiler__AbstractCompiler__modelbuilder]))(var_compiler) /* modelbuilder on <var_compiler:SeparateCompiler>*/;
-var367 = ((val* (*)(val*))(var366->class->vft[COLOR_modelbuilder__ModelBuilder__toolcontext]))(var366) /* toolcontext on <var366:ModelBuilder>*/;
-var368 = ((val* (*)(val*))(var367->class->vft[COLOR_abstract_compiler__ToolContext__opt_typing_test_metrics]))(var367) /* opt_typing_test_metrics on <var367:ToolContext>*/;
-var369 = ((val* (*)(val*))(var368->class->vft[COLOR_opts__Option__value]))(var368) /* value on <var368:OptionBool>*/;
-var370 = ((struct instance_kernel__Bool*)var369)->value; /* autounbox from nullable Object to Bool */;
-if (var370){
-var371 = ((val* (*)(val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__compiler]))(self) /* compiler on <self:SeparateCompilerVisitor>*/;
-var372 = ((val* (*)(val*))(var371->class->vft[COLOR_abstract_compiler__AbstractCompiler__count_type_test_resolved]))(var371) /* count_type_test_resolved on <var371:AbstractCompiler(SeparateCompiler)>*/;
-var_373 = var372;
-var_374 = var_tag;
-var375 = ((val* (*)(val*, val*))(var_373->class->vft[COLOR_abstract_collection__MapRead___91d_93d]))(var_373, var_374) /* [] on <var_373:HashMap[String, Int]>*/;
-var376 = 1;
-{ /* Inline kernel#Int#+ (var375,var376) */
-var379 = ((struct instance_kernel__Int*)var375)->value; /* autounbox from nullable Object to Int */;
-var380 = var379 + var376;
-var377 = var380;
-goto RET_LABEL378;
-RET_LABEL378:(void)0;
-}
-var381 = BOX_kernel__Int(var377); /* autobox from Int to nullable Object */
-((void (*)(val*, val*, val*))(var_373->class->vft[COLOR_abstract_collection__Map___91d_93d_61d]))(var_373, var_374, var381) /* []= on <var_373:HashMap[String, Int]>*/;
-if (varonce382) {
-var383 = varonce382;
+if (varonce366) {
+var367 = varonce366;
 } else {
-var384 = "count_type_test_resolved_";
-var385 = 25;
-var386 = string__NativeString__to_s_with_length(var384, var385);
-var383 = var386;
-varonce382 = var383;
+var368 = " = type_";
+var369 = 8;
+var370 = string__NativeString__to_s_with_length(var368, var369);
+var367 = var370;
+varonce366 = var367;
 }
-if (varonce387) {
-var388 = varonce387;
+var371 = ((val* (*)(val*))(var_mtype->class->vft[COLOR_abstract_compiler__MType__c_name]))(var_mtype) /* c_name on <var_mtype:MType>*/;
+if (varonce372) {
+var373 = varonce372;
 } else {
-var389 = "++;";
-var390 = 3;
-var391 = string__NativeString__to_s_with_length(var389, var390);
-var388 = var391;
-varonce387 = var388;
+var374 = ".id;";
+var375 = 4;
+var376 = string__NativeString__to_s_with_length(var374, var375);
+var373 = var376;
+varonce372 = var373;
 }
-var392 = NEW_array__Array(&type_array__Arraykernel__Object);
-{ /* var392 = array_instance Array[Object] */
-var393 = 3;
-var394 = NEW_array__NativeArray(var393, &type_array__NativeArraykernel__Object);
-((struct instance_array__NativeArray*)var394)->values[0] = (val*) var383;
-((struct instance_array__NativeArray*)var394)->values[1] = (val*) var_tag;
-((struct instance_array__NativeArray*)var394)->values[2] = (val*) var388;
-((void (*)(val*, val*, long))(var392->class->vft[COLOR_array__Array__with_native]))(var392, var394, var393) /* with_native on <var392:Array[Object]>*/;
-CHECK_NEW_array__Array(var392);
+var377 = NEW_array__Array(&type_array__Arraykernel__Object);
+{ /* var377 = array_instance Array[Object] */
+var378 = 4;
+var379 = NEW_array__NativeArray(var378, &type_array__NativeArraykernel__Object);
+((struct instance_array__NativeArray*)var379)->values[0] = (val*) var_idtype;
+((struct instance_array__NativeArray*)var379)->values[1] = (val*) var367;
+((struct instance_array__NativeArray*)var379)->values[2] = (val*) var371;
+((struct instance_array__NativeArray*)var379)->values[3] = (val*) var373;
+((void (*)(val*, val*, long))(var377->class->vft[COLOR_array__Array__with_native]))(var377, var379, var378) /* with_native on <var377:Array[Object]>*/;
+}
+var380 = ((val* (*)(val*))(var377->class->vft[COLOR_string__Object__to_s]))(var377) /* to_s on <var377:Array[Object]>*/;
+((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var380) /* add on <self:SeparateCompilerVisitor>*/;
+var381 = ((val* (*)(val*))(var_compiler->class->vft[COLOR_abstract_compiler__AbstractCompiler__modelbuilder]))(var_compiler) /* modelbuilder on <var_compiler:SeparateCompiler>*/;
+var382 = ((val* (*)(val*))(var381->class->vft[COLOR_modelbuilder__ModelBuilder__toolcontext]))(var381) /* toolcontext on <var381:ModelBuilder>*/;
+var383 = ((val* (*)(val*))(var382->class->vft[COLOR_abstract_compiler__ToolContext__opt_typing_test_metrics]))(var382) /* opt_typing_test_metrics on <var382:ToolContext>*/;
+var384 = ((val* (*)(val*))(var383->class->vft[COLOR_opts__Option__value]))(var383) /* value on <var383:OptionBool>*/;
+var385 = ((struct instance_kernel__Bool*)var384)->value; /* autounbox from nullable Object to Bool */;
+if (var385){
+var386 = ((val* (*)(val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__compiler]))(self) /* compiler on <self:SeparateCompilerVisitor>*/;
+var387 = ((val* (*)(val*))(var386->class->vft[COLOR_abstract_compiler__AbstractCompiler__count_type_test_resolved]))(var386) /* count_type_test_resolved on <var386:AbstractCompiler(SeparateCompiler)>*/;
+var_388 = var387;
+var_389 = var_tag;
+var390 = ((val* (*)(val*, val*))(var_388->class->vft[COLOR_abstract_collection__MapRead___91d_93d]))(var_388, var_389) /* [] on <var_388:HashMap[String, Int]>*/;
+var391 = 1;
+{ /* Inline kernel#Int#+ (var390,var391) */
+var394 = ((struct instance_kernel__Int*)var390)->value; /* autounbox from nullable Object to Int */;
+var395 = var394 + var391;
+var392 = var395;
+goto RET_LABEL393;
+RET_LABEL393:(void)0;
+}
+var396 = BOX_kernel__Int(var392); /* autobox from Int to nullable Object */
+((void (*)(val*, val*, val*))(var_388->class->vft[COLOR_abstract_collection__Map___91d_93d_61d]))(var_388, var_389, var396) /* []= on <var_388:HashMap[String, Int]>*/;
+if (varonce397) {
+var398 = varonce397;
+} else {
+var399 = "count_type_test_resolved_";
+var400 = 25;
+var401 = string__NativeString__to_s_with_length(var399, var400);
+var398 = var401;
+varonce397 = var398;
 }
-var395 = ((val* (*)(val*))(var392->class->vft[COLOR_string__Object__to_s]))(var392) /* to_s on <var392:Array[Object]>*/;
-((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var395) /* add on <self:SeparateCompilerVisitor>*/;
+if (varonce402) {
+var403 = varonce402;
 } else {
+var404 = "++;";
+var405 = 3;
+var406 = string__NativeString__to_s_with_length(var404, var405);
+var403 = var406;
+varonce402 = var403;
 }
-} else {
-if (varonce396) {
-var397 = varonce396;
-} else {
-var398 = "printf(\"NOT YET IMPLEMENTED: type_test(%s, ";
-var399 = 43;
-var400 = string__NativeString__to_s_with_length(var398, var399);
-var397 = var400;
-varonce396 = var397;
+var407 = NEW_array__Array(&type_array__Arraykernel__Object);
+{ /* var407 = array_instance Array[Object] */
+var408 = 3;
+var409 = NEW_array__NativeArray(var408, &type_array__NativeArraykernel__Object);
+((struct instance_array__NativeArray*)var409)->values[0] = (val*) var398;
+((struct instance_array__NativeArray*)var409)->values[1] = (val*) var_tag;
+((struct instance_array__NativeArray*)var409)->values[2] = (val*) var403;
+((void (*)(val*, val*, long))(var407->class->vft[COLOR_array__Array__with_native]))(var407, var409, var408) /* with_native on <var407:Array[Object]>*/;
 }
-if (varonce401) {
-var402 = varonce401;
+var410 = ((val* (*)(val*))(var407->class->vft[COLOR_string__Object__to_s]))(var407) /* to_s on <var407:Array[Object]>*/;
+((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var410) /* add on <self:SeparateCompilerVisitor>*/;
 } else {
-var403 = ").\\n\", \"";
-var404 = 8;
-var405 = string__NativeString__to_s_with_length(var403, var404);
-var402 = var405;
-varonce401 = var402;
 }
-var406 = ((val* (*)(val*))(var_value->class->vft[COLOR_string__Object__inspect]))(var_value) /* inspect on <var_value:RuntimeVariable>*/;
-if (varonce407) {
-var408 = varonce407;
 } else {
-var409 = "\"); exit(1);";
-var410 = 12;
-var411 = string__NativeString__to_s_with_length(var409, var410);
-var408 = var411;
-varonce407 = var408;
-}
-var412 = NEW_array__Array(&type_array__Arraykernel__Object);
-{ /* var412 = array_instance Array[Object] */
-var413 = 5;
-var414 = NEW_array__NativeArray(var413, &type_array__NativeArraykernel__Object);
-((struct instance_array__NativeArray*)var414)->values[0] = (val*) var397;
-((struct instance_array__NativeArray*)var414)->values[1] = (val*) var_mtype;
-((struct instance_array__NativeArray*)var414)->values[2] = (val*) var402;
-((struct instance_array__NativeArray*)var414)->values[3] = (val*) var406;
-((struct instance_array__NativeArray*)var414)->values[4] = (val*) var408;
-((void (*)(val*, val*, long))(var412->class->vft[COLOR_array__Array__with_native]))(var412, var414, var413) /* with_native on <var412:Array[Object]>*/;
-CHECK_NEW_array__Array(var412);
-}
-var415 = ((val* (*)(val*))(var412->class->vft[COLOR_string__Object__to_s]))(var412) /* to_s on <var412:Array[Object]>*/;
-((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var415) /* add on <self:SeparateCompilerVisitor>*/;
-}
+if (varonce411) {
+var412 = varonce411;
+} else {
+var413 = "printf(\"NOT YET IMPLEMENTED: type_test(%s, ";
+var414 = 43;
+var415 = string__NativeString__to_s_with_length(var413, var414);
+var412 = var415;
+varonce411 = var412;
 }
-if (var_maybe_null){
 if (varonce416) {
 var417 = varonce416;
 } else {
-var418 = "if(";
-var419 = 3;
+var418 = ").\\n\", \"";
+var419 = 8;
 var420 = string__NativeString__to_s_with_length(var418, var419);
 var417 = var420;
 varonce416 = var417;
 }
-if (varonce421) {
-var422 = varonce421;
-} else {
-var423 = " == NULL) {";
-var424 = 11;
-var425 = string__NativeString__to_s_with_length(var423, var424);
-var422 = var425;
-varonce421 = var422;
-}
-var426 = NEW_array__Array(&type_array__Arraykernel__Object);
-{ /* var426 = array_instance Array[Object] */
-var427 = 3;
-var428 = NEW_array__NativeArray(var427, &type_array__NativeArraykernel__Object);
-((struct instance_array__NativeArray*)var428)->values[0] = (val*) var417;
-((struct instance_array__NativeArray*)var428)->values[1] = (val*) var_value;
-((struct instance_array__NativeArray*)var428)->values[2] = (val*) var422;
-((void (*)(val*, val*, long))(var426->class->vft[COLOR_array__Array__with_native]))(var426, var428, var427) /* with_native on <var426:Array[Object]>*/;
-CHECK_NEW_array__Array(var426);
-}
-var429 = ((val* (*)(val*))(var426->class->vft[COLOR_string__Object__to_s]))(var426) /* to_s on <var426:Array[Object]>*/;
-((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var429) /* add on <self:SeparateCompilerVisitor>*/;
-if (varonce430) {
-var431 = varonce430;
-} else {
-var432 = " = ";
-var433 = 3;
-var434 = string__NativeString__to_s_with_length(var432, var433);
-var431 = var434;
-varonce430 = var431;
-}
-if (varonce435) {
-var436 = varonce435;
-} else {
-var437 = ";";
-var438 = 1;
-var439 = string__NativeString__to_s_with_length(var437, var438);
-var436 = var439;
-varonce435 = var436;
-}
-var440 = NEW_array__Array(&type_array__Arraykernel__Object);
-{ /* var440 = array_instance Array[Object] */
-var441 = 4;
-var442 = NEW_array__NativeArray(var441, &type_array__NativeArraykernel__Object);
-((struct instance_array__NativeArray*)var442)->values[0] = (val*) var_res;
-((struct instance_array__NativeArray*)var442)->values[1] = (val*) var431;
-((struct instance_array__NativeArray*)var442)->values[2] = (val*) var_accept_null;
-((struct instance_array__NativeArray*)var442)->values[3] = (val*) var436;
-((void (*)(val*, val*, long))(var440->class->vft[COLOR_array__Array__with_native]))(var440, var442, var441) /* with_native on <var440:Array[Object]>*/;
-CHECK_NEW_array__Array(var440);
-}
-var443 = ((val* (*)(val*))(var440->class->vft[COLOR_string__Object__to_s]))(var440) /* to_s on <var440:Array[Object]>*/;
-((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var443) /* add on <self:SeparateCompilerVisitor>*/;
-if (varonce444) {
-var445 = varonce444;
-} else {
-var446 = "} else {";
-var447 = 8;
-var448 = string__NativeString__to_s_with_length(var446, var447);
-var445 = var448;
-varonce444 = var445;
-}
-((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var445) /* add on <self:SeparateCompilerVisitor>*/;
-} else {
-}
-var449 = ((val* (*)(val*, val*))(self->class->vft[COLOR_separate_compiler__SeparateCompilerVisitor__type_info]))(self, var_value) /* type_info on <self:SeparateCompilerVisitor>*/;
-var_value_type_info = var449;
-var451 = ((val* (*)(val*))(var_compiler->class->vft[COLOR_abstract_compiler__AbstractCompiler__modelbuilder]))(var_compiler) /* modelbuilder on <var_compiler:SeparateCompiler>*/;
-var452 = ((val* (*)(val*))(var451->class->vft[COLOR_modelbuilder__ModelBuilder__toolcontext]))(var451) /* toolcontext on <var451:ModelBuilder>*/;
-var453 = ((val* (*)(val*))(var452->class->vft[COLOR_separate_compiler__ToolContext__opt_phmod_typing]))(var452) /* opt_phmod_typing on <var452:ToolContext>*/;
-var454 = ((val* (*)(val*))(var453->class->vft[COLOR_opts__Option__value]))(var453) /* value on <var453:OptionBool>*/;
-var455 = ((struct instance_kernel__Bool*)var454)->value; /* autounbox from nullable Object to Bool */;
-var_456 = var455;
-if (var455){
-var450 = var_456;
-} else {
-var457 = ((val* (*)(val*))(var_compiler->class->vft[COLOR_abstract_compiler__AbstractCompiler__modelbuilder]))(var_compiler) /* modelbuilder on <var_compiler:SeparateCompiler>*/;
-var458 = ((val* (*)(val*))(var457->class->vft[COLOR_modelbuilder__ModelBuilder__toolcontext]))(var457) /* toolcontext on <var457:ModelBuilder>*/;
-var459 = ((val* (*)(val*))(var458->class->vft[COLOR_separate_compiler__ToolContext__opt_phand_typing]))(var458) /* opt_phand_typing on <var458:ToolContext>*/;
-var460 = ((val* (*)(val*))(var459->class->vft[COLOR_opts__Option__value]))(var459) /* value on <var459:OptionBool>*/;
-var461 = ((struct instance_kernel__Bool*)var460)->value; /* autounbox from nullable Object to Bool */;
-var450 = var461;
-}
-if (var450){
-if (varonce462) {
-var463 = varonce462;
-} else {
-var464 = " = HASH(";
-var465 = 8;
-var466 = string__NativeString__to_s_with_length(var464, var465);
-var463 = var466;
-varonce462 = var463;
-}
-if (varonce467) {
-var468 = varonce467;
-} else {
-var469 = "->color, ";
-var470 = 9;
-var471 = string__NativeString__to_s_with_length(var469, var470);
-var468 = var471;
-varonce467 = var468;
-}
-if (varonce472) {
-var473 = varonce472;
-} else {
-var474 = ");";
-var475 = 2;
-var476 = string__NativeString__to_s_with_length(var474, var475);
-var473 = var476;
-varonce472 = var473;
-}
-var477 = NEW_array__Array(&type_array__Arraykernel__Object);
-{ /* var477 = array_instance Array[Object] */
-var478 = 6;
-var479 = NEW_array__NativeArray(var478, &type_array__NativeArraykernel__Object);
-((struct instance_array__NativeArray*)var479)->values[0] = (val*) var_cltype;
-((struct instance_array__NativeArray*)var479)->values[1] = (val*) var463;
-((struct instance_array__NativeArray*)var479)->values[2] = (val*) var_value_type_info;
-((struct instance_array__NativeArray*)var479)->values[3] = (val*) var468;
-((struct instance_array__NativeArray*)var479)->values[4] = (val*) var_idtype;
-((struct instance_array__NativeArray*)var479)->values[5] = (val*) var473;
-((void (*)(val*, val*, long))(var477->class->vft[COLOR_array__Array__with_native]))(var477, var479, var478) /* with_native on <var477:Array[Object]>*/;
-CHECK_NEW_array__Array(var477);
-}
-var480 = ((val* (*)(val*))(var477->class->vft[COLOR_string__Object__to_s]))(var477) /* to_s on <var477:Array[Object]>*/;
-((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var480) /* add on <self:SeparateCompilerVisitor>*/;
-} else {
-}
-if (varonce481) {
-var482 = varonce481;
-} else {
-var483 = "if(";
-var484 = 3;
-var485 = string__NativeString__to_s_with_length(var483, var484);
-var482 = var485;
-varonce481 = var482;
-}
-if (varonce486) {
-var487 = varonce486;
-} else {
-var488 = " >= ";
-var489 = 4;
-var490 = string__NativeString__to_s_with_length(var488, var489);
-var487 = var490;
-varonce486 = var487;
-}
-if (varonce491) {
-var492 = varonce491;
-} else {
-var493 = "->table_size) {";
-var494 = 15;
-var495 = string__NativeString__to_s_with_length(var493, var494);
-var492 = var495;
-varonce491 = var492;
-}
-var496 = NEW_array__Array(&type_array__Arraykernel__Object);
-{ /* var496 = array_instance Array[Object] */
-var497 = 5;
-var498 = NEW_array__NativeArray(var497, &type_array__NativeArraykernel__Object);
-((struct instance_array__NativeArray*)var498)->values[0] = (val*) var482;
-((struct instance_array__NativeArray*)var498)->values[1] = (val*) var_cltype;
-((struct instance_array__NativeArray*)var498)->values[2] = (val*) var487;
-((struct instance_array__NativeArray*)var498)->values[3] = (val*) var_value_type_info;
-((struct instance_array__NativeArray*)var498)->values[4] = (val*) var492;
-((void (*)(val*, val*, long))(var496->class->vft[COLOR_array__Array__with_native]))(var496, var498, var497) /* with_native on <var496:Array[Object]>*/;
-CHECK_NEW_array__Array(var496);
-}
-var499 = ((val* (*)(val*))(var496->class->vft[COLOR_string__Object__to_s]))(var496) /* to_s on <var496:Array[Object]>*/;
-((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var499) /* add on <self:SeparateCompilerVisitor>*/;
-if (varonce500) {
-var501 = varonce500;
-} else {
-var502 = " = 0;";
-var503 = 5;
-var504 = string__NativeString__to_s_with_length(var502, var503);
-var501 = var504;
-varonce500 = var501;
-}
-var505 = NEW_array__Array(&type_array__Arraykernel__Object);
-{ /* var505 = array_instance Array[Object] */
-var506 = 2;
-var507 = NEW_array__NativeArray(var506, &type_array__NativeArraykernel__Object);
-((struct instance_array__NativeArray*)var507)->values[0] = (val*) var_res;
-((struct instance_array__NativeArray*)var507)->values[1] = (val*) var501;
-((void (*)(val*, val*, long))(var505->class->vft[COLOR_array__Array__with_native]))(var505, var507, var506) /* with_native on <var505:Array[Object]>*/;
-CHECK_NEW_array__Array(var505);
-}
-var508 = ((val* (*)(val*))(var505->class->vft[COLOR_string__Object__to_s]))(var505) /* to_s on <var505:Array[Object]>*/;
-((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var508) /* add on <self:SeparateCompilerVisitor>*/;
-if (varonce509) {
-var510 = varonce509;
-} else {
-var511 = "} else {";
-var512 = 8;
-var513 = string__NativeString__to_s_with_length(var511, var512);
-var510 = var513;
-varonce509 = var510;
-}
-((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var510) /* add on <self:SeparateCompilerVisitor>*/;
-if (varonce514) {
-var515 = varonce514;
-} else {
-var516 = " = ";
-var517 = 3;
-var518 = string__NativeString__to_s_with_length(var516, var517);
-var515 = var518;
-varonce514 = var515;
-}
-if (varonce519) {
-var520 = varonce519;
-} else {
-var521 = "->type_table[";
-var522 = 13;
-var523 = string__NativeString__to_s_with_length(var521, var522);
-var520 = var523;
-varonce519 = var520;
+var421 = ((val* (*)(val*))(var_value->class->vft[COLOR_string__Object__inspect]))(var_value) /* inspect on <var_value:RuntimeVariable>*/;
+if (varonce422) {
+var423 = varonce422;
+} else {
+var424 = "\"); show_backtrace(1);";
+var425 = 22;
+var426 = string__NativeString__to_s_with_length(var424, var425);
+var423 = var426;
+varonce422 = var423;
+}
+var427 = NEW_array__Array(&type_array__Arraykernel__Object);
+{ /* var427 = array_instance Array[Object] */
+var428 = 5;
+var429 = NEW_array__NativeArray(var428, &type_array__NativeArraykernel__Object);
+((struct instance_array__NativeArray*)var429)->values[0] = (val*) var412;
+((struct instance_array__NativeArray*)var429)->values[1] = (val*) var_mtype;
+((struct instance_array__NativeArray*)var429)->values[2] = (val*) var417;
+((struct instance_array__NativeArray*)var429)->values[3] = (val*) var421;
+((struct instance_array__NativeArray*)var429)->values[4] = (val*) var423;
+((void (*)(val*, val*, long))(var427->class->vft[COLOR_array__Array__with_native]))(var427, var429, var428) /* with_native on <var427:Array[Object]>*/;
+}
+var430 = ((val* (*)(val*))(var427->class->vft[COLOR_string__Object__to_s]))(var427) /* to_s on <var427:Array[Object]>*/;
+((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var430) /* add on <self:SeparateCompilerVisitor>*/;
 }
+}
+if (var_maybe_null){
+if (varonce431) {
+var432 = varonce431;
+} else {
+var433 = "if(";
+var434 = 3;
+var435 = string__NativeString__to_s_with_length(var433, var434);
+var432 = var435;
+varonce431 = var432;
+}
+if (varonce436) {
+var437 = varonce436;
+} else {
+var438 = " == NULL) {";
+var439 = 11;
+var440 = string__NativeString__to_s_with_length(var438, var439);
+var437 = var440;
+varonce436 = var437;
+}
+var441 = NEW_array__Array(&type_array__Arraykernel__Object);
+{ /* var441 = array_instance Array[Object] */
+var442 = 3;
+var443 = NEW_array__NativeArray(var442, &type_array__NativeArraykernel__Object);
+((struct instance_array__NativeArray*)var443)->values[0] = (val*) var432;
+((struct instance_array__NativeArray*)var443)->values[1] = (val*) var_value;
+((struct instance_array__NativeArray*)var443)->values[2] = (val*) var437;
+((void (*)(val*, val*, long))(var441->class->vft[COLOR_array__Array__with_native]))(var441, var443, var442) /* with_native on <var441:Array[Object]>*/;
+}
+var444 = ((val* (*)(val*))(var441->class->vft[COLOR_string__Object__to_s]))(var441) /* to_s on <var441:Array[Object]>*/;
+((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var444) /* add on <self:SeparateCompilerVisitor>*/;
+if (varonce445) {
+var446 = varonce445;
+} else {
+var447 = " = ";
+var448 = 3;
+var449 = string__NativeString__to_s_with_length(var447, var448);
+var446 = var449;
+varonce445 = var446;
+}
+if (varonce450) {
+var451 = varonce450;
+} else {
+var452 = ";";
+var453 = 1;
+var454 = string__NativeString__to_s_with_length(var452, var453);
+var451 = var454;
+varonce450 = var451;
+}
+var455 = NEW_array__Array(&type_array__Arraykernel__Object);
+{ /* var455 = array_instance Array[Object] */
+var456 = 4;
+var457 = NEW_array__NativeArray(var456, &type_array__NativeArraykernel__Object);
+((struct instance_array__NativeArray*)var457)->values[0] = (val*) var_res;
+((struct instance_array__NativeArray*)var457)->values[1] = (val*) var446;
+((struct instance_array__NativeArray*)var457)->values[2] = (val*) var_accept_null;
+((struct instance_array__NativeArray*)var457)->values[3] = (val*) var451;
+((void (*)(val*, val*, long))(var455->class->vft[COLOR_array__Array__with_native]))(var455, var457, var456) /* with_native on <var455:Array[Object]>*/;
+}
+var458 = ((val* (*)(val*))(var455->class->vft[COLOR_string__Object__to_s]))(var455) /* to_s on <var455:Array[Object]>*/;
+((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var458) /* add on <self:SeparateCompilerVisitor>*/;
+if (varonce459) {
+var460 = varonce459;
+} else {
+var461 = "} else {";
+var462 = 8;
+var463 = string__NativeString__to_s_with_length(var461, var462);
+var460 = var463;
+varonce459 = var460;
+}
+((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var460) /* add on <self:SeparateCompilerVisitor>*/;
+} else {
+}
+var464 = ((val* (*)(val*, val*))(self->class->vft[COLOR_separate_compiler__SeparateCompilerVisitor__type_info]))(self, var_value) /* type_info on <self:SeparateCompilerVisitor>*/;
+var_value_type_info = var464;
+var466 = ((val* (*)(val*))(var_compiler->class->vft[COLOR_abstract_compiler__AbstractCompiler__modelbuilder]))(var_compiler) /* modelbuilder on <var_compiler:SeparateCompiler>*/;
+var467 = ((val* (*)(val*))(var466->class->vft[COLOR_modelbuilder__ModelBuilder__toolcontext]))(var466) /* toolcontext on <var466:ModelBuilder>*/;
+var468 = ((val* (*)(val*))(var467->class->vft[COLOR_separate_compiler__ToolContext__opt_phmod_typing]))(var467) /* opt_phmod_typing on <var467:ToolContext>*/;
+var469 = ((val* (*)(val*))(var468->class->vft[COLOR_opts__Option__value]))(var468) /* value on <var468:OptionBool>*/;
+var470 = ((struct instance_kernel__Bool*)var469)->value; /* autounbox from nullable Object to Bool */;
+var_471 = var470;
+if (var470){
+var465 = var_471;
+} else {
+var472 = ((val* (*)(val*))(var_compiler->class->vft[COLOR_abstract_compiler__AbstractCompiler__modelbuilder]))(var_compiler) /* modelbuilder on <var_compiler:SeparateCompiler>*/;
+var473 = ((val* (*)(val*))(var472->class->vft[COLOR_modelbuilder__ModelBuilder__toolcontext]))(var472) /* toolcontext on <var472:ModelBuilder>*/;
+var474 = ((val* (*)(val*))(var473->class->vft[COLOR_separate_compiler__ToolContext__opt_phand_typing]))(var473) /* opt_phand_typing on <var473:ToolContext>*/;
+var475 = ((val* (*)(val*))(var474->class->vft[COLOR_opts__Option__value]))(var474) /* value on <var474:OptionBool>*/;
+var476 = ((struct instance_kernel__Bool*)var475)->value; /* autounbox from nullable Object to Bool */;
+var465 = var476;
+}
+if (var465){
+if (varonce477) {
+var478 = varonce477;
+} else {
+var479 = " = HASH(";
+var480 = 8;
+var481 = string__NativeString__to_s_with_length(var479, var480);
+var478 = var481;
+varonce477 = var478;
+}
+if (varonce482) {
+var483 = varonce482;
+} else {
+var484 = "->color, ";
+var485 = 9;
+var486 = string__NativeString__to_s_with_length(var484, var485);
+var483 = var486;
+varonce482 = var483;
+}
+if (varonce487) {
+var488 = varonce487;
+} else {
+var489 = ");";
+var490 = 2;
+var491 = string__NativeString__to_s_with_length(var489, var490);
+var488 = var491;
+varonce487 = var488;
+}
+var492 = NEW_array__Array(&type_array__Arraykernel__Object);
+{ /* var492 = array_instance Array[Object] */
+var493 = 6;
+var494 = NEW_array__NativeArray(var493, &type_array__NativeArraykernel__Object);
+((struct instance_array__NativeArray*)var494)->values[0] = (val*) var_cltype;
+((struct instance_array__NativeArray*)var494)->values[1] = (val*) var478;
+((struct instance_array__NativeArray*)var494)->values[2] = (val*) var_value_type_info;
+((struct instance_array__NativeArray*)var494)->values[3] = (val*) var483;
+((struct instance_array__NativeArray*)var494)->values[4] = (val*) var_idtype;
+((struct instance_array__NativeArray*)var494)->values[5] = (val*) var488;
+((void (*)(val*, val*, long))(var492->class->vft[COLOR_array__Array__with_native]))(var492, var494, var493) /* with_native on <var492:Array[Object]>*/;
+}
+var495 = ((val* (*)(val*))(var492->class->vft[COLOR_string__Object__to_s]))(var492) /* to_s on <var492:Array[Object]>*/;
+((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var495) /* add on <self:SeparateCompilerVisitor>*/;
+} else {
+}
+if (varonce496) {
+var497 = varonce496;
+} else {
+var498 = "if(";
+var499 = 3;
+var500 = string__NativeString__to_s_with_length(var498, var499);
+var497 = var500;
+varonce496 = var497;
+}
+if (varonce501) {
+var502 = varonce501;
+} else {
+var503 = " >= ";
+var504 = 4;
+var505 = string__NativeString__to_s_with_length(var503, var504);
+var502 = var505;
+varonce501 = var502;
+}
+if (varonce506) {
+var507 = varonce506;
+} else {
+var508 = "->table_size) {";
+var509 = 15;
+var510 = string__NativeString__to_s_with_length(var508, var509);
+var507 = var510;
+varonce506 = var507;
+}
+var511 = NEW_array__Array(&type_array__Arraykernel__Object);
+{ /* var511 = array_instance Array[Object] */
+var512 = 5;
+var513 = NEW_array__NativeArray(var512, &type_array__NativeArraykernel__Object);
+((struct instance_array__NativeArray*)var513)->values[0] = (val*) var497;
+((struct instance_array__NativeArray*)var513)->values[1] = (val*) var_cltype;
+((struct instance_array__NativeArray*)var513)->values[2] = (val*) var502;
+((struct instance_array__NativeArray*)var513)->values[3] = (val*) var_value_type_info;
+((struct instance_array__NativeArray*)var513)->values[4] = (val*) var507;
+((void (*)(val*, val*, long))(var511->class->vft[COLOR_array__Array__with_native]))(var511, var513, var512) /* with_native on <var511:Array[Object]>*/;
+}
+var514 = ((val* (*)(val*))(var511->class->vft[COLOR_string__Object__to_s]))(var511) /* to_s on <var511:Array[Object]>*/;
+((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var514) /* add on <self:SeparateCompilerVisitor>*/;
+if (varonce515) {
+var516 = varonce515;
+} else {
+var517 = " = 0;";
+var518 = 5;
+var519 = string__NativeString__to_s_with_length(var517, var518);
+var516 = var519;
+varonce515 = var516;
+}
+var520 = NEW_array__Array(&type_array__Arraykernel__Object);
+{ /* var520 = array_instance Array[Object] */
+var521 = 2;
+var522 = NEW_array__NativeArray(var521, &type_array__NativeArraykernel__Object);
+((struct instance_array__NativeArray*)var522)->values[0] = (val*) var_res;
+((struct instance_array__NativeArray*)var522)->values[1] = (val*) var516;
+((void (*)(val*, val*, long))(var520->class->vft[COLOR_array__Array__with_native]))(var520, var522, var521) /* with_native on <var520:Array[Object]>*/;
+}
+var523 = ((val* (*)(val*))(var520->class->vft[COLOR_string__Object__to_s]))(var520) /* to_s on <var520:Array[Object]>*/;
+((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var523) /* add on <self:SeparateCompilerVisitor>*/;
 if (varonce524) {
 var525 = varonce524;
 } else {
-var526 = "] == ";
-var527 = 5;
+var526 = "} else {";
+var527 = 8;
 var528 = string__NativeString__to_s_with_length(var526, var527);
 var525 = var528;
 varonce524 = var525;
 }
+((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var525) /* add on <self:SeparateCompilerVisitor>*/;
 if (varonce529) {
 var530 = varonce529;
 } else {
-var531 = ";";
-var532 = 1;
+var531 = " = ";
+var532 = 3;
 var533 = string__NativeString__to_s_with_length(var531, var532);
 var530 = var533;
 varonce529 = var530;
 }
-var534 = NEW_array__Array(&type_array__Arraykernel__Object);
-{ /* var534 = array_instance Array[Object] */
-var535 = 8;
-var536 = NEW_array__NativeArray(var535, &type_array__NativeArraykernel__Object);
-((struct instance_array__NativeArray*)var536)->values[0] = (val*) var_res;
-((struct instance_array__NativeArray*)var536)->values[1] = (val*) var515;
-((struct instance_array__NativeArray*)var536)->values[2] = (val*) var_value_type_info;
-((struct instance_array__NativeArray*)var536)->values[3] = (val*) var520;
-((struct instance_array__NativeArray*)var536)->values[4] = (val*) var_cltype;
-((struct instance_array__NativeArray*)var536)->values[5] = (val*) var525;
-((struct instance_array__NativeArray*)var536)->values[6] = (val*) var_idtype;
-((struct instance_array__NativeArray*)var536)->values[7] = (val*) var530;
-((void (*)(val*, val*, long))(var534->class->vft[COLOR_array__Array__with_native]))(var534, var536, var535) /* with_native on <var534:Array[Object]>*/;
-CHECK_NEW_array__Array(var534);
-}
-var537 = ((val* (*)(val*))(var534->class->vft[COLOR_string__Object__to_s]))(var534) /* to_s on <var534:Array[Object]>*/;
-((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var537) /* add on <self:SeparateCompilerVisitor>*/;
-if (varonce538) {
-var539 = varonce538;
-} else {
-var540 = "}";
-var541 = 1;
-var542 = string__NativeString__to_s_with_length(var540, var541);
-var539 = var542;
-varonce538 = var539;
-}
-((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var539) /* add on <self:SeparateCompilerVisitor>*/;
+if (varonce534) {
+var535 = varonce534;
+} else {
+var536 = "->type_table[";
+var537 = 13;
+var538 = string__NativeString__to_s_with_length(var536, var537);
+var535 = var538;
+varonce534 = var535;
+}
+if (varonce539) {
+var540 = varonce539;
+} else {
+var541 = "] == ";
+var542 = 5;
+var543 = string__NativeString__to_s_with_length(var541, var542);
+var540 = var543;
+varonce539 = var540;
+}
+if (varonce544) {
+var545 = varonce544;
+} else {
+var546 = ";";
+var547 = 1;
+var548 = string__NativeString__to_s_with_length(var546, var547);
+var545 = var548;
+varonce544 = var545;
+}
+var549 = NEW_array__Array(&type_array__Arraykernel__Object);
+{ /* var549 = array_instance Array[Object] */
+var550 = 8;
+var551 = NEW_array__NativeArray(var550, &type_array__NativeArraykernel__Object);
+((struct instance_array__NativeArray*)var551)->values[0] = (val*) var_res;
+((struct instance_array__NativeArray*)var551)->values[1] = (val*) var530;
+((struct instance_array__NativeArray*)var551)->values[2] = (val*) var_value_type_info;
+((struct instance_array__NativeArray*)var551)->values[3] = (val*) var535;
+((struct instance_array__NativeArray*)var551)->values[4] = (val*) var_cltype;
+((struct instance_array__NativeArray*)var551)->values[5] = (val*) var540;
+((struct instance_array__NativeArray*)var551)->values[6] = (val*) var_idtype;
+((struct instance_array__NativeArray*)var551)->values[7] = (val*) var545;
+((void (*)(val*, val*, long))(var549->class->vft[COLOR_array__Array__with_native]))(var549, var551, var550) /* with_native on <var549:Array[Object]>*/;
+}
+var552 = ((val* (*)(val*))(var549->class->vft[COLOR_string__Object__to_s]))(var549) /* to_s on <var549:Array[Object]>*/;
+((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var552) /* add on <self:SeparateCompilerVisitor>*/;
+if (varonce553) {
+var554 = varonce553;
+} else {
+var555 = "}";
+var556 = 1;
+var557 = string__NativeString__to_s_with_length(var555, var556);
+var554 = var557;
+varonce553 = var554;
+}
+((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var554) /* add on <self:SeparateCompilerVisitor>*/;
 if (var_maybe_null){
-if (varonce543) {
-var544 = varonce543;
+if (varonce558) {
+var559 = varonce558;
 } else {
-var545 = "}";
-var546 = 1;
-var547 = string__NativeString__to_s_with_length(var545, var546);
-var544 = var547;
-varonce543 = var544;
+var560 = "}";
+var561 = 1;
+var562 = string__NativeString__to_s_with_length(var560, var561);
+var559 = var562;
+varonce558 = var559;
 }
-((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var544) /* add on <self:SeparateCompilerVisitor>*/;
+((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var559) /* add on <self:SeparateCompilerVisitor>*/;
 } else {
 }
 var = var_res;
@@ -6924,7 +6812,6 @@ var49 = NEW_array__NativeArray(var48, &type_array__NativeArraykernel__Object);
 ((struct instance_array__NativeArray*)var49)->values[4] = (val*) var41;
 ((struct instance_array__NativeArray*)var49)->values[5] = (val*) var43;
 ((void (*)(val*, val*, long))(var47->class->vft[COLOR_array__Array__with_native]))(var47, var49, var48) /* with_native on <var47:Array[Object]>*/;
-CHECK_NEW_array__Array(var47);
 }
 var50 = ((val* (*)(val*))(var47->class->vft[COLOR_string__Object__to_s]))(var47) /* to_s on <var47:Array[Object]>*/;
 ((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var50) /* add on <self:SeparateCompilerVisitor>*/;
@@ -6982,7 +6869,6 @@ var78 = NEW_array__NativeArray(var77, &type_array__NativeArraykernel__Object);
 ((struct instance_array__NativeArray*)var78)->values[4] = (val*) var70;
 ((struct instance_array__NativeArray*)var78)->values[5] = (val*) var72;
 ((void (*)(val*, val*, long))(var76->class->vft[COLOR_array__Array__with_native]))(var76, var78, var77) /* with_native on <var76:Array[Object]>*/;
-CHECK_NEW_array__Array(var76);
 }
 var79 = ((val* (*)(val*))(var76->class->vft[COLOR_string__Object__to_s]))(var76) /* to_s on <var76:Array[Object]>*/;
 ((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var79) /* add on <self:SeparateCompilerVisitor>*/;
@@ -6999,8 +6885,8 @@ var81 = var80->type->type_table[cltype] == idtype;
 if (!var81) {
 var_class_name = var80 == NULL ? "null" : var80->type->name;
 fprintf(stderr, "Runtime error: Cast failed. Expected `%s`, got `%s`", "MClassType", var_class_name);
-fprintf(stderr, " (%s:%d)\n", "src/separate_compiler.nit", 1392);
-exit(1);
+fprintf(stderr, " (%s:%d)\n", "src/separate_compiler.nit", 1446);
+show_backtrace(1);
 }
 var_mtype1 = var80;
 if (varonce82) {
@@ -7020,7 +6906,6 @@ var90 = NEW_array__NativeArray(var89, &type_array__NativeArraykernel__Object);
 ((struct instance_array__NativeArray*)var90)->values[0] = (val*) var83;
 ((struct instance_array__NativeArray*)var90)->values[1] = (val*) var87;
 ((void (*)(val*, val*, long))(var88->class->vft[COLOR_array__Array__with_native]))(var88, var90, var89) /* with_native on <var88:Array[Object]>*/;
-CHECK_NEW_array__Array(var88);
 }
 var91 = ((val* (*)(val*))(var88->class->vft[COLOR_string__Object__to_s]))(var88) /* to_s on <var88:Array[Object]>*/;
 ((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__require_declaration]))(self, var91) /* require_declaration on <self:SeparateCompilerVisitor>*/;
@@ -7074,7 +6959,6 @@ var115 = NEW_array__NativeArray(var114, &type_array__NativeArraykernel__Object);
 ((struct instance_array__NativeArray*)var115)->values[6] = (val*) var107;
 ((struct instance_array__NativeArray*)var115)->values[7] = (val*) var109;
 ((void (*)(val*, val*, long))(var113->class->vft[COLOR_array__Array__with_native]))(var113, var115, var114) /* with_native on <var113:Array[Object]>*/;
-CHECK_NEW_array__Array(var113);
 }
 var116 = ((val* (*)(val*))(var113->class->vft[COLOR_string__Object__to_s]))(var113) /* to_s on <var113:Array[Object]>*/;
 ((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var116) /* add on <self:SeparateCompilerVisitor>*/;
@@ -7163,7 +7047,6 @@ var154 = NEW_array__NativeArray(var153, &type_array__NativeArraykernel__Object);
 ((struct instance_array__NativeArray*)var154)->values[12] = (val*) var_value2;
 ((struct instance_array__NativeArray*)var154)->values[13] = (val*) var148;
 ((void (*)(val*, val*, long))(var152->class->vft[COLOR_array__Array__with_native]))(var152, var154, var153) /* with_native on <var152:Array[Object]>*/;
-CHECK_NEW_array__Array(var152);
 }
 var155 = ((val* (*)(val*))(var152->class->vft[COLOR_string__Object__to_s]))(var152) /* to_s on <var152:Array[Object]>*/;
 ((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var155) /* add on <self:SeparateCompilerVisitor>*/;
@@ -7234,33 +7117,68 @@ val* var43 /* : Array[Object] */;
 long var44 /* : Int */;
 val* var45 /* : NativeArray[Object] */;
 val* var46 /* : String */;
-static val* varonce47;
-val* var48 /* : String */;
-char* var49 /* : NativeString */;
-long var50 /* : Int */;
-val* var51 /* : String */;
-val* var52 /* : MType */;
-val* var53 /* : String */;
-val* var54 /* : Array[Object] */;
-long var55 /* : Int */;
-val* var56 /* : NativeArray[Object] */;
-val* var57 /* : String */;
+short int var47 /* : Bool */;
+val* var48 /* : MType */;
+short int var49 /* : Bool */;
+int cltype;
+int idtype;
+short int var_ /* var : Bool */;
+val* var50 /* : MType */;
+short int var51 /* : Bool */;
+int cltype52;
+int idtype53;
+const char* var_class_name;
+val* var54 /* : MClass */;
+val* var55 /* : MClassKind */;
+val* var56 /* : MClassKind */;
+short int var57 /* : Bool */;
 static val* varonce58;
 val* var59 /* : String */;
 char* var60 /* : NativeString */;
 long var61 /* : Int */;
 val* var62 /* : String */;
 val* var63 /* : MType */;
-val* var64 /* : String */;
-static val* varonce65;
-val* var66 /* : String */;
-char* var67 /* : NativeString */;
-long var68 /* : Int */;
-val* var69 /* : String */;
-val* var70 /* : Array[Object] */;
-long var71 /* : Int */;
-val* var72 /* : NativeArray[Object] */;
+short int var64 /* : Bool */;
+int cltype65;
+int idtype66;
+const char* var_class_name67;
+val* var68 /* : MClass */;
+static val* varonce69;
+val* var70 /* : String */;
+char* var71 /* : NativeString */;
+long var72 /* : Int */;
 val* var73 /* : String */;
+val* var74 /* : Array[Object] */;
+long var75 /* : Int */;
+val* var76 /* : NativeArray[Object] */;
+val* var77 /* : String */;
+static val* varonce78;
+val* var79 /* : String */;
+char* var80 /* : NativeString */;
+long var81 /* : Int */;
+val* var82 /* : String */;
+val* var83 /* : MType */;
+val* var84 /* : String */;
+val* var85 /* : Array[Object] */;
+long var86 /* : Int */;
+val* var87 /* : NativeArray[Object] */;
+val* var88 /* : String */;
+static val* varonce89;
+val* var90 /* : String */;
+char* var91 /* : NativeString */;
+long var92 /* : Int */;
+val* var93 /* : String */;
+val* var94 /* : MType */;
+val* var95 /* : String */;
+static val* varonce96;
+val* var97 /* : String */;
+char* var98 /* : NativeString */;
+long var99 /* : Int */;
+val* var100 /* : String */;
+val* var101 /* : Array[Object] */;
+long var102 /* : Int */;
+val* var103 /* : NativeArray[Object] */;
+val* var104 /* : String */;
 var_value = p0;
 if (varonce) {
 var1 = varonce;
@@ -7299,7 +7217,6 @@ var18 = NEW_array__NativeArray(var17, &type_array__NativeArraykernel__Object);
 ((struct instance_array__NativeArray*)var18)->values[1] = (val*) var_res;
 ((struct instance_array__NativeArray*)var18)->values[2] = (val*) var12;
 ((void (*)(val*, val*, long))(var16->class->vft[COLOR_array__Array__with_native]))(var16, var18, var17) /* with_native on <var16:Array[Object]>*/;
-CHECK_NEW_array__Array(var16);
 }
 var19 = ((val* (*)(val*))(var16->class->vft[COLOR_string__Object__to_s]))(var16) /* to_s on <var16:Array[Object]>*/;
 ((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add_decl]))(self, var19) /* add_decl on <self:SeparateCompilerVisitor>*/;
@@ -7354,66 +7271,146 @@ var45 = NEW_array__NativeArray(var44, &type_array__NativeArraykernel__Object);
 ((struct instance_array__NativeArray*)var45)->values[4] = (val*) var_value;
 ((struct instance_array__NativeArray*)var45)->values[5] = (val*) var39;
 ((void (*)(val*, val*, long))(var43->class->vft[COLOR_array__Array__with_native]))(var43, var45, var44) /* with_native on <var43:Array[Object]>*/;
-CHECK_NEW_array__Array(var43);
 }
 var46 = ((val* (*)(val*))(var43->class->vft[COLOR_string__Object__to_s]))(var43) /* to_s on <var43:Array[Object]>*/;
 ((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var46) /* add on <self:SeparateCompilerVisitor>*/;
 } else {
-if (varonce47) {
-var48 = varonce47;
+var48 = ((val* (*)(val*))(var_value->class->vft[COLOR_abstract_compiler__RuntimeVariable__mtype]))(var_value) /* mtype on <var_value:RuntimeVariable>*/;
+/* <var48:MType> isa MClassType */
+cltype = type_model__MClassType.color;
+idtype = type_model__MClassType.id;
+if(cltype >= var48->type->table_size) {
+var49 = 0;
+} else {
+var49 = var48->type->type_table[cltype] == idtype;
+}
+var_ = var49;
+if (var49){
+var50 = ((val* (*)(val*))(var_value->class->vft[COLOR_abstract_compiler__RuntimeVariable__mtype]))(var_value) /* mtype on <var_value:RuntimeVariable>*/;
+/* <var50:MType> isa MClassType */
+cltype52 = type_model__MClassType.color;
+idtype53 = type_model__MClassType.id;
+if(cltype52 >= var50->type->table_size) {
+var51 = 0;
 } else {
-var49 = "type_";
-var50 = 5;
-var51 = string__NativeString__to_s_with_length(var49, var50);
-var48 = var51;
-varonce47 = var48;
+var51 = var50->type->type_table[cltype52] == idtype53;
+}
+if (!var51) {
+var_class_name = var50 == NULL ? "null" : var50->type->name;
+fprintf(stderr, "Runtime error: Cast failed. Expected `%s`, got `%s`", "MClassType", var_class_name);
+fprintf(stderr, " (%s:%d)\n", "src/separate_compiler.nit", 1462);
+show_backtrace(1);
+}
+var54 = ((val* (*)(val*))(var50->class->vft[COLOR_model__MClassType__mclass]))(var50) /* mclass on <var50:MType(MClassType)>*/;
+var55 = ((val* (*)(val*))(var54->class->vft[COLOR_model__MClass__kind]))(var54) /* kind on <var54:MClass>*/;
+var56 = ((val* (*)(val*))(self->class->vft[COLOR_model__Object__extern_kind]))(self) /* extern_kind on <self:SeparateCompilerVisitor>*/;
+var57 = ((short int (*)(val*, val*))(var55->class->vft[COLOR_kernel__Object___61d_61d]))(var55, var56) /* == on <var55:MClassKind>*/;
+var47 = var57;
+} else {
+var47 = var_;
 }
-var52 = ((val* (*)(val*))(var_value->class->vft[COLOR_abstract_compiler__RuntimeVariable__mtype]))(var_value) /* mtype on <var_value:RuntimeVariable>*/;
-var53 = ((val* (*)(val*))(var52->class->vft[COLOR_abstract_compiler__MType__c_name]))(var52) /* c_name on <var52:MType>*/;
-var54 = NEW_array__Array(&type_array__Arraykernel__Object);
-{ /* var54 = array_instance Array[Object] */
-var55 = 2;
-var56 = NEW_array__NativeArray(var55, &type_array__NativeArraykernel__Object);
-((struct instance_array__NativeArray*)var56)->values[0] = (val*) var48;
-((struct instance_array__NativeArray*)var56)->values[1] = (val*) var53;
-((void (*)(val*, val*, long))(var54->class->vft[COLOR_array__Array__with_native]))(var54, var56, var55) /* with_native on <var54:Array[Object]>*/;
-CHECK_NEW_array__Array(var54);
-}
-var57 = ((val* (*)(val*))(var54->class->vft[COLOR_string__Object__to_s]))(var54) /* to_s on <var54:Array[Object]>*/;
-((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__require_declaration]))(self, var57) /* require_declaration on <self:SeparateCompilerVisitor>*/;
+if (var47){
 if (varonce58) {
 var59 = varonce58;
 } else {
-var60 = " = type_";
-var61 = 8;
+var60 = " = \"";
+var61 = 4;
 var62 = string__NativeString__to_s_with_length(var60, var61);
 var59 = var62;
 varonce58 = var59;
 }
 var63 = ((val* (*)(val*))(var_value->class->vft[COLOR_abstract_compiler__RuntimeVariable__mtype]))(var_value) /* mtype on <var_value:RuntimeVariable>*/;
-var64 = ((val* (*)(val*))(var63->class->vft[COLOR_abstract_compiler__MType__c_name]))(var63) /* c_name on <var63:MType>*/;
-if (varonce65) {
-var66 = varonce65;
+/* <var63:MType> isa MClassType */
+cltype65 = type_model__MClassType.color;
+idtype66 = type_model__MClassType.id;
+if(cltype65 >= var63->type->table_size) {
+var64 = 0;
 } else {
-var67 = ".name;";
-var68 = 6;
-var69 = string__NativeString__to_s_with_length(var67, var68);
-var66 = var69;
-varonce65 = var66;
+var64 = var63->type->type_table[cltype65] == idtype66;
 }
-var70 = NEW_array__Array(&type_array__Arraykernel__Object);
-{ /* var70 = array_instance Array[Object] */
-var71 = 4;
-var72 = NEW_array__NativeArray(var71, &type_array__NativeArraykernel__Object);
-((struct instance_array__NativeArray*)var72)->values[0] = (val*) var_res;
-((struct instance_array__NativeArray*)var72)->values[1] = (val*) var59;
-((struct instance_array__NativeArray*)var72)->values[2] = (val*) var64;
-((struct instance_array__NativeArray*)var72)->values[3] = (val*) var66;
-((void (*)(val*, val*, long))(var70->class->vft[COLOR_array__Array__with_native]))(var70, var72, var71) /* with_native on <var70:Array[Object]>*/;
-CHECK_NEW_array__Array(var70);
+if (!var64) {
+var_class_name67 = var63 == NULL ? "null" : var63->type->name;
+fprintf(stderr, "Runtime error: Cast failed. Expected `%s`, got `%s`", "MClassType", var_class_name67);
+fprintf(stderr, " (%s:%d)\n", "src/separate_compiler.nit", 1463);
+show_backtrace(1);
+}
+var68 = ((val* (*)(val*))(var63->class->vft[COLOR_model__MClassType__mclass]))(var63) /* mclass on <var63:MType(MClassType)>*/;
+if (varonce69) {
+var70 = varonce69;
+} else {
+var71 = "\";";
+var72 = 2;
+var73 = string__NativeString__to_s_with_length(var71, var72);
+var70 = var73;
+varonce69 = var70;
+}
+var74 = NEW_array__Array(&type_array__Arraykernel__Object);
+{ /* var74 = array_instance Array[Object] */
+var75 = 4;
+var76 = NEW_array__NativeArray(var75, &type_array__NativeArraykernel__Object);
+((struct instance_array__NativeArray*)var76)->values[0] = (val*) var_res;
+((struct instance_array__NativeArray*)var76)->values[1] = (val*) var59;
+((struct instance_array__NativeArray*)var76)->values[2] = (val*) var68;
+((struct instance_array__NativeArray*)var76)->values[3] = (val*) var70;
+((void (*)(val*, val*, long))(var74->class->vft[COLOR_array__Array__with_native]))(var74, var76, var75) /* with_native on <var74:Array[Object]>*/;
+}
+var77 = ((val* (*)(val*))(var74->class->vft[COLOR_string__Object__to_s]))(var74) /* to_s on <var74:Array[Object]>*/;
+((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var77) /* add on <self:SeparateCompilerVisitor>*/;
+} else {
+if (varonce78) {
+var79 = varonce78;
+} else {
+var80 = "type_";
+var81 = 5;
+var82 = string__NativeString__to_s_with_length(var80, var81);
+var79 = var82;
+varonce78 = var79;
+}
+var83 = ((val* (*)(val*))(var_value->class->vft[COLOR_abstract_compiler__RuntimeVariable__mtype]))(var_value) /* mtype on <var_value:RuntimeVariable>*/;
+var84 = ((val* (*)(val*))(var83->class->vft[COLOR_abstract_compiler__MType__c_name]))(var83) /* c_name on <var83:MType>*/;
+var85 = NEW_array__Array(&type_array__Arraykernel__Object);
+{ /* var85 = array_instance Array[Object] */
+var86 = 2;
+var87 = NEW_array__NativeArray(var86, &type_array__NativeArraykernel__Object);
+((struct instance_array__NativeArray*)var87)->values[0] = (val*) var79;
+((struct instance_array__NativeArray*)var87)->values[1] = (val*) var84;
+((void (*)(val*, val*, long))(var85->class->vft[COLOR_array__Array__with_native]))(var85, var87, var86) /* with_native on <var85:Array[Object]>*/;
+}
+var88 = ((val* (*)(val*))(var85->class->vft[COLOR_string__Object__to_s]))(var85) /* to_s on <var85:Array[Object]>*/;
+((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__require_declaration]))(self, var88) /* require_declaration on <self:SeparateCompilerVisitor>*/;
+if (varonce89) {
+var90 = varonce89;
+} else {
+var91 = " = type_";
+var92 = 8;
+var93 = string__NativeString__to_s_with_length(var91, var92);
+var90 = var93;
+varonce89 = var90;
+}
+var94 = ((val* (*)(val*))(var_value->class->vft[COLOR_abstract_compiler__RuntimeVariable__mtype]))(var_value) /* mtype on <var_value:RuntimeVariable>*/;
+var95 = ((val* (*)(val*))(var94->class->vft[COLOR_abstract_compiler__MType__c_name]))(var94) /* c_name on <var94:MType>*/;
+if (varonce96) {
+var97 = varonce96;
+} else {
+var98 = ".name;";
+var99 = 6;
+var100 = string__NativeString__to_s_with_length(var98, var99);
+var97 = var100;
+varonce96 = var97;
+}
+var101 = NEW_array__Array(&type_array__Arraykernel__Object);
+{ /* var101 = array_instance Array[Object] */
+var102 = 4;
+var103 = NEW_array__NativeArray(var102, &type_array__NativeArraykernel__Object);
+((struct instance_array__NativeArray*)var103)->values[0] = (val*) var_res;
+((struct instance_array__NativeArray*)var103)->values[1] = (val*) var90;
+((struct instance_array__NativeArray*)var103)->values[2] = (val*) var95;
+((struct instance_array__NativeArray*)var103)->values[3] = (val*) var97;
+((void (*)(val*, val*, long))(var101->class->vft[COLOR_array__Array__with_native]))(var101, var103, var102) /* with_native on <var101:Array[Object]>*/;
+}
+var104 = ((val* (*)(val*))(var101->class->vft[COLOR_string__Object__to_s]))(var101) /* to_s on <var101:Array[Object]>*/;
+((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var104) /* add on <self:SeparateCompilerVisitor>*/;
 }
-var73 = ((val* (*)(val*))(var70->class->vft[COLOR_string__Object__to_s]))(var70) /* to_s on <var70:Array[Object]>*/;
-((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var73) /* add on <self:SeparateCompilerVisitor>*/;
 }
 var = var_res;
 goto RET_LABEL;
@@ -8008,7 +8005,6 @@ var47 = NEW_array__NativeArray(var46, &type_array__NativeArraykernel__Object);
 ((struct instance_array__NativeArray*)var47)->values[4] = (val*) var_value2;
 ((struct instance_array__NativeArray*)var47)->values[5] = (val*) var41;
 ((void (*)(val*, val*, long))(var45->class->vft[COLOR_array__Array__with_native]))(var45, var47, var46) /* with_native on <var45:Array[Object]>*/;
-CHECK_NEW_array__Array(var45);
 }
 var48 = ((val* (*)(val*))(var45->class->vft[COLOR_string__Object__to_s]))(var45) /* to_s on <var45:Array[Object]>*/;
 ((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var48) /* add on <self:SeparateCompilerVisitor>*/;
@@ -8066,7 +8062,6 @@ var76 = NEW_array__NativeArray(var75, &type_array__NativeArraykernel__Object);
 ((struct instance_array__NativeArray*)var76)->values[4] = (val*) var68;
 ((struct instance_array__NativeArray*)var76)->values[5] = (val*) var70;
 ((void (*)(val*, val*, long))(var74->class->vft[COLOR_array__Array__with_native]))(var74, var76, var75) /* with_native on <var74:Array[Object]>*/;
-CHECK_NEW_array__Array(var74);
 }
 var77 = ((val* (*)(val*))(var74->class->vft[COLOR_string__Object__to_s]))(var74) /* to_s on <var74:Array[Object]>*/;
 ((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var77) /* add on <self:SeparateCompilerVisitor>*/;
@@ -8083,8 +8078,8 @@ var79 = var78->type->type_table[cltype] == idtype;
 if (!var79) {
 var_class_name = var78 == NULL ? "null" : var78->type->name;
 fprintf(stderr, "Runtime error: Cast failed. Expected `%s`, got `%s`", "MClassType", var_class_name);
-fprintf(stderr, " (%s:%d)\n", "src/separate_compiler.nit", 1429);
-exit(1);
+fprintf(stderr, " (%s:%d)\n", "src/separate_compiler.nit", 1485);
+show_backtrace(1);
 }
 var_mtype1 = var78;
 if (varonce80) {
@@ -8104,7 +8099,6 @@ var88 = NEW_array__NativeArray(var87, &type_array__NativeArraykernel__Object);
 ((struct instance_array__NativeArray*)var88)->values[0] = (val*) var81;
 ((struct instance_array__NativeArray*)var88)->values[1] = (val*) var85;
 ((void (*)(val*, val*, long))(var86->class->vft[COLOR_array__Array__with_native]))(var86, var88, var87) /* with_native on <var86:Array[Object]>*/;
-CHECK_NEW_array__Array(var86);
 }
 var89 = ((val* (*)(val*))(var86->class->vft[COLOR_string__Object__to_s]))(var86) /* to_s on <var86:Array[Object]>*/;
 ((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__require_declaration]))(self, var89) /* require_declaration on <self:SeparateCompilerVisitor>*/;
@@ -8158,7 +8152,6 @@ var113 = NEW_array__NativeArray(var112, &type_array__NativeArraykernel__Object);
 ((struct instance_array__NativeArray*)var113)->values[6] = (val*) var105;
 ((struct instance_array__NativeArray*)var113)->values[7] = (val*) var107;
 ((void (*)(val*, val*, long))(var111->class->vft[COLOR_array__Array__with_native]))(var111, var113, var112) /* with_native on <var111:Array[Object]>*/;
-CHECK_NEW_array__Array(var111);
 }
 var114 = ((val* (*)(val*))(var111->class->vft[COLOR_string__Object__to_s]))(var111) /* to_s on <var111:Array[Object]>*/;
 ((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var114) /* add on <self:SeparateCompilerVisitor>*/;
@@ -8188,7 +8181,6 @@ var127 = NEW_array__NativeArray(var126, &type_array__NativeArraykernel__Object);
 ((struct instance_array__NativeArray*)var127)->values[1] = (val*) var_res;
 ((struct instance_array__NativeArray*)var127)->values[2] = (val*) var121;
 ((void (*)(val*, val*, long))(var125->class->vft[COLOR_array__Array__with_native]))(var125, var127, var126) /* with_native on <var125:Array[Object]>*/;
-CHECK_NEW_array__Array(var125);
 }
 var128 = ((val* (*)(val*))(var125->class->vft[COLOR_string__Object__to_s]))(var125) /* to_s on <var125:Array[Object]>*/;
 ((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var128) /* add on <self:SeparateCompilerVisitor>*/;
@@ -8232,7 +8224,6 @@ var148 = NEW_array__NativeArray(var147, &type_array__NativeArraykernel__Object);
 ((struct instance_array__NativeArray*)var148)->values[4] = (val*) var_value1;
 ((struct instance_array__NativeArray*)var148)->values[5] = (val*) var142;
 ((void (*)(val*, val*, long))(var146->class->vft[COLOR_array__Array__with_native]))(var146, var148, var147) /* with_native on <var146:Array[Object]>*/;
-CHECK_NEW_array__Array(var146);
 }
 var149 = ((val* (*)(val*))(var146->class->vft[COLOR_string__Object__to_s]))(var146) /* to_s on <var146:Array[Object]>*/;
 ((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var149) /* add on <self:SeparateCompilerVisitor>*/;
@@ -8256,7 +8247,6 @@ var155 = 1;
 var_maybe_null = var155;
 var156 = NEW_array__Array(&type_array__Arraystring__String);
 ((void (*)(val*))(var156->class->vft[COLOR_array__Array__init]))(var156) /* init on <var156:Array[String]>*/;
-CHECK_NEW_array__Array(var156);
 var_test = var156;
 var157 = ((val* (*)(val*))(var_value1->class->vft[COLOR_abstract_compiler__RuntimeVariable__mcasttype]))(var_value1) /* mcasttype on <var_value1:RuntimeVariable>*/;
 var_t1 = var157;
@@ -8285,7 +8275,6 @@ var168 = NEW_array__NativeArray(var167, &type_array__NativeArraykernel__Object);
 ((struct instance_array__NativeArray*)var168)->values[0] = (val*) var_value1;
 ((struct instance_array__NativeArray*)var168)->values[1] = (val*) var162;
 ((void (*)(val*, val*, long))(var166->class->vft[COLOR_array__Array__with_native]))(var166, var168, var167) /* with_native on <var166:Array[Object]>*/;
-CHECK_NEW_array__Array(var166);
 }
 var169 = ((val* (*)(val*))(var166->class->vft[COLOR_string__Object__to_s]))(var166) /* to_s on <var166:Array[Object]>*/;
 ((void (*)(val*, val*))(var_test->class->vft[COLOR_abstract_collection__SimpleCollection__add]))(var_test, var169) /* add on <var_test:Array[String]>*/;
@@ -8322,7 +8311,6 @@ var183 = NEW_array__NativeArray(var182, &type_array__NativeArraykernel__Object);
 ((struct instance_array__NativeArray*)var183)->values[0] = (val*) var_value2;
 ((struct instance_array__NativeArray*)var183)->values[1] = (val*) var177;
 ((void (*)(val*, val*, long))(var181->class->vft[COLOR_array__Array__with_native]))(var181, var183, var182) /* with_native on <var181:Array[Object]>*/;
-CHECK_NEW_array__Array(var181);
 }
 var184 = ((val* (*)(val*))(var181->class->vft[COLOR_string__Object__to_s]))(var181) /* to_s on <var181:Array[Object]>*/;
 ((void (*)(val*, val*))(var_test->class->vft[COLOR_abstract_collection__SimpleCollection__add]))(var_test, var184) /* add on <var_test:Array[String]>*/;
@@ -8394,7 +8382,6 @@ var217 = NEW_array__NativeArray(var216, &type_array__NativeArraykernel__Object);
 ((struct instance_array__NativeArray*)var217)->values[2] = (val*) var_value2;
 ((struct instance_array__NativeArray*)var217)->values[3] = (val*) var211;
 ((void (*)(val*, val*, long))(var215->class->vft[COLOR_array__Array__with_native]))(var215, var217, var216) /* with_native on <var215:Array[Object]>*/;
-CHECK_NEW_array__Array(var215);
 }
 var218 = ((val* (*)(val*))(var215->class->vft[COLOR_string__Object__to_s]))(var215) /* to_s on <var215:Array[Object]>*/;
 ((void (*)(val*, val*))(var_test->class->vft[COLOR_abstract_collection__SimpleCollection__add]))(var_test, var218) /* add on <var_test:Array[String]>*/;
@@ -8447,7 +8434,6 @@ var240 = NEW_array__NativeArray(var239, &type_array__NativeArraykernel__Object);
 ((struct instance_array__NativeArray*)var240)->values[2] = (val*) var_value2;
 ((struct instance_array__NativeArray*)var240)->values[3] = (val*) var234;
 ((void (*)(val*, val*, long))(var238->class->vft[COLOR_array__Array__with_native]))(var238, var240, var239) /* with_native on <var238:Array[Object]>*/;
-CHECK_NEW_array__Array(var238);
 }
 var241 = ((val* (*)(val*))(var238->class->vft[COLOR_string__Object__to_s]))(var238) /* to_s on <var238:Array[Object]>*/;
 ((void (*)(val*, val*))(var_test->class->vft[COLOR_abstract_collection__SimpleCollection__add]))(var_test, var241) /* add on <var_test:Array[String]>*/;
@@ -8522,7 +8508,6 @@ var271 = NEW_array__NativeArray(var270, &type_array__NativeArraykernel__Object);
 ((struct instance_array__NativeArray*)var271)->values[8] = (val*) var_t2;
 ((struct instance_array__NativeArray*)var271)->values[9] = (val*) var265;
 ((void (*)(val*, val*, long))(var269->class->vft[COLOR_array__Array__with_native]))(var269, var271, var270) /* with_native on <var269:Array[Object]>*/;
-CHECK_NEW_array__Array(var269);
 }
 var272 = ((val* (*)(val*))(var269->class->vft[COLOR_string__Object__to_s]))(var269) /* to_s on <var269:Array[Object]>*/;
 ((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var272) /* add on <self:SeparateCompilerVisitor>*/;
@@ -8567,7 +8552,6 @@ var290 = NEW_array__NativeArray(var289, &type_array__NativeArraykernel__Object);
 ((struct instance_array__NativeArray*)var290)->values[4] = (val*) var_t2;
 ((struct instance_array__NativeArray*)var290)->values[5] = (val*) var284;
 ((void (*)(val*, val*, long))(var288->class->vft[COLOR_array__Array__with_native]))(var288, var290, var289) /* with_native on <var288:Array[Object]>*/;
-CHECK_NEW_array__Array(var288);
 }
 var291 = ((val* (*)(val*))(var288->class->vft[COLOR_string__Object__to_s]))(var288) /* to_s on <var288:Array[Object]>*/;
 ((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var291) /* add on <self:SeparateCompilerVisitor>*/;
@@ -8592,7 +8576,7 @@ var298 = string__NativeString__to_s_with_length(var296, var297);
 var295 = var298;
 varonce294 = var295;
 }
-var299 = ((val* (*)(val*))(var_primitive->class->vft[COLOR_abstract_compiler__MType__c_name]))(var_primitive) /* c_name on <var_primitive:nullable Object(MType)>*/;
+var299 = ((val* (*)(val*))(var_primitive->class->vft[COLOR_separate_compiler__MType__c_instance_name]))(var_primitive) /* c_instance_name on <var_primitive:nullable Object(MType)>*/;
 if (varonce300) {
 var301 = varonce300;
 } else {
@@ -8611,7 +8595,7 @@ var309 = string__NativeString__to_s_with_length(var307, var308);
 var306 = var309;
 varonce305 = var306;
 }
-var310 = ((val* (*)(val*))(var_primitive->class->vft[COLOR_abstract_compiler__MType__c_name]))(var_primitive) /* c_name on <var_primitive:nullable Object(MType)>*/;
+var310 = ((val* (*)(val*))(var_primitive->class->vft[COLOR_separate_compiler__MType__c_instance_name]))(var_primitive) /* c_instance_name on <var_primitive:nullable Object(MType)>*/;
 if (varonce311) {
 var312 = varonce311;
 } else {
@@ -8644,7 +8628,6 @@ var323 = NEW_array__NativeArray(var322, &type_array__NativeArraykernel__Object);
 ((struct instance_array__NativeArray*)var323)->values[7] = (val*) var_value2;
 ((struct instance_array__NativeArray*)var323)->values[8] = (val*) var317;
 ((void (*)(val*, val*, long))(var321->class->vft[COLOR_array__Array__with_native]))(var321, var323, var322) /* with_native on <var321:Array[Object]>*/;
-CHECK_NEW_array__Array(var321);
 }
 var324 = ((val* (*)(val*))(var321->class->vft[COLOR_string__Object__to_s]))(var321) /* to_s on <var321:Array[Object]>*/;
 ((void (*)(val*, val*))(var_test->class->vft[COLOR_abstract_collection__SimpleCollection__add]))(var_test, var324) /* add on <var_test:Array[String]>*/;
@@ -8685,13 +8668,11 @@ var341 = NEW_array__NativeArray(var340, &type_array__NativeArraykernel__Object);
 ((struct instance_array__NativeArray*)var341)->values[2] = (val*) var_value2;
 ((struct instance_array__NativeArray*)var341)->values[3] = (val*) var335;
 ((void (*)(val*, val*, long))(var339->class->vft[COLOR_array__Array__with_native]))(var339, var341, var340) /* with_native on <var339:Array[Object]>*/;
-CHECK_NEW_array__Array(var339);
 }
 var342 = ((val* (*)(val*))(var339->class->vft[COLOR_string__Object__to_s]))(var339) /* to_s on <var339:Array[Object]>*/;
 ((void (*)(val*, val*))(var_test->class->vft[COLOR_abstract_collection__SimpleCollection__add]))(var_test, var342) /* add on <var_test:Array[String]>*/;
 var343 = NEW_array__Array(&type_array__Arraystring__String);
 ((void (*)(val*))(var343->class->vft[COLOR_array__Array__init]))(var343) /* init on <var343:Array[String]>*/;
-CHECK_NEW_array__Array(var343);
 var_s = var343;
 var344 = ((val* (*)(val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__compiler]))(self) /* compiler on <self:SeparateCompilerVisitor>*/;
 var345 = ((val* (*)(val*))(var344->class->vft[COLOR_separate_compiler__SeparateCompiler__box_kinds]))(var344) /* box_kinds on <var344:AbstractCompiler(SeparateCompiler)>*/;
@@ -8731,7 +8712,7 @@ var365 = string__NativeString__to_s_with_length(var363, var364);
 var362 = var365;
 varonce361 = var362;
 }
-var366 = ((val* (*)(val*))(var_t->class->vft[COLOR_abstract_compiler__MClass__c_name]))(var_t) /* c_name on <var_t:MClass>*/;
+var366 = ((val* (*)(val*))(var_t->class->vft[COLOR_separate_compiler__MClass__c_instance_name]))(var_t) /* c_instance_name on <var_t:MClass>*/;
 if (varonce367) {
 var368 = varonce367;
 } else {
@@ -8750,7 +8731,7 @@ var376 = string__NativeString__to_s_with_length(var374, var375);
 var373 = var376;
 varonce372 = var373;
 }
-var377 = ((val* (*)(val*))(var_t->class->vft[COLOR_abstract_compiler__MClass__c_name]))(var_t) /* c_name on <var_t:MClass>*/;
+var377 = ((val* (*)(val*))(var_t->class->vft[COLOR_separate_compiler__MClass__c_instance_name]))(var_t) /* c_instance_name on <var_t:MClass>*/;
 if (varonce378) {
 var379 = varonce378;
 } else {
@@ -8788,7 +8769,6 @@ var391 = BOX_kernel__Int(var_v); /* autobox from Int to Object */
 ((struct instance_array__NativeArray*)var390)->values[11] = (val*) var_value2;
 ((struct instance_array__NativeArray*)var390)->values[12] = (val*) var384;
 ((void (*)(val*, val*, long))(var388->class->vft[COLOR_array__Array__with_native]))(var388, var390, var389) /* with_native on <var388:Array[Object]>*/;
-CHECK_NEW_array__Array(var388);
 }
 var392 = ((val* (*)(val*))(var388->class->vft[COLOR_string__Object__to_s]))(var388) /* to_s on <var388:Array[Object]>*/;
 ((void (*)(val*, val*))(var_s->class->vft[COLOR_abstract_collection__SimpleCollection__add]))(var_s, var392) /* add on <var_s:Array[String]>*/;
@@ -8832,7 +8812,6 @@ var411 = NEW_array__NativeArray(var410, &type_array__NativeArraykernel__Object);
 ((struct instance_array__NativeArray*)var411)->values[1] = (val*) var403;
 ((struct instance_array__NativeArray*)var411)->values[2] = (val*) var405;
 ((void (*)(val*, val*, long))(var409->class->vft[COLOR_array__Array__with_native]))(var409, var411, var410) /* with_native on <var409:Array[Object]>*/;
-CHECK_NEW_array__Array(var409);
 }
 var412 = ((val* (*)(val*))(var409->class->vft[COLOR_string__Object__to_s]))(var409) /* to_s on <var409:Array[Object]>*/;
 ((void (*)(val*, val*))(var_test->class->vft[COLOR_abstract_collection__SimpleCollection__add]))(var_test, var412) /* add on <var_test:Array[String]>*/;
@@ -8875,7 +8854,6 @@ var430 = NEW_array__NativeArray(var429, &type_array__NativeArraykernel__Object);
 ((struct instance_array__NativeArray*)var430)->values[4] = (val*) var_value2;
 ((struct instance_array__NativeArray*)var430)->values[5] = (val*) var424;
 ((void (*)(val*, val*, long))(var428->class->vft[COLOR_array__Array__with_native]))(var428, var430, var429) /* with_native on <var428:Array[Object]>*/;
-CHECK_NEW_array__Array(var428);
 }
 var431 = ((val* (*)(val*))(var428->class->vft[COLOR_string__Object__to_s]))(var428) /* to_s on <var428:Array[Object]>*/;
 ((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var431) /* add on <self:SeparateCompilerVisitor>*/;
@@ -8942,7 +8920,6 @@ var460 = NEW_array__NativeArray(var459, &type_array__NativeArraykernel__Object);
 ((struct instance_array__NativeArray*)var460)->values[6] = (val*) var452;
 ((struct instance_array__NativeArray*)var460)->values[7] = (val*) var454;
 ((void (*)(val*, val*, long))(var458->class->vft[COLOR_array__Array__with_native]))(var458, var460, var459) /* with_native on <var458:Array[Object]>*/;
-CHECK_NEW_array__Array(var458);
 }
 var461 = ((val* (*)(val*))(var458->class->vft[COLOR_string__Object__to_s]))(var458) /* to_s on <var458:Array[Object]>*/;
 ((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var461) /* add on <self:SeparateCompilerVisitor>*/;
@@ -9251,7 +9228,6 @@ var13 = 1;
 var14 = NEW_array__NativeArray(var13, &type_array__NativeArraymodel__MType);
 ((struct instance_array__NativeArray*)var14)->values[0] = (val*) var_elttype;
 ((void (*)(val*, val*, long))(var12->class->vft[COLOR_array__Array__with_native]))(var12, var14, var13) /* with_native on <var12:Array[MType]>*/;
-CHECK_NEW_array__Array(var12);
 }
 var15 = ((val* (*)(val*, val*))(var_arrayclass->class->vft[COLOR_model__MClass__get_mtype]))(var_arrayclass, var12) /* get_mtype on <var_arrayclass:MClass>*/;
 var_arraytype = var15;
@@ -9294,7 +9270,6 @@ var34 = NEW_array__NativeArray(var33, &type_array__NativeArraykernel__Object);
 ((struct instance_array__NativeArray*)var34)->values[3] = (val*) var_elttype;
 ((struct instance_array__NativeArray*)var34)->values[4] = (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);
 }
 var35 = ((val* (*)(val*))(var32->class->vft[COLOR_string__Object__to_s]))(var32) /* to_s on <var32:Array[Object]>*/;
 ((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var35) /* add on <self:SeparateCompilerVisitor>*/;
@@ -9309,7 +9284,6 @@ var41 = ((long (*)(val*))(var_array->class->vft[COLOR_abstract_collection__Colle
 var42 = BOX_kernel__Int(var40); /* autobox from Int to Discrete */
 var43 = BOX_kernel__Int(var41); /* autobox from Int to Discrete */
 ((void (*)(val*, val*, val*))(var39->class->vft[COLOR_range__Range__without_last]))(var39, var42, var43) /* without_last on <var39:Range[Int]>*/;
-CHECK_NEW_range__Range(var39);
 var44 = ((val* (*)(val*))(var39->class->vft[COLOR_abstract_collection__Collection__iterator]))(var39) /* iterator on <var39:Range[Int]>*/;
 for(;;) {
 var45 = ((short int (*)(val*))(var44->class->vft[COLOR_abstract_collection__Iterator__is_ok]))(var44) /* is_ok on <var44:Iterator[nullable Object]>*/;
@@ -9382,7 +9356,6 @@ var80 = BOX_kernel__Int(var_i); /* autobox from Int to Object */
 ((struct instance_array__NativeArray*)var79)->values[7] = (val*) var_r;
 ((struct instance_array__NativeArray*)var79)->values[8] = (val*) var73;
 ((void (*)(val*, val*, long))(var77->class->vft[COLOR_array__Array__with_native]))(var77, var79, var78) /* with_native on <var77:Array[Object]>*/;
-CHECK_NEW_array__Array(var77);
 }
 var81 = ((val* (*)(val*))(var77->class->vft[COLOR_string__Object__to_s]))(var77) /* to_s on <var77:Array[Object]>*/;
 ((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var81) /* add on <self:SeparateCompilerVisitor>*/;
@@ -9410,11 +9383,9 @@ var92 = NEW_array__NativeArray(var91, &type_array__NativeArrayabstract_compiler_
 ((struct instance_array__NativeArray*)var92)->values[1] = (val*) var_nat;
 ((struct instance_array__NativeArray*)var92)->values[2] = (val*) var_length;
 ((void (*)(val*, val*, long))(var90->class->vft[COLOR_array__Array__with_native]))(var90, var92, var91) /* with_native on <var90:Array[RuntimeVariable]>*/;
-CHECK_NEW_array__Array(var90);
 }
 var93 = ((val* (*)(val*, val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__send]))(self, var89, var90) /* send on <self:SeparateCompilerVisitor>*/;
 var93;
-((void (*)(val*, val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__check_init_instance]))(self, var_res, var_arraytype) /* check_init_instance on <self:SeparateCompilerVisitor>*/;
 if (varonce94) {
 var95 = varonce94;
 } else {
@@ -9622,7 +9593,6 @@ var7 = 1;
 var8 = NEW_array__NativeArray(var7, &type_array__NativeArraymodel__MType);
 ((struct instance_array__NativeArray*)var8)->values[0] = (val*) var_elttype;
 ((void (*)(val*, val*, long))(var6->class->vft[COLOR_array__Array__with_native]))(var6, var8, var7) /* with_native on <var6:Array[MType]>*/;
-CHECK_NEW_array__Array(var6);
 }
 var9 = ((val* (*)(val*, val*))(var5->class->vft[COLOR_model__MClass__get_mtype]))(var5, var6) /* get_mtype on <var5:MClass>*/;
 var_mtype = var9;
@@ -9644,7 +9614,6 @@ var19 = NEW_array__NativeArray(var18, &type_array__NativeArraykernel__Object);
 ((struct instance_array__NativeArray*)var19)->values[0] = (val*) var11;
 ((struct instance_array__NativeArray*)var19)->values[1] = (val*) var16;
 ((void (*)(val*, val*, long))(var17->class->vft[COLOR_array__Array__with_native]))(var17, var19, var18) /* with_native on <var17:Array[Object]>*/;
-CHECK_NEW_array__Array(var17);
 }
 var20 = ((val* (*)(val*))(var17->class->vft[COLOR_string__Object__to_s]))(var17) /* to_s on <var17:Array[Object]>*/;
 ((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__require_declaration]))(self, var20) /* require_declaration on <self:SeparateCompilerVisitor>*/;
@@ -9658,18 +9627,19 @@ var21 = var_mtype->type->type_table[cltype] == idtype;
 }
 if (!var21) {
 fprintf(stderr, "Runtime error: %s", "Assert failed");
-fprintf(stderr, " (%s:%d)\n", "src/separate_compiler.nit", 1543);
-exit(1);
+fprintf(stderr, " (%s:%d)\n", "src/separate_compiler.nit", 1598);
+show_backtrace(1);
 }
 var22 = ((val* (*)(val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__compiler]))(self) /* compiler on <self:SeparateCompilerVisitor>*/;
 var_compiler = var22;
 var23 = ((short int (*)(val*))(var_mtype->class->vft[COLOR_model__MType__need_anchor]))(var_mtype) /* need_anchor on <var_mtype:MClassType(MGenericType)>*/;
 if (var23){
+((void (*)(val*, val*))(self->class->vft[COLOR_separate_compiler__SeparateCompilerVisitor__hardening_live_open_type]))(self, var_mtype) /* hardening_live_open_type on <self:SeparateCompilerVisitor>*/;
 var24 = ((val* (*)(val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__frame]))(self) /* frame on <self:SeparateCompilerVisitor>*/;
 if (var24 == NULL) {
-fprintf(stderr, "Runtime error: %s", "Reciever is null");
-fprintf(stderr, " (%s:%d)\n", "src/separate_compiler.nit", 1546);
-exit(1);
+fprintf(stderr, "Runtime error: %s", "Receiver is null");
+fprintf(stderr, " (%s:%d)\n", "src/separate_compiler.nit", 1602);
+show_backtrace(1);
 } else {
 var25 = ((val* (*)(val*))(var24->class->vft[COLOR_abstract_compiler__Frame__mpropdef]))(var24) /* mpropdef on <var24:nullable Frame>*/;
 }
@@ -9677,9 +9647,9 @@ var26 = ((val* (*)(val*))(var25->class->vft[COLOR_model__MPropDef__mclassdef]))(
 ((void (*)(val*, val*, val*))(self->class->vft[COLOR_separate_compiler__SeparateCompilerVisitor__link_unresolved_type]))(self, var26, var_mtype) /* link_unresolved_type on <self:SeparateCompilerVisitor>*/;
 var27 = ((val* (*)(val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__frame]))(self) /* frame on <self:SeparateCompilerVisitor>*/;
 if (var27 == NULL) {
-fprintf(stderr, "Runtime error: %s", "Reciever is null");
-fprintf(stderr, " (%s:%d)\n", "src/separate_compiler.nit", 1547);
-exit(1);
+fprintf(stderr, "Runtime error: %s", "Receiver is null");
+fprintf(stderr, " (%s:%d)\n", "src/separate_compiler.nit", 1603);
+show_backtrace(1);
 } else {
 var28 = ((val* (*)(val*))(var27->class->vft[COLOR_abstract_compiler__Frame__arguments]))(var27) /* arguments on <var27:nullable Frame>*/;
 }
@@ -9779,7 +9749,6 @@ var78 = NEW_array__NativeArray(var77, &type_array__NativeArraykernel__Object);
 ((struct instance_array__NativeArray*)var78)->values[9] = (val*) var70;
 ((struct instance_array__NativeArray*)var78)->values[10] = (val*) var72;
 ((void (*)(val*, val*, long))(var76->class->vft[COLOR_array__Array__with_native]))(var76, var78, var77) /* with_native on <var76:Array[Object]>*/;
-CHECK_NEW_array__Array(var76);
 }
 var79 = ((val* (*)(val*))(var76->class->vft[COLOR_string__Object__to_s]))(var76) /* to_s on <var76:Array[Object]>*/;
 var80 = ((val* (*)(val*, val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__new_expr]))(self, var79, var_mtype) /* new_expr on <self:SeparateCompilerVisitor>*/;
@@ -9848,7 +9817,6 @@ var111 = NEW_array__NativeArray(var110, &type_array__NativeArraykernel__Object);
 ((struct instance_array__NativeArray*)var111)->values[7] = (val*) var103;
 ((struct instance_array__NativeArray*)var111)->values[8] = (val*) var105;
 ((void (*)(val*, val*, long))(var109->class->vft[COLOR_array__Array__with_native]))(var109, var111, var110) /* with_native on <var109:Array[Object]>*/;
-CHECK_NEW_array__Array(var109);
 }
 var112 = ((val* (*)(val*))(var109->class->vft[COLOR_string__Object__to_s]))(var109) /* to_s on <var109:Array[Object]>*/;
 var113 = ((val* (*)(val*, val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__new_expr]))(self, var112, var_mtype) /* new_expr on <self:SeparateCompilerVisitor>*/;
@@ -9876,7 +9844,6 @@ var123 = NEW_array__NativeArray(var122, &type_array__NativeArraykernel__Object);
 ((struct instance_array__NativeArray*)var123)->values[0] = (val*) var116;
 ((struct instance_array__NativeArray*)var123)->values[1] = (val*) var120;
 ((void (*)(val*, val*, long))(var121->class->vft[COLOR_array__Array__with_native]))(var121, var123, var122) /* with_native on <var121:Array[Object]>*/;
-CHECK_NEW_array__Array(var121);
 }
 var124 = ((val* (*)(val*))(var121->class->vft[COLOR_string__Object__to_s]))(var121) /* to_s on <var121:Array[Object]>*/;
 ((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__require_declaration]))(self, var124) /* require_declaration on <self:SeparateCompilerVisitor>*/;
@@ -9931,7 +9898,6 @@ var150 = NEW_array__NativeArray(var149, &type_array__NativeArraykernel__Object);
 ((struct instance_array__NativeArray*)var150)->values[5] = (val*) var142;
 ((struct instance_array__NativeArray*)var150)->values[6] = (val*) var144;
 ((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]>*/;
 var152 = ((val* (*)(val*, val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__new_expr]))(self, var151, var_mtype) /* new_expr on <self:SeparateCompilerVisitor>*/;