X-Git-Url: http://nitlanguage.org diff --git a/c_src/separate_compiler.sep.2.c b/c_src/separate_compiler.sep.2.c index 402b281..8d5f525 100644 --- a/c_src/separate_compiler.sep.2.c +++ b/c_src/separate_compiler.sep.2.c @@ -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 */; -var2 = ((short int (*)(val*, val*))(var1->class->vft[COLOR_kernel__Object___61d_61d]))(var1, var_mtype) /* == on */; -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 */; -var5 = ((val* (*)(val*))(var4->class->vft[COLOR_abstract_compiler__MType__ctype]))(var4) /* ctype on */; -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 */; -var_ = var10; -if (var10){ -var11 = ((val* (*)(val*))(var_mtype->class->vft[COLOR_abstract_compiler__MType__ctype]))(var_mtype) /* ctype on */; -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 */; -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 */; -var19 = ((val* (*)(val*))(var18->class->vft[COLOR_abstract_compiler__MType__ctype]))(var18) /* ctype on */; -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 */; -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 */; -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 */; -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 */; -CHECK_NEW_array__Array(var53); -} -var56 = ((val* (*)(val*))(var53->class->vft[COLOR_string__Object__to_s]))(var53) /* to_s on */; -var57 = ((val* (*)(val*, val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__new_expr]))(self, var56, var_mtype) /* new_expr on */; -var = var57; -goto RET_LABEL; -} else { -var58 = ((val* (*)(val*))(var_mtype->class->vft[COLOR_abstract_compiler__MType__ctype]))(var_mtype) /* ctype on */; -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 */; -if (var64){ -var65 = ((val* (*)(val*))(var_value->class->vft[COLOR_abstract_compiler__RuntimeVariable__mtype]))(var_value) /* mtype on */; -/* 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 */; -var_res = var67; -var68 = ((val* (*)(val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__compiler]))(self) /* compiler on */; -var69 = ((val* (*)(val*))(var68->class->vft[COLOR_separate_compiler__SeparateCompiler__runtime_type_analysis]))(var68) /* runtime_type_analysis on */; -var70 = ((val* (*)(val*))(var69->class->vft[COLOR_rapid_type_analysis__RapidTypeAnalysis__live_types]))(var69) /* live_types on */; -var71 = ((short int (*)(val*, val*))(var70->class->vft[COLOR_abstract_collection__Collection__has]))(var70, var_valtype) /* has on */; -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 */; -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 */; -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 */; -CHECK_NEW_array__Array(var95); -} -var98 = ((val* (*)(val*))(var95->class->vft[COLOR_string__Object__to_s]))(var95) /* to_s on */; -((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var98) /* add on */; -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 */; -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 */; -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 */; -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 */; -CHECK_NEW_array__Array(var131); -} -var134 = ((val* (*)(val*))(var131->class->vft[COLOR_string__Object__to_s]))(var131) /* to_s on */; -((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var134) /* add on */; -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 */; -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 */; -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 */; -CHECK_NEW_array__Array(var158); -} -var161 = ((val* (*)(val*))(var158->class->vft[COLOR_string__Object__to_s]))(var158) /* to_s on */; -((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var161) /* add on */; -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 */; -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 */; -CHECK_NEW_array__Array(var178); -} -var181 = ((val* (*)(val*))(var178->class->vft[COLOR_string__Object__to_s]))(var178) /* to_s on */; -((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var181) /* add on */; -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 */; var2 = ((val* (*)(val*))(var1->class->vft[COLOR_abstract_compiler__MType__ctype]))(var1) /* ctype on */; @@ -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 */; -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 */; -var27 = ((val* (*)(val*))(var26->class->vft[COLOR_abstract_compiler__MType__c_name]))(var26) /* c_name on */; -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 */; -CHECK_NEW_array__Array(var28); -} -var31 = ((val* (*)(val*))(var28->class->vft[COLOR_string__Object__to_s]))(var28) /* to_s on */; -((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__require_declaration]))(self, var31) /* require_declaration on */; -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 */; -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 */; +var22 = ((val* (*)(val*))(var21->class->vft[COLOR_separate_compiler__SeparateCompiler__undead_types]))(var21) /* undead_types on */; +var23 = ((val* (*)(val*))(var_value->class->vft[COLOR_abstract_compiler__RuntimeVariable__mtype]))(var_value) /* mtype on */; +((void (*)(val*, val*))(var22->class->vft[COLOR_abstract_collection__SimpleCollection__add]))(var22, var23) /* add on */; +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 */; -var40 = ((val* (*)(val*))(var_value->class->vft[COLOR_abstract_compiler__RuntimeVariable__mtype]))(var_value) /* mtype on */; -var41 = ((val* (*)(val*))(var40->class->vft[COLOR_abstract_compiler__MType__c_name]))(var40) /* c_name on */; -((void (*)(val*, val*))(var_34->class->vft[COLOR_abstract_collection__SimpleCollection__add]))(var_34, var41) /* add on */; -if (varonce42) { -var43 = varonce42; +var29 = ((val* (*)(val*))(var_value->class->vft[COLOR_abstract_compiler__RuntimeVariable__mtype]))(var_value) /* mtype on */; +var30 = ((val* (*)(val*))(var29->class->vft[COLOR_abstract_compiler__MType__c_name]))(var29) /* c_name on */; +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 */; +} +var34 = ((val* (*)(val*))(var31->class->vft[COLOR_string__Object__to_s]))(var31) /* to_s on */; +((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__require_declaration]))(self, var34) /* require_declaration on */; +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 */; +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 */; -var47 = ((val* (*)(val*))(var_34->class->vft[COLOR_string__Object__to_s]))(var_34) /* to_s on */; -var = var47; +((void (*)(val*, val*))(var_37->class->vft[COLOR_abstract_collection__SimpleCollection__add]))(var_37, var39) /* add on */; +var43 = ((val* (*)(val*))(var_value->class->vft[COLOR_abstract_compiler__RuntimeVariable__mtype]))(var_value) /* mtype on */; +var44 = ((val* (*)(val*))(var43->class->vft[COLOR_abstract_compiler__MType__c_name]))(var43) /* c_name on */; +((void (*)(val*, val*))(var_37->class->vft[COLOR_abstract_collection__SimpleCollection__add]))(var_37, var44) /* add on */; +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 */; +var50 = ((val* (*)(val*))(var_37->class->vft[COLOR_string__Object__to_s]))(var_37) /* to_s on */; +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 */; @@ -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 */; 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 */; -var4 = ((val* (*)(val*))(var_mmethod->class->vft[COLOR_separate_compiler__MProperty__const_color]))(var_mmethod) /* const_color on */; -var5 = ((val* (*)(val*, val*, val*, val*))(self->class->vft[COLOR_separate_compiler__SeparateCompilerVisitor__table_send]))(self, var_mmethod, var_arguments, var4) /* table_send on */; -var = var5; +var4 = ((val* (*)(val*))(var_arguments->class->vft[COLOR_abstract_collection__Collection__first]))(var_arguments) /* first on */; +var5 = ((val* (*)(val*))(var4->class->vft[COLOR_abstract_compiler__RuntimeVariable__mcasttype]))(var4) /* mcasttype on */; +var6 = ((val* (*)(val*))(var5->class->vft[COLOR_abstract_compiler__MType__ctype]))(var5) /* ctype on */; +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 */; +if (var11){ +var12 = ((val* (*)(val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__compiler]))(self) /* compiler on */; +var13 = ((val* (*)(val*))(var12->class->vft[COLOR_abstract_compiler__AbstractCompiler__mainmodule]))(var12) /* mainmodule on */; +var_m = var13; +var14 = ((val* (*)(val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__compiler]))(self) /* compiler on */; +var15 = ((val* (*)(val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__compiler]))(self) /* compiler on */; +var16 = ((val* (*)(val*))(var15->class->vft[COLOR_abstract_compiler__AbstractCompiler__realmainmodule]))(var15) /* realmainmodule on */; +((void (*)(val*, val*))(var14->class->vft[COLOR_abstract_compiler__AbstractCompiler__mainmodule_61d]))(var14, var16) /* mainmodule= on */; +var17 = ((val* (*)(val*))(var_arguments->class->vft[COLOR_abstract_collection__Collection__first]))(var_arguments) /* first on */; +var18 = ((val* (*)(val*))(var17->class->vft[COLOR_abstract_compiler__RuntimeVariable__mcasttype]))(var17) /* mcasttype on */; +var19 = ((val* (*)(val*, val*, val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__monomorphic_send]))(self, var_mmethod, var18, var_arguments) /* monomorphic_send on */; +var_res = var19; +var20 = ((val* (*)(val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__compiler]))(self) /* compiler on */; +((void (*)(val*, val*))(var20->class->vft[COLOR_abstract_compiler__AbstractCompiler__mainmodule_61d]))(var20, var_m) /* mainmodule= on */; +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 */; +var22 = ((val* (*)(val*, val*, val*, val*))(self->class->vft[COLOR_separate_compiler__SeparateCompilerVisitor__table_send]))(self, var_mmethod, var_arguments, var21) /* table_send on */; +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 */; -var2 = ((val* (*)(val*))(var1->class->vft[COLOR_abstract_compiler__RuntimeVariable__mcasttype]))(var1) /* mcasttype on */; -var3 = ((val* (*)(val*))(var2->class->vft[COLOR_abstract_compiler__MType__ctype]))(var2) /* ctype on */; +var1 = ((long (*)(val*))(var_arguments->class->vft[COLOR_abstract_collection__Collection__length]))(var_arguments) /* length on */; +var2 = ((val* (*)(val*))(var_mmethod->class->vft[COLOR_model__MProperty__intro]))(var_mmethod) /* intro on */; +var3 = ((val* (*)(val*))(var2->class->vft[COLOR_model__MMethodDef__msignature]))(var2) /* msignature on */; +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 */; +} +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 */; -if (var8){ -var9 = ((val* (*)(val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__compiler]))(self) /* compiler on */; -var10 = ((val* (*)(val*))(var9->class->vft[COLOR_abstract_compiler__AbstractCompiler__mainmodule]))(var9) /* mainmodule on */; -var_m = var10; -var11 = ((val* (*)(val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__compiler]))(self) /* compiler on */; -var12 = ((val* (*)(val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__compiler]))(self) /* compiler on */; -var13 = ((val* (*)(val*))(var12->class->vft[COLOR_abstract_compiler__AbstractCompiler__realmainmodule]))(var12) /* realmainmodule on */; -((void (*)(val*, val*))(var11->class->vft[COLOR_abstract_compiler__AbstractCompiler__mainmodule_61d]))(var11, var13) /* mainmodule= on */; -var14 = ((val* (*)(val*))(var_arguments->class->vft[COLOR_abstract_collection__Collection__first]))(var_arguments) /* first on */; -var15 = ((val* (*)(val*))(var14->class->vft[COLOR_abstract_compiler__RuntimeVariable__mcasttype]))(var14) /* mcasttype on */; -var16 = ((val* (*)(val*, val*, val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__monomorphic_send]))(self, var_mmethod, var15, var_arguments) /* monomorphic_send on */; -var_res = var16; -var17 = ((val* (*)(val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__compiler]))(self) /* compiler on */; -((void (*)(val*, val*))(var17->class->vft[COLOR_abstract_compiler__AbstractCompiler__mainmodule_61d]))(var17, var_m) /* mainmodule= on */; -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 */; -var19 = ((val* (*)(val*))(var18->class->vft[COLOR_model__MMethodDef__msignature]))(var18) /* msignature on */; -var20 = ((val* (*)(val*))(var_mmethod->class->vft[COLOR_model__MProperty__intro]))(var_mmethod) /* intro on */; -var21 = ((val* (*)(val*))(var20->class->vft[COLOR_model__MPropDef__mclassdef]))(var20) /* mclassdef on */; -var22 = ((val* (*)(val*))(var21->class->vft[COLOR_model__MClassDef__bound_mtype]))(var21) /* bound_mtype on */; -var23 = ((val* (*)(val*))(var_mmethod->class->vft[COLOR_model__MProperty__intro]))(var_mmethod) /* intro on */; -var24 = ((val* (*)(val*))(var23->class->vft[COLOR_model__MPropDef__mclassdef]))(var23) /* mclassdef on */; -var25 = ((val* (*)(val*))(var24->class->vft[COLOR_model__MClassDef__bound_mtype]))(var24) /* bound_mtype on */; -var26 = ((val* (*)(val*))(var_mmethod->class->vft[COLOR_model__MProperty__intro]))(var_mmethod) /* intro on */; -var27 = ((val* (*)(val*))(var26->class->vft[COLOR_model__MPropDef__mclassdef]))(var26) /* mclassdef on */; -var28 = ((val* (*)(val*))(var27->class->vft[COLOR_model__MClassDef__mmodule]))(var27) /* mmodule on */; -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 */; -} -var_msignature = var30; -var31 = ((val* (*)(val*))(var_msignature->class->vft[COLOR_model__MSignature__return_mtype]))(var_msignature) /* return_mtype on */; -var_ret = var31; -var32 = ((short int (*)(val*))(var_mmethod->class->vft[COLOR_model__MMethod__is_new]))(var_mmethod) /* is_new on */; -if (var32){ -var33 = ((val* (*)(val*))(var_arguments->class->vft[COLOR_abstract_collection__Collection__first]))(var_arguments) /* first on */; -var34 = ((val* (*)(val*))(var33->class->vft[COLOR_abstract_compiler__RuntimeVariable__mtype]))(var33) /* mtype on */; -var_ret = var34; -var35 = ((val* (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__new_var]))(self, var_ret) /* new_var on */; -var_res36 = var35; +var21 = ((long (*)(val*))(var_arguments->class->vft[COLOR_abstract_collection__Collection__length]))(var_arguments) /* length on */; +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 */; +} +var31 = ((val* (*)(val*))(var27->class->vft[COLOR_string__Object__to_s]))(var27) /* to_s on */; +((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__debug]))(self, var31) /* debug on */; +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 */; +var33 = ((val* (*)(val*))(var32->class->vft[COLOR_model__MMethodDef__msignature]))(var32) /* msignature on */; +var34 = ((val* (*)(val*))(var_mmethod->class->vft[COLOR_model__MProperty__intro]))(var_mmethod) /* intro on */; +var35 = ((val* (*)(val*))(var34->class->vft[COLOR_model__MPropDef__mclassdef]))(var34) /* mclassdef on */; +var36 = ((val* (*)(val*))(var35->class->vft[COLOR_model__MClassDef__bound_mtype]))(var35) /* bound_mtype on */; +var37 = ((val* (*)(val*))(var_mmethod->class->vft[COLOR_model__MProperty__intro]))(var_mmethod) /* intro on */; +var38 = ((val* (*)(val*))(var37->class->vft[COLOR_model__MPropDef__mclassdef]))(var37) /* mclassdef on */; +var39 = ((val* (*)(val*))(var38->class->vft[COLOR_model__MClassDef__bound_mtype]))(var38) /* bound_mtype on */; +var40 = ((val* (*)(val*))(var_mmethod->class->vft[COLOR_model__MProperty__intro]))(var_mmethod) /* intro on */; +var41 = ((val* (*)(val*))(var40->class->vft[COLOR_model__MPropDef__mclassdef]))(var40) /* mclassdef on */; +var42 = ((val* (*)(val*))(var41->class->vft[COLOR_model__MClassDef__mmodule]))(var41) /* mmodule on */; +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 */; +} +var_msignature = var44; +var45 = ((val* (*)(val*))(var_msignature->class->vft[COLOR_model__MSignature__return_mtype]))(var_msignature) /* return_mtype on */; +var_ret = var45; +var46 = ((short int (*)(val*))(var_mmethod->class->vft[COLOR_model__MMethod__is_new]))(var_mmethod) /* is_new on */; +if (var46){ +var47 = ((val* (*)(val*))(var_arguments->class->vft[COLOR_abstract_collection__Collection__first]))(var_arguments) /* first on */; +var48 = ((val* (*)(val*))(var47->class->vft[COLOR_abstract_compiler__RuntimeVariable__mtype]))(var47) /* mtype on */; +var_ret = var48; +var49 = ((val* (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__new_var]))(self, var_ret) /* new_var on */; +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 */; -var_res36 = var40; -} -} -var41 = NEW_string__Buffer(&type_string__Buffer); -((void (*)(val*))(var41->class->vft[COLOR_string__Buffer__init]))(var41) /* init on */; -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 */; -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_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 */; +var_res = var53; +} } -((void (*)(val*, val*))(var_s->class->vft[COLOR_abstract_collection__Sequence__append]))(var_s, var45) /* append on */; -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 */; -CHECK_NEW_array__Array(var49); -} -var52 = ((val* (*)(val*))(var49->class->vft[COLOR_string__Object__to_s]))(var49) /* to_s on */; -((void (*)(val*, val*))(var_ss->class->vft[COLOR_abstract_collection__Sequence__append]))(var_ss, var52) /* append on */; -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 */; -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 */; -CHECK_NEW_range__Range(var53); -var58 = ((val* (*)(val*))(var53->class->vft[COLOR_abstract_collection__Collection__iterator]))(var53) /* iterator on */; +var54 = NEW_string__Buffer(&type_string__Buffer); +((void (*)(val*))(var54->class->vft[COLOR_string__Buffer__init]))(var54) /* init on */; +var_s = var54; +var55 = NEW_string__Buffer(&type_string__Buffer); +((void (*)(val*))(var55->class->vft[COLOR_string__Buffer__init]))(var55) /* init on */; +var_ss = var55; +var56 = ((val* (*)(val*))(var_arguments->class->vft[COLOR_abstract_collection__Collection__first]))(var_arguments) /* first on */; +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 */; +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 */; +} +var65 = ((val* (*)(val*))(var62->class->vft[COLOR_string__Object__to_s]))(var62) /* to_s on */; +((void (*)(val*, val*))(var_ss->class->vft[COLOR_abstract_collection__Sequence__append]))(var_ss, var65) /* append on */; +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 */; +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 */; +var71 = ((val* (*)(val*))(var66->class->vft[COLOR_abstract_collection__Collection__iterator]))(var66) /* iterator on */; for(;;) { -var59 = ((short int (*)(val*))(var58->class->vft[COLOR_abstract_collection__Iterator__is_ok]))(var58) /* is_ok on */; -if(!var59) break; -var60 = ((val* (*)(val*))(var58->class->vft[COLOR_abstract_collection__Iterator__item]))(var58) /* item on */; -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_a = var66; -var67 = ((val* (*)(val*))(var_msignature->class->vft[COLOR_model__MSignature__mparameters]))(var_msignature) /* mparameters on */; -var68 = ((val* (*)(val*, long))(var67->class->vft[COLOR_abstract_collection__SequenceRead___91d_93d]))(var67, var_i) /* [] on */; -var69 = ((val* (*)(val*))(var68->class->vft[COLOR_model__MParameter__mtype]))(var68) /* mtype on */; -var_t = var69; -var70 = ((long (*)(val*))(var_msignature->class->vft[COLOR_model__MSignature__vararg_rank]))(var_msignature) /* vararg_rank on */; -{ /* 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 */; -var79 = ((val* (*)(val*))(var78->class->vft[COLOR_abstract_compiler__RuntimeVariable__mcasttype]))(var78) /* mcasttype on */; -var_t = var79; +var72 = ((short int (*)(val*))(var71->class->vft[COLOR_abstract_collection__Iterator__is_ok]))(var71) /* is_ok on */; +if(!var72) break; +var73 = ((val* (*)(val*))(var71->class->vft[COLOR_abstract_collection__Iterator__item]))(var71) /* item on */; +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_a = var79; +var80 = ((val* (*)(val*))(var_msignature->class->vft[COLOR_model__MSignature__mparameters]))(var_msignature) /* mparameters on */; +var81 = ((val* (*)(val*, long))(var80->class->vft[COLOR_abstract_collection__SequenceRead___91d_93d]))(var80, var_i) /* [] on */; +var82 = ((val* (*)(val*))(var81->class->vft[COLOR_model__MParameter__mtype]))(var81) /* mtype on */; +var_t = var82; +var83 = ((long (*)(val*))(var_msignature->class->vft[COLOR_model__MSignature__vararg_rank]))(var_msignature) /* vararg_rank on */; +{ /* 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 */; +var92 = ((val* (*)(val*))(var91->class->vft[COLOR_abstract_compiler__RuntimeVariable__mcasttype]))(var91) /* mcasttype on */; +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 */; -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 */; -CHECK_NEW_array__Array(var86); +var98 = ((val* (*)(val*))(var_t->class->vft[COLOR_abstract_compiler__MType__ctype]))(var_t) /* ctype on */; +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 */; +} +var102 = ((val* (*)(val*))(var99->class->vft[COLOR_string__Object__to_s]))(var99) /* to_s on */; +((void (*)(val*, val*))(var_s->class->vft[COLOR_abstract_collection__Sequence__append]))(var_s, var102) /* append on */; +var103 = ((val* (*)(val*, val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__autobox]))(self, var_a, var_t) /* autobox on */; +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 */; +} +var112 = ((val* (*)(val*))(var109->class->vft[COLOR_string__Object__to_s]))(var109) /* to_s on */; +((void (*)(val*, val*))(var_ss->class->vft[COLOR_abstract_collection__Sequence__append]))(var_ss, var112) /* append on */; +CONTINUE_label: (void)0; +((void (*)(val*))(var71->class->vft[COLOR_abstract_collection__Iterator__next]))(var71) /* next on */; +} +BREAK_label: (void)0; +var115 = ((val* (*)(val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__compiler]))(self) /* compiler on */; +var116 = ((val* (*)(val*))(var115->class->vft[COLOR_abstract_compiler__AbstractCompiler__modelbuilder]))(var115) /* modelbuilder on */; +var117 = ((val* (*)(val*))(var116->class->vft[COLOR_modelbuilder__ModelBuilder__toolcontext]))(var116) /* toolcontext on */; +var118 = ((val* (*)(val*))(var117->class->vft[COLOR_abstract_compiler__ToolContext__opt_no_check_other]))(var117) /* opt_no_check_other on */; +var119 = ((val* (*)(val*))(var118->class->vft[COLOR_opts__Option__value]))(var118) /* value on */; +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 */; +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 */; +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 */; +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 */; -((void (*)(val*, val*))(var_s->class->vft[COLOR_abstract_collection__Sequence__append]))(var_s, var89) /* append on */; -var90 = ((val* (*)(val*, val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__autobox]))(self, var_a, var_t) /* autobox on */; -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 */; -CHECK_NEW_array__Array(var96); -} -var99 = ((val* (*)(val*))(var96->class->vft[COLOR_string__Object__to_s]))(var96) /* to_s on */; -((void (*)(val*, val*))(var_ss->class->vft[COLOR_abstract_collection__Sequence__append]))(var_ss, var99) /* append on */; -CONTINUE_label: (void)0; -((void (*)(val*))(var58->class->vft[COLOR_abstract_collection__Iterator__next]))(var58) /* next on */; +var136 = ((short int (*)(val*, val*))(var130->class->vft[COLOR_kernel__Object___61d_61d]))(var130, var132) /* == on */; +var113 = var136; } -BREAK_label: (void)0; -var102 = ((val* (*)(val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__compiler]))(self) /* compiler on */; -var103 = ((val* (*)(val*))(var102->class->vft[COLOR_abstract_compiler__AbstractCompiler__modelbuilder]))(var102) /* modelbuilder on */; -var104 = ((val* (*)(val*))(var103->class->vft[COLOR_modelbuilder__ModelBuilder__toolcontext]))(var103) /* toolcontext on */; -var105 = ((val* (*)(val*))(var104->class->vft[COLOR_abstract_compiler__ToolContext__opt_no_check_other]))(var104) /* opt_no_check_other on */; -var106 = ((val* (*)(val*))(var105->class->vft[COLOR_opts__Option__value]))(var105) /* value on */; -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 */; -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 */; -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 */; -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 */; -var100 = var123; -} -var_consider_null = var100; -var125 = ((val* (*)(val*))(var_recv->class->vft[COLOR_abstract_compiler__RuntimeVariable__mcasttype]))(var_recv) /* mcasttype on */; -/* isa MNullableType */ +var_consider_null = var113; +var138 = ((val* (*)(val*))(var_recv->class->vft[COLOR_abstract_compiler__RuntimeVariable__mcasttype]))(var_recv) /* mcasttype on */; +/* 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 */; -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 */; -((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var141) /* add on */; -var142 = ((val* (*)(val*))(var_mmethod->class->vft[COLOR_model__MProperty__name]))(var_mmethod) /* name on */; -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 */; +} +var154 = ((val* (*)(val*))(var151->class->vft[COLOR_string__Object__to_s]))(var151) /* to_s on */; +((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var154) /* add on */; +var155 = ((val* (*)(val*))(var_mmethod->class->vft[COLOR_model__MProperty__name]))(var_mmethod) /* name on */; +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 */; -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 */; +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_arg = var152; -var153 = ((val* (*)(val*))(var_arg->class->vft[COLOR_abstract_compiler__RuntimeVariable__mcasttype]))(var_arg) /* mcasttype on */; -/* 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_arg = var165; +var166 = ((val* (*)(val*))(var_arg->class->vft[COLOR_abstract_compiler__RuntimeVariable__mcasttype]))(var_arg) /* mcasttype on */; +/* 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 */; -CHECK_NEW_array__Array(var167); -} -var170 = ((val* (*)(val*))(var167->class->vft[COLOR_string__Object__to_s]))(var167) /* to_s on */; -((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var170) /* add on */; -} else { -var171 = ((val* (*)(val*))(var_arg->class->vft[COLOR_abstract_compiler__RuntimeVariable__mcasttype]))(var_arg) /* mcasttype on */; -/* 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 */; -CHECK_NEW_array__Array(var180); } var183 = ((val* (*)(val*))(var180->class->vft[COLOR_string__Object__to_s]))(var180) /* to_s on */; ((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var183) /* add on */; } else { -if (varonce184) { -var185 = varonce184; +var184 = ((val* (*)(val*))(var_arg->class->vft[COLOR_abstract_compiler__RuntimeVariable__mcasttype]))(var_arg) /* mcasttype on */; +/* 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 */; +} +var196 = ((val* (*)(val*))(var193->class->vft[COLOR_string__Object__to_s]))(var193) /* to_s on */; +((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var196) /* add on */; +} 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 */; -if (varonce190) { -var191 = varonce190; +var202 = ((val* (*)(val*))(var_arg->class->vft[COLOR_string__Object__inspect]))(var_arg) /* inspect on */; +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 */; -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 */; } -var198 = ((val* (*)(val*))(var195->class->vft[COLOR_string__Object__to_s]))(var195) /* to_s on */; -((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var198) /* add on */; +var211 = ((val* (*)(val*))(var208->class->vft[COLOR_string__Object__to_s]))(var208) /* to_s on */; +((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var211) /* add on */; } } } else { -var199 = ((val* (*)(val*))(var_mmethod->class->vft[COLOR_model__MProperty__name]))(var_mmethod) /* name on */; -if (varonce200) { -var201 = varonce200; +var212 = ((val* (*)(val*))(var_mmethod->class->vft[COLOR_model__MProperty__name]))(var_mmethod) /* name on */; +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 */; -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 */; +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_arg210 = var209; -var211 = ((val* (*)(val*))(var_arg210->class->vft[COLOR_abstract_compiler__RuntimeVariable__mcasttype]))(var_arg210) /* mcasttype on */; -/* 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 */; -CHECK_NEW_array__Array(var225); -} -var228 = ((val* (*)(val*))(var225->class->vft[COLOR_string__Object__to_s]))(var225) /* to_s on */; -((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var228) /* add on */; -} else { -var229 = ((val* (*)(val*))(var_arg210->class->vft[COLOR_abstract_compiler__RuntimeVariable__mcasttype]))(var_arg210) /* mcasttype on */; -/* 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_arg223 = var222; +var224 = ((val* (*)(val*))(var_arg223->class->vft[COLOR_abstract_compiler__RuntimeVariable__mcasttype]))(var_arg223) /* mcasttype on */; +/* 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 */; -CHECK_NEW_array__Array(var238); } var241 = ((val* (*)(val*))(var238->class->vft[COLOR_string__Object__to_s]))(var238) /* to_s on */; ((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var241) /* add on */; } 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 */; -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 */; -CHECK_NEW_array__Array(var253); -} -var256 = ((val* (*)(val*))(var253->class->vft[COLOR_string__Object__to_s]))(var253) /* to_s on */; -((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var256) /* add on */; +var242 = ((val* (*)(val*))(var_arg223->class->vft[COLOR_abstract_compiler__RuntimeVariable__mcasttype]))(var_arg223) /* mcasttype on */; +/* 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 */; +} +var254 = ((val* (*)(val*))(var251->class->vft[COLOR_string__Object__to_s]))(var251) /* to_s on */; +((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var254) /* add on */; +} 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 */; +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 */; +} +var269 = ((val* (*)(val*))(var266->class->vft[COLOR_string__Object__to_s]))(var266) /* to_s on */; +((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var269) /* add on */; } } } 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 */; +((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add_abort]))(self, var271) /* add_abort on */; } } -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 */; +((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var276) /* add on */; } else { } -var268 = ((val* (*)(val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__compiler]))(self) /* compiler on */; -var269 = ((val* (*)(val*))(var268->class->vft[COLOR_abstract_compiler__AbstractCompiler__modelbuilder]))(var268) /* modelbuilder on */; -var270 = ((val* (*)(val*))(var269->class->vft[COLOR_modelbuilder__ModelBuilder__toolcontext]))(var269) /* toolcontext on */; -var271 = ((val* (*)(val*))(var270->class->vft[COLOR_separate_compiler__ToolContext__opt_no_shortcut_equate]))(var270) /* opt_no_shortcut_equate on */; -var272 = ((val* (*)(val*))(var271->class->vft[COLOR_opts__Option__value]))(var271) /* value on */; -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 */; -if (varonce278) { -var279 = varonce278; +var281 = ((val* (*)(val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__compiler]))(self) /* compiler on */; +var282 = ((val* (*)(val*))(var281->class->vft[COLOR_abstract_compiler__AbstractCompiler__modelbuilder]))(var281) /* modelbuilder on */; +var283 = ((val* (*)(val*))(var282->class->vft[COLOR_modelbuilder__ModelBuilder__toolcontext]))(var282) /* toolcontext on */; +var284 = ((val* (*)(val*))(var283->class->vft[COLOR_separate_compiler__ToolContext__opt_no_shortcut_equate]))(var283) /* opt_no_shortcut_equate on */; +var285 = ((val* (*)(val*))(var284->class->vft[COLOR_opts__Option__value]))(var284) /* value on */; +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 */; +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 */; -var_284 = var283; -if (var283){ -var276 = var_284; +var296 = ((short int (*)(val*, val*))(var290->class->vft[COLOR_kernel__Object___61d_61d]))(var290, var292) /* == on */; +var_297 = var296; +if (var296){ +var289 = var_297; } else { -var285 = ((val* (*)(val*))(var_mmethod->class->vft[COLOR_model__MProperty__name]))(var_mmethod) /* name on */; -if (varonce286) { -var287 = varonce286; +var298 = ((val* (*)(val*))(var_mmethod->class->vft[COLOR_model__MProperty__name]))(var_mmethod) /* name on */; +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 */; -var276 = var291; +var304 = ((short int (*)(val*, val*))(var298->class->vft[COLOR_kernel__Object___61d_61d]))(var298, var300) /* == on */; +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_arg296 = var295; -var297 = ((val* (*)(val*))(var_arg296->class->vft[COLOR_abstract_compiler__RuntimeVariable__mcasttype]))(var_arg296) /* mcasttype on */; -/* 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 */; -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 */; -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 */; -CHECK_NEW_array__Array(var313); -} -var316 = ((val* (*)(val*))(var313->class->vft[COLOR_string__Object__to_s]))(var313) /* to_s on */; -((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var316) /* add on */; -} 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 */; -CHECK_NEW_array__Array(var322); -} -var325 = ((val* (*)(val*))(var322->class->vft[COLOR_string__Object__to_s]))(var322) /* to_s on */; -((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var325) /* add on */; +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_arg309 = var308; +var310 = ((val* (*)(val*))(var_arg309->class->vft[COLOR_abstract_compiler__RuntimeVariable__mcasttype]))(var_arg309) /* mcasttype on */; +/* 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 */; +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 */; +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 */; +} +var329 = ((val* (*)(val*))(var326->class->vft[COLOR_string__Object__to_s]))(var326) /* to_s on */; +((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var329) /* add on */; +} 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 */; +} +var338 = ((val* (*)(val*))(var335->class->vft[COLOR_string__Object__to_s]))(var335) /* to_s on */; +((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var338) /* add on */; } 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 */; +((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var340) /* add on */; } 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_r = var338; +var351 = ((val* (*)(val*))(var_ret->class->vft[COLOR_abstract_compiler__MType__ctype]))(var_ret) /* ctype on */; +var_r = var351; } ((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__require_declaration]))(self, var_const_color) /* require_declaration on */; -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 */; -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 */; -((void (*)(val*, val*))(var_341->class->vft[COLOR_abstract_collection__SimpleCollection__add]))(var_341, var_r) /* add on */; -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 */; -((void (*)(val*, val*))(var_341->class->vft[COLOR_abstract_collection__SimpleCollection__add]))(var_341, var_s) /* add on */; -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 */; -var357 = ((val* (*)(val*))(var_arguments->class->vft[COLOR_abstract_collection__Collection__first]))(var_arguments) /* first on */; -((void (*)(val*, val*))(var_341->class->vft[COLOR_abstract_collection__SimpleCollection__add]))(var_341, var357) /* add on */; -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 */; -((void (*)(val*, val*))(var_341->class->vft[COLOR_abstract_collection__SimpleCollection__add]))(var_341, var_const_color) /* add on */; -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 */; -((void (*)(val*, val*))(var_341->class->vft[COLOR_abstract_collection__SimpleCollection__add]))(var_341, var_ss) /* add on */; -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 */; -((void (*)(val*, val*))(var_341->class->vft[COLOR_abstract_collection__SimpleCollection__add]))(var_341, var_mmethod) /* add on */; -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 */; -var378 = ((val* (*)(val*))(var_arguments->class->vft[COLOR_abstract_collection__Collection__first]))(var_arguments) /* first on */; -var379 = ((val* (*)(val*))(var378->class->vft[COLOR_string__Object__inspect]))(var378) /* inspect on */; -((void (*)(val*, val*))(var_341->class->vft[COLOR_abstract_collection__SimpleCollection__add]))(var_341, var379) /* add on */; -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 */; -var385 = ((val* (*)(val*))(var_341->class->vft[COLOR_string__Object__to_s]))(var_341) /* to_s on */; -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 */; +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 */; +((void (*)(val*, val*))(var_354->class->vft[COLOR_abstract_collection__SimpleCollection__add]))(var_354, var_r) /* add on */; +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 */; +((void (*)(val*, val*))(var_354->class->vft[COLOR_abstract_collection__SimpleCollection__add]))(var_354, var_s) /* add on */; +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 */; +var370 = ((val* (*)(val*))(var_arguments->class->vft[COLOR_abstract_collection__Collection__first]))(var_arguments) /* first on */; +((void (*)(val*, val*))(var_354->class->vft[COLOR_abstract_collection__SimpleCollection__add]))(var_354, var370) /* add on */; +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 */; +((void (*)(val*, val*))(var_354->class->vft[COLOR_abstract_collection__SimpleCollection__add]))(var_354, var_const_color) /* add on */; +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 */; +((void (*)(val*, val*))(var_354->class->vft[COLOR_abstract_collection__SimpleCollection__add]))(var_354, var_ss) /* add on */; +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 */; +((void (*)(val*, val*))(var_354->class->vft[COLOR_abstract_collection__SimpleCollection__add]))(var_354, var_mmethod) /* add on */; +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 */; +var391 = ((val* (*)(val*))(var_arguments->class->vft[COLOR_abstract_collection__Collection__first]))(var_arguments) /* first on */; +var392 = ((val* (*)(val*))(var391->class->vft[COLOR_string__Object__inspect]))(var391) /* inspect on */; +((void (*)(val*, val*))(var_354->class->vft[COLOR_abstract_collection__SimpleCollection__add]))(var_354, var392) /* add on */; 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 */; -CHECK_NEW_array__Array(var398); -} -var401 = ((val* (*)(val*))(var398->class->vft[COLOR_string__Object__to_s]))(var398) /* to_s on */; -((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var401) /* add on */; -} else { -if (varonce402) { -var403 = varonce402; +((void (*)(val*, val*))(var_354->class->vft[COLOR_abstract_collection__SimpleCollection__add]))(var_354, var394) /* add on */; +var398 = ((val* (*)(val*))(var_354->class->vft[COLOR_string__Object__to_s]))(var_354) /* to_s on */; +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 */; -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 */; -((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var410) /* add on */; +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 */; +} +var414 = ((val* (*)(val*))(var411->class->vft[COLOR_string__Object__to_s]))(var411) /* to_s on */; +((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var414) /* add on */; +} 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 */; +} +var423 = ((val* (*)(val*))(var420->class->vft[COLOR_string__Object__to_s]))(var420) /* to_s on */; +((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var423) /* add on */; } 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 */; +((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var425) /* add on */; } 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 */; -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 */; +var2 = ((val* (*)(val*))(var_mmethoddef->class->vft[COLOR_model__MMethodDef__msignature]))(var_mmethoddef) /* msignature on */; +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 */; +} +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 */; +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 */; -var4 = ((short int (*)(val*))(var3->class->vft[COLOR_model__MMethod__is_new]))(var3) /* is_new on */; -if (var4){ -var5 = ((val* (*)(val*))(var_arguments->class->vft[COLOR_abstract_collection__Collection__first]))(var_arguments) /* first on */; -var6 = ((val* (*)(val*))(var5->class->vft[COLOR_abstract_compiler__RuntimeVariable__mtype]))(var5) /* mtype on */; -var_ret = var6; -var7 = ((val* (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__new_var]))(self, var_ret) /* new_var on */; -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 */; -var12 = ((val* (*)(val*))(var11->class->vft[COLOR_model__MClassDef__bound_mtype]))(var11) /* bound_mtype on */; -var13 = ((val* (*)(val*))(var_mmethoddef->class->vft[COLOR_model__MPropDef__mclassdef]))(var_mmethoddef) /* mclassdef on */; -var14 = ((val* (*)(val*))(var13->class->vft[COLOR_model__MClassDef__bound_mtype]))(var13) /* bound_mtype on */; -var15 = ((val* (*)(val*))(var_mmethoddef->class->vft[COLOR_model__MPropDef__mclassdef]))(var_mmethoddef) /* mclassdef on */; -var16 = ((val* (*)(val*))(var15->class->vft[COLOR_model__MClassDef__mmodule]))(var15) /* mmodule on */; -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 = var18; -var19 = ((val* (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__new_var]))(self, var_ret) /* new_var on */; -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 */; +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 */; -var23 = ((val* (*)(val*))(var22->class->vft[COLOR_abstract_compiler__AbstractCompiler__modelbuilder]))(var22) /* modelbuilder on */; -var24 = ((val* (*)(val*))(var23->class->vft[COLOR_modelize_property__ModelBuilder__mpropdef2npropdef]))(var23) /* mpropdef2npropdef on */; -var25 = ((short int (*)(val*, val*))(var24->class->vft[COLOR_abstract_collection__MapRead__has_key]))(var24, var_mmethoddef) /* has_key on */; -var_ = var25; -if (var25){ -var26 = ((val* (*)(val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__compiler]))(self) /* compiler on */; -var27 = ((val* (*)(val*))(var26->class->vft[COLOR_abstract_compiler__AbstractCompiler__modelbuilder]))(var26) /* modelbuilder on */; -var28 = ((val* (*)(val*))(var27->class->vft[COLOR_modelize_property__ModelBuilder__mpropdef2npropdef]))(var27) /* mpropdef2npropdef on */; -var29 = ((val* (*)(val*, val*))(var28->class->vft[COLOR_abstract_collection__MapRead___91d_93d]))(var28, var_mmethoddef) /* [] on */; -/* 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 */; +} +var30 = ((val* (*)(val*))(var26->class->vft[COLOR_string__Object__to_s]))(var26) /* to_s on */; +((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__debug]))(self, var30) /* debug on */; +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 */; +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 */; +} +var_ret = var32; +var33 = ((val* (*)(val*))(var_mmethoddef->class->vft[COLOR_model__MPropDef__mproperty]))(var_mmethoddef) /* mproperty on */; +var34 = ((short int (*)(val*))(var33->class->vft[COLOR_model__MMethod__is_new]))(var33) /* is_new on */; +if (var34){ +var35 = ((val* (*)(val*))(var_arguments->class->vft[COLOR_abstract_collection__Collection__first]))(var_arguments) /* first on */; +var36 = ((val* (*)(val*))(var35->class->vft[COLOR_abstract_compiler__RuntimeVariable__mtype]))(var35) /* mtype on */; +var_ret = var36; +var37 = ((val* (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__new_var]))(self, var_ret) /* new_var on */; +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 */; +var42 = ((val* (*)(val*))(var41->class->vft[COLOR_model__MClassDef__bound_mtype]))(var41) /* bound_mtype on */; +var43 = ((val* (*)(val*))(var_mmethoddef->class->vft[COLOR_model__MPropDef__mclassdef]))(var_mmethoddef) /* mclassdef on */; +var44 = ((val* (*)(val*))(var43->class->vft[COLOR_model__MClassDef__bound_mtype]))(var43) /* bound_mtype on */; +var45 = ((val* (*)(val*))(var_mmethoddef->class->vft[COLOR_model__MPropDef__mclassdef]))(var_mmethoddef) /* mclassdef on */; +var46 = ((val* (*)(val*))(var45->class->vft[COLOR_model__MClassDef__mmodule]))(var45) /* mmodule on */; +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 = var48; +var49 = ((val* (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__new_var]))(self, var_ret) /* new_var on */; +var_res = var49; +} +} +var52 = ((val* (*)(val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__compiler]))(self) /* compiler on */; +var53 = ((val* (*)(val*))(var52->class->vft[COLOR_abstract_compiler__AbstractCompiler__modelbuilder]))(var52) /* modelbuilder on */; +var54 = ((val* (*)(val*))(var53->class->vft[COLOR_modelize_property__ModelBuilder__mpropdef2npropdef]))(var53) /* mpropdef2npropdef on */; +var55 = ((short int (*)(val*, val*))(var54->class->vft[COLOR_abstract_collection__MapRead__has_key]))(var54, var_mmethoddef) /* has_key on */; +var_ = var55; +if (var55){ +var56 = ((val* (*)(val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__compiler]))(self) /* compiler on */; +var57 = ((val* (*)(val*))(var56->class->vft[COLOR_abstract_compiler__AbstractCompiler__modelbuilder]))(var56) /* modelbuilder on */; +var58 = ((val* (*)(val*))(var57->class->vft[COLOR_modelize_property__ModelBuilder__mpropdef2npropdef]))(var57) /* mpropdef2npropdef on */; +var59 = ((val* (*)(val*, val*))(var58->class->vft[COLOR_abstract_collection__MapRead___91d_93d]))(var58, var_mmethoddef) /* [] on */; +/* 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 */; -var33 = ((val* (*)(val*))(var32->class->vft[COLOR_abstract_compiler__AbstractCompiler__modelbuilder]))(var32) /* modelbuilder on */; -var34 = ((val* (*)(val*))(var33->class->vft[COLOR_modelbuilder__ModelBuilder__toolcontext]))(var33) /* toolcontext on */; -var35 = ((val* (*)(val*))(var34->class->vft[COLOR_separate_compiler__ToolContext__opt_no_inline_intern]))(var34) /* opt_no_inline_intern on */; -var36 = ((val* (*)(val*))(var35->class->vft[COLOR_opts__Option__value]))(var35) /* value on */; -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 */; -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 */; +var63 = ((val* (*)(val*))(var62->class->vft[COLOR_abstract_compiler__AbstractCompiler__modelbuilder]))(var62) /* modelbuilder on */; +var64 = ((val* (*)(val*))(var63->class->vft[COLOR_modelbuilder__ModelBuilder__toolcontext]))(var63) /* toolcontext on */; +var65 = ((val* (*)(val*))(var64->class->vft[COLOR_separate_compiler__ToolContext__opt_no_inline_intern]))(var64) /* opt_no_inline_intern on */; +var66 = ((val* (*)(val*))(var65->class->vft[COLOR_opts__Option__value]))(var65) /* value on */; +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 */; -((void (*)(val*, val*))(var_frame->class->vft[COLOR_abstract_compiler__Frame__returnlabel_61d]))(var_frame, var44) /* returnlabel= on */; +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 */; +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 */; +((void (*)(val*, val*))(var_frame->class->vft[COLOR_abstract_compiler__Frame__returnlabel_61d]))(var_frame, var75) /* returnlabel= on */; ((void (*)(val*, val*))(var_frame->class->vft[COLOR_abstract_compiler__Frame__returnvar_61d]))(var_frame, var_res) /* returnvar= on */; -var45 = ((val* (*)(val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__frame]))(self) /* frame on */; -var_old_frame = var45; +var76 = ((val* (*)(val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__frame]))(self) /* frame on */; +var_old_frame = var76; ((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__frame_61d]))(self, var_frame) /* frame= on */; -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 */; -if (varonce62) { -var63 = varonce62; +var92 = ((val* (*)(val*, val*))(var_arguments->class->vft[COLOR_string__Collection__join]))(var_arguments, var88) /* join on */; +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 */; -CHECK_NEW_array__Array(var67); -} -var70 = ((val* (*)(val*))(var67->class->vft[COLOR_string__Object__to_s]))(var67) /* to_s on */; -((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var70) /* add on */; -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 */; -var71; -var72 = ((val* (*)(val*))(var_frame->class->vft[COLOR_abstract_compiler__Frame__returnlabel]))(var_frame) /* returnlabel on */; -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 */; +} +var101 = ((val* (*)(val*))(var98->class->vft[COLOR_string__Object__to_s]))(var98) /* to_s on */; +((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var101) /* add on */; +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 */; +var102; +var103 = ((val* (*)(val*))(var_frame->class->vft[COLOR_abstract_compiler__Frame__returnlabel]))(var_frame) /* returnlabel on */; +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 */; -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 */; } -var81 = ((val* (*)(val*))(var78->class->vft[COLOR_string__Object__to_s]))(var78) /* to_s on */; -((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var81) /* add on */; -if (varonce82) { -var83 = varonce82; +var112 = ((val* (*)(val*))(var109->class->vft[COLOR_string__Object__to_s]))(var109) /* to_s on */; +((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var112) /* add on */; +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 */; +((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var114) /* add on */; ((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__frame_61d]))(self, var_old_frame) /* frame= on */; 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 */; -var87 = ((val* (*)(val*))(var_mmethoddef->class->vft[COLOR_abstract_compiler__MPropDef__c_name]))(var_mmethoddef) /* c_name on */; -((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__require_declaration]))(self, var87) /* require_declaration on */; -var88 = NULL; +var118 = ((val* (*)(val*))(var_mmethoddef->class->vft[COLOR_abstract_compiler__MPropDef__c_name]))(var_mmethoddef) /* c_name on */; +((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__require_declaration]))(self, var118) /* require_declaration on */; +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 */; -if (varonce91) { -var92 = varonce91; +if (var120){ +var121 = ((val* (*)(val*))(var_mmethoddef->class->vft[COLOR_abstract_compiler__MPropDef__c_name]))(var_mmethoddef) /* c_name on */; +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 */; -if (varonce102) { -var103 = varonce102; +var132 = ((val* (*)(val*, val*))(var_arguments->class->vft[COLOR_string__Collection__join]))(var_arguments, var128) /* join on */; +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 */; } -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 */; -CHECK_NEW_array__Array(var107); -} -var110 = ((val* (*)(val*))(var107->class->vft[COLOR_string__Object__to_s]))(var107) /* to_s on */; -((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var110) /* add on */; -var111 = NULL; -var = var111; +var141 = ((val* (*)(val*))(var138->class->vft[COLOR_string__Object__to_s]))(var138) /* to_s on */; +((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var141) /* add on */; +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 */; -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 */; +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 */; +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 */; +} +var168 = ((val* (*)(val*))(var165->class->vft[COLOR_string__Object__to_s]))(var165) /* to_s on */; +((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var168) /* add on */; } -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 */; -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 */; -CHECK_NEW_array__Array(var134); -} -var137 = ((val* (*)(val*))(var134->class->vft[COLOR_string__Object__to_s]))(var134) /* to_s on */; -((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var137) /* add on */; +/* 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 */; +var2 = ((val* (*)(val*))(var1->class->vft[COLOR_abstract_compiler__RuntimeVariable__mcasttype]))(var1) /* mcasttype on */; +var3 = ((val* (*)(val*))(var2->class->vft[COLOR_abstract_compiler__MType__ctype]))(var2) /* ctype on */; +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 */; +if (var8){ +var9 = ((val* (*)(val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__compiler]))(self) /* compiler on */; +var10 = ((val* (*)(val*))(var9->class->vft[COLOR_abstract_compiler__AbstractCompiler__mainmodule]))(var9) /* mainmodule on */; +var_main = var10; +var11 = ((val* (*)(val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__compiler]))(self) /* compiler on */; +var12 = ((val* (*)(val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__compiler]))(self) /* compiler on */; +var13 = ((val* (*)(val*))(var12->class->vft[COLOR_abstract_compiler__AbstractCompiler__realmainmodule]))(var12) /* realmainmodule on */; +((void (*)(val*, val*))(var11->class->vft[COLOR_abstract_compiler__AbstractCompiler__mainmodule_61d]))(var11, var13) /* mainmodule= on */; +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 */; +var_res = var14; +var15 = ((val* (*)(val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__compiler]))(self) /* compiler on */; +((void (*)(val*, val*))(var15->class->vft[COLOR_abstract_compiler__AbstractCompiler__mainmodule_61d]))(var15, var_main) /* mainmodule= on */; 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 */; -var2 = ((val* (*)(val*))(var_m->class->vft[COLOR_separate_compiler__MPropDef__const_color]))(var_m) /* const_color on */; -var3 = ((val* (*)(val*, val*, val*, val*))(self->class->vft[COLOR_separate_compiler__SeparateCompilerVisitor__table_send]))(self, var1, var_arguments, var2) /* table_send on */; -var = var3; +var16 = ((val* (*)(val*))(var_m->class->vft[COLOR_model__MPropDef__mproperty]))(var_m) /* mproperty on */; +var17 = ((val* (*)(val*))(var_m->class->vft[COLOR_separate_compiler__MPropDef__const_color]))(var_m) /* const_color on */; +var18 = ((val* (*)(val*, val*, val*, val*))(self->class->vft[COLOR_separate_compiler__SeparateCompilerVisitor__table_send]))(self, var16, var_arguments, var17) /* table_send on */; +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 */; -CHECK_NEW_array__Array(var5); var_ = var5; ((void (*)(val*, val*))(var_->class->vft[COLOR_abstract_collection__Sequence__push]))(var_, var_recv) /* push on */; ((void (*)(val*, val*, val*, val*, val*))(var2->class->vft[COLOR_abstract_compiler__Frame__init]))(var2, self, var_mpropdef, var4, var_) /* init on */; -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 */; var7 = ((val* (*)(val*, val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__array_instance]))(self, var_varargs, var_elttype) /* array_instance on */; @@ -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 */; 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 */; @@ -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 */; -CHECK_NEW_array__Array(var28); } var31 = ((val* (*)(val*))(var28->class->vft[COLOR_string__Object__to_s]))(var28) /* to_s on */; ((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var31) /* add on */; @@ -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 */; -CHECK_NEW_array__Array(var66); } var69 = ((val* (*)(val*))(var66->class->vft[COLOR_string__Object__to_s]))(var66) /* to_s on */; ((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var69) /* add on */; @@ -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 */; -CHECK_NEW_array__Array(var104); } var107 = ((val* (*)(val*))(var104->class->vft[COLOR_string__Object__to_s]))(var104) /* to_s on */; ((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var107) /* add on */; @@ -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 */; -CHECK_NEW_array__Array(var124); } var127 = ((val* (*)(val*))(var124->class->vft[COLOR_string__Object__to_s]))(var124) /* to_s on */; ((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var127) /* add on */; @@ -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 */; 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 */; @@ -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 */; -CHECK_NEW_array__Array(var46); } var49 = ((val* (*)(val*))(var46->class->vft[COLOR_string__Object__to_s]))(var46) /* to_s on */; ((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var49) /* add on */; @@ -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 */; -CHECK_NEW_array__Array(var70); } var73 = ((val* (*)(val*))(var70->class->vft[COLOR_string__Object__to_s]))(var70) /* to_s on */; ((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var73) /* add on */; @@ -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 */; -CHECK_NEW_array__Array(var80); } var83 = ((val* (*)(val*))(var80->class->vft[COLOR_string__Object__to_s]))(var80) /* to_s on */; ((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add_abort]))(self, var83) /* add_abort on */; @@ -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 */; -CHECK_NEW_array__Array(var125); } var128 = ((val* (*)(val*))(var125->class->vft[COLOR_string__Object__to_s]))(var125) /* to_s on */; ((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var128) /* add on */; @@ -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 */; -CHECK_NEW_array__Array(var161); } var164 = ((val* (*)(val*))(var161->class->vft[COLOR_string__Object__to_s]))(var161) /* to_s on */; ((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var164) /* add on */; @@ -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 */; -CHECK_NEW_array__Array(var171); } var174 = ((val* (*)(val*))(var171->class->vft[COLOR_string__Object__to_s]))(var171) /* to_s on */; ((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add_abort]))(self, var174) /* add_abort on */; @@ -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 */; 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 */; @@ -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 */; -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 */; -CHECK_NEW_array__Array(var53); } var56 = ((val* (*)(val*))(var53->class->vft[COLOR_string__Object__to_s]))(var53) /* to_s on */; ((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var56) /* add on */; @@ -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 */; +var62 = ((val* (*)(val*))(var_mtype->class->vft[COLOR_separate_compiler__MType__c_instance_name]))(var_mtype) /* c_instance_name on */; 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 */; -CHECK_NEW_array__Array(var89); } var92 = ((val* (*)(val*))(var89->class->vft[COLOR_string__Object__to_s]))(var89) /* to_s on */; ((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var92) /* add on */; @@ -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 */; -CHECK_NEW_array__Array(var122); } var125 = ((val* (*)(val*))(var122->class->vft[COLOR_string__Object__to_s]))(var122) /* to_s on */; ((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var125) /* add on */; @@ -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 */; -CHECK_NEW_array__Array(var152); } var155 = ((val* (*)(val*))(var152->class->vft[COLOR_string__Object__to_s]))(var152) /* to_s on */; ((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var155) /* add on */; } } 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 */; +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 */; +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 */; +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 */; +} +var192 = ((val* (*)(val*))(var189->class->vft[COLOR_string__Object__to_s]))(var189) /* to_s on */; +((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var192) /* add on */; +} +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 */; +var1 = ((val* (*)(val*))(var->class->vft[COLOR_abstract_compiler__AbstractCompiler__modelbuilder]))(var) /* modelbuilder on */; +var2 = ((val* (*)(val*))(var1->class->vft[COLOR_modelbuilder__ModelBuilder__toolcontext]))(var1) /* toolcontext on */; +var3 = ((val* (*)(val*))(var2->class->vft[COLOR_abstract_compiler__ToolContext__opt_hardening]))(var2) /* opt_hardening on */; +var4 = ((val* (*)(val*))(var3->class->vft[COLOR_opts__Option__value]))(var3) /* value on */; +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 */; +((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__require_declaration]))(self, var7) /* require_declaration on */; +var8 = ((val* (*)(val*))(var_mtype->class->vft[COLOR_separate_compiler__MType__const_color]))(var_mtype) /* const_color on */; +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 */; +} +var21 = ((val* (*)(val*))(var18->class->vft[COLOR_string__Object__to_s]))(var18) /* to_s on */; +((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var21) /* add on */; +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 */; +var28 = ((val* (*)(val*))(var27->class->vft[COLOR_string__AbstractString__escape_to_c]))(var27) /* escape_to_c on */; +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 */; +} +var37 = ((val* (*)(val*))(var34->class->vft[COLOR_string__Object__to_s]))(var34) /* to_s on */; +((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var37) /* add on */; +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 */; +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 */; +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 */; +var1 = ((val* (*)(val*))(var->class->vft[COLOR_abstract_compiler__AbstractCompiler__modelbuilder]))(var) /* modelbuilder on */; +var2 = ((val* (*)(val*))(var1->class->vft[COLOR_modelbuilder__ModelBuilder__toolcontext]))(var1) /* toolcontext on */; +var3 = ((val* (*)(val*))(var2->class->vft[COLOR_abstract_compiler__ToolContext__opt_hardening]))(var2) /* opt_hardening on */; +var4 = ((val* (*)(val*))(var3->class->vft[COLOR_opts__Option__value]))(var3) /* value on */; +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 */; -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 */; +} +var19 = ((val* (*)(val*))(var16->class->vft[COLOR_string__Object__to_s]))(var16) /* to_s on */; +((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var19) /* add on */; +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 */; -if (varonce168) { -var169 = varonce168; +((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add_abort]))(self, var21) /* add_abort on */; +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 */; +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 */; -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 */; -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 */; } -var192 = ((val* (*)(val*))(var189->class->vft[COLOR_string__Object__to_s]))(var189) /* to_s on */; -((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var192) /* add on */; +var48 = ((val* (*)(val*))(var45->class->vft[COLOR_string__Object__to_s]))(var45) /* to_s on */; +((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var48) /* add on */; +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 */; +} +var62 = ((val* (*)(val*))(var59->class->vft[COLOR_string__Object__to_s]))(var59) /* to_s on */; +((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var62) /* add on */; +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 */; +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 */; 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 */; -CHECK_NEW_array__Array(var7); } var10 = ((val* (*)(val*))(var7->class->vft[COLOR_string__Object__to_s]))(var7) /* to_s on */; ((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__require_declaration]))(self, var10) /* require_declaration on */; @@ -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 */; var15 = ((val* (*)(val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__frame]))(self) /* frame on */; 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 */; } @@ -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 */; var18 = ((val* (*)(val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__frame]))(self) /* frame on */; 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 */; } @@ -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 */; -CHECK_NEW_array__Array(var63); } var66 = ((val* (*)(val*))(var63->class->vft[COLOR_string__Object__to_s]))(var63) /* to_s on */; var67 = ((val* (*)(val*, val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__new_expr]))(self, var66, var_mtype) /* new_expr on */; @@ -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 */; -CHECK_NEW_array__Array(var91); } var94 = ((val* (*)(val*))(var91->class->vft[COLOR_string__Object__to_s]))(var91) /* to_s on */; var95 = ((val* (*)(val*, val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__new_expr]))(self, var94, var_mtype) /* new_expr on */; @@ -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 */; -CHECK_NEW_array__Array(var103); -} -var106 = ((val* (*)(val*))(var103->class->vft[COLOR_string__Object__to_s]))(var103) /* to_s on */; -((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__require_declaration]))(self, var106) /* require_declaration on */; -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 */; -var113 = ((val* (*)(val*))(var112->class->vft[COLOR_abstract_compiler__MClass__c_name]))(var112) /* c_name on */; -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 */; -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 */; -CHECK_NEW_array__Array(var125); -} -var128 = ((val* (*)(val*))(var125->class->vft[COLOR_string__Object__to_s]))(var125) /* to_s on */; -var129 = ((val* (*)(val*, val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__new_expr]))(self, var128, var_mtype) /* new_expr on */; -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 */; -var1 = ((val* (*)(val*))(var->class->vft[COLOR_abstract_compiler__AbstractCompiler__modelbuilder]))(var) /* modelbuilder on */; -var2 = ((val* (*)(val*))(var1->class->vft[COLOR_modelbuilder__ModelBuilder__toolcontext]))(var1) /* toolcontext on */; -var3 = ((val* (*)(val*))(var2->class->vft[COLOR_abstract_compiler__ToolContext__opt_no_check_initialization]))(var2) /* opt_no_check_initialization on */; -var4 = ((val* (*)(val*))(var3->class->vft[COLOR_opts__Option__value]))(var3) /* value on */; -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 */; } -var10 = ((val* (*)(val*))(var_mtype->class->vft[COLOR_model__MClassType__mclass]))(var_mtype) /* mclass on */; -var11 = ((val* (*)(val*))(var10->class->vft[COLOR_abstract_compiler__MClass__c_name]))(var10) /* c_name on */; -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 */; -CHECK_NEW_array__Array(var12); -} -var15 = ((val* (*)(val*))(var12->class->vft[COLOR_string__Object__to_s]))(var12) /* to_s on */; -((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__require_declaration]))(self, var15) /* require_declaration on */; -if (varonce16) { -var17 = varonce16; +var106 = ((val* (*)(val*))(var103->class->vft[COLOR_string__Object__to_s]))(var103) /* to_s on */; +((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__require_declaration]))(self, var106) /* require_declaration on */; +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 */; -var22 = ((val* (*)(val*))(var21->class->vft[COLOR_abstract_compiler__MClass__c_name]))(var21) /* c_name on */; -if (varonce23) { -var24 = varonce23; +var112 = ((val* (*)(val*))(var_mtype->class->vft[COLOR_model__MClassType__mclass]))(var_mtype) /* mclass on */; +var113 = ((val* (*)(val*))(var112->class->vft[COLOR_abstract_compiler__MClass__c_name]))(var112) /* c_name on */; +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 */; +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 */; } -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 */; -CHECK_NEW_array__Array(var33); -} -var36 = ((val* (*)(val*))(var33->class->vft[COLOR_string__Object__to_s]))(var33) /* to_s on */; -((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var36) /* add on */; +var128 = ((val* (*)(val*))(var125->class->vft[COLOR_string__Object__to_s]))(var125) /* to_s on */; +var129 = ((val* (*)(val*, val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__new_expr]))(self, var128, var_mtype) /* new_expr on */; +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 */; -CHECK_NEW_array__Array(var16); } var19 = ((val* (*)(val*))(var16->class->vft[COLOR_string__Object__to_s]))(var16) /* to_s on */; ((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var19) /* add on */; @@ -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 */; 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 */; } @@ -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 */; -CHECK_NEW_array__Array(var43); } var46 = ((val* (*)(val*))(var43->class->vft[COLOR_string__Object__to_s]))(var43) /* to_s on */; ((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add_decl]))(self, var46) /* add_decl on */; @@ -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 */; -CHECK_NEW_array__Array(var63); } var66 = ((val* (*)(val*))(var63->class->vft[COLOR_string__Object__to_s]))(var63) /* to_s on */; ((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add_decl]))(self, var66) /* add_decl on */; @@ -5666,9 +5543,9 @@ var_accept_null = var76; var80 = ((val* (*)(val*))(var_value->class->vft[COLOR_abstract_compiler__RuntimeVariable__mcasttype]))(var_value) /* mcasttype on */; var81 = ((val* (*)(val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__frame]))(self) /* frame on */; 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 */; } @@ -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 */; var85 = ((val* (*)(val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__frame]))(self) /* frame on */; 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 */; } @@ -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 */; -CHECK_NEW_array__Array(var106); } var109 = ((val* (*)(val*))(var106->class->vft[COLOR_string__Object__to_s]))(var106) /* to_s on */; ((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var109) /* add on */; @@ -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 */; -CHECK_NEW_array__Array(var135); } var138 = ((val* (*)(val*))(var135->class->vft[COLOR_string__Object__to_s]))(var135) /* to_s on */; ((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var138) /* add on */; @@ -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 */; -CHECK_NEW_array__Array(var156); } var159 = ((val* (*)(val*))(var156->class->vft[COLOR_string__Object__to_s]))(var156) /* to_s on */; ((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add_decl]))(self, var159) /* add_decl on */; +((void (*)(val*, val*))(self->class->vft[COLOR_separate_compiler__SeparateCompilerVisitor__hardening_live_open_type]))(self, var_mtype) /* hardening_live_open_type on */; var160 = ((val* (*)(val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__frame]))(self) /* frame on */; 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 */; } var162 = ((val* (*)(val*))(var161->class->vft[COLOR_model__MPropDef__mclassdef]))(var161) /* mclassdef on */; -((void (*)(val*, val*, val*))(self->class->vft[COLOR_separate_compiler__SeparateCompilerVisitor__link_unresolved_type]))(self, var162, var_ntype) /* link_unresolved_type on */; -var163 = ((val* (*)(val*))(var_ntype->class->vft[COLOR_separate_compiler__MType__const_color]))(var_ntype) /* const_color on */; +((void (*)(val*, val*, val*))(self->class->vft[COLOR_separate_compiler__SeparateCompilerVisitor__link_unresolved_type]))(self, var162, var_mtype) /* link_unresolved_type on */; +var163 = ((val* (*)(val*))(var_mtype->class->vft[COLOR_separate_compiler__MType__const_color]))(var_mtype) /* const_color on */; ((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__require_declaration]))(self, var163) /* require_declaration on */; var165 = ((val* (*)(val*))(var_compiler->class->vft[COLOR_abstract_compiler__AbstractCompiler__modelbuilder]))(var_compiler) /* modelbuilder on */; var166 = ((val* (*)(val*))(var165->class->vft[COLOR_modelbuilder__ModelBuilder__toolcontext]))(var165) /* toolcontext on */; @@ -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 */; +var191 = ((val* (*)(val*))(var_mtype->class->vft[COLOR_separate_compiler__MType__const_color]))(var_mtype) /* const_color on */; 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 */; -CHECK_NEW_array__Array(var197); } var200 = ((val* (*)(val*))(var197->class->vft[COLOR_string__Object__to_s]))(var197) /* to_s on */; ((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var200) /* add on */; @@ -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 */; +var211 = ((val* (*)(val*))(var_mtype->class->vft[COLOR_separate_compiler__MType__const_color]))(var_mtype) /* const_color on */; 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 */; -CHECK_NEW_array__Array(var217); } var220 = ((val* (*)(val*))(var217->class->vft[COLOR_string__Object__to_s]))(var217) /* to_s on */; ((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var220) /* add on */; @@ -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 */; -CHECK_NEW_array__Array(var247); } var250 = ((val* (*)(val*))(var247->class->vft[COLOR_string__Object__to_s]))(var247) /* to_s on */; ((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var250) /* add on */; } else { } +((void (*)(val*, val*))(self->class->vft[COLOR_separate_compiler__SeparateCompilerVisitor__hardening_cast_type]))(self, var_type_struct) /* hardening_cast_type on */; 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 */; -CHECK_NEW_array__Array(var261); } var264 = ((val* (*)(val*))(var261->class->vft[COLOR_string__Object__to_s]))(var261) /* to_s on */; ((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var264) /* add on */; @@ -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 */; -CHECK_NEW_array__Array(var275); } var278 = ((val* (*)(val*))(var275->class->vft[COLOR_string__Object__to_s]))(var275) /* to_s on */; ((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var278) /* add on */; @@ -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 */; -CHECK_NEW_array__Array(var303); } var306 = ((val* (*)(val*))(var303->class->vft[COLOR_string__Object__to_s]))(var303) /* to_s on */; ((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add_decl]))(self, var306) /* add_decl on */; @@ -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 */; -CHECK_NEW_array__Array(var317); } var320 = ((val* (*)(val*))(var317->class->vft[COLOR_string__Object__to_s]))(var317) /* to_s on */; ((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var320) /* add on */; @@ -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 */; -CHECK_NEW_array__Array(var332); } var335 = ((val* (*)(val*))(var332->class->vft[COLOR_string__Object__to_s]))(var332) /* to_s on */; ((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__require_declaration]))(self, var335) /* require_declaration on */; 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 */; -CHECK_NEW_array__Array(var347); } var350 = ((val* (*)(val*))(var347->class->vft[COLOR_string__Object__to_s]))(var347) /* to_s on */; -((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var350) /* add on */; +((void (*)(val*, val*))(self->class->vft[COLOR_separate_compiler__SeparateCompilerVisitor__hardening_cast_type]))(self, var350) /* hardening_cast_type on */; 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 */; -CHECK_NEW_array__Array(var362); } var365 = ((val* (*)(val*))(var362->class->vft[COLOR_string__Object__to_s]))(var362) /* to_s on */; ((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var365) /* add on */; -var366 = ((val* (*)(val*))(var_compiler->class->vft[COLOR_abstract_compiler__AbstractCompiler__modelbuilder]))(var_compiler) /* modelbuilder on */; -var367 = ((val* (*)(val*))(var366->class->vft[COLOR_modelbuilder__ModelBuilder__toolcontext]))(var366) /* toolcontext on */; -var368 = ((val* (*)(val*))(var367->class->vft[COLOR_abstract_compiler__ToolContext__opt_typing_test_metrics]))(var367) /* opt_typing_test_metrics on */; -var369 = ((val* (*)(val*))(var368->class->vft[COLOR_opts__Option__value]))(var368) /* value on */; -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 */; -var372 = ((val* (*)(val*))(var371->class->vft[COLOR_abstract_compiler__AbstractCompiler__count_type_test_resolved]))(var371) /* count_type_test_resolved on */; -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 */; -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 */; -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 */; +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 */; -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 */; +} +var380 = ((val* (*)(val*))(var377->class->vft[COLOR_string__Object__to_s]))(var377) /* to_s on */; +((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var380) /* add on */; +var381 = ((val* (*)(val*))(var_compiler->class->vft[COLOR_abstract_compiler__AbstractCompiler__modelbuilder]))(var_compiler) /* modelbuilder on */; +var382 = ((val* (*)(val*))(var381->class->vft[COLOR_modelbuilder__ModelBuilder__toolcontext]))(var381) /* toolcontext on */; +var383 = ((val* (*)(val*))(var382->class->vft[COLOR_abstract_compiler__ToolContext__opt_typing_test_metrics]))(var382) /* opt_typing_test_metrics on */; +var384 = ((val* (*)(val*))(var383->class->vft[COLOR_opts__Option__value]))(var383) /* value on */; +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 */; +var387 = ((val* (*)(val*))(var386->class->vft[COLOR_abstract_compiler__AbstractCompiler__count_type_test_resolved]))(var386) /* count_type_test_resolved on */; +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 */; +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 */; +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 */; -((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var395) /* add on */; +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 */; } -if (varonce401) { -var402 = varonce401; +var410 = ((val* (*)(val*))(var407->class->vft[COLOR_string__Object__to_s]))(var407) /* to_s on */; +((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var410) /* add on */; } 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 */; -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 */; -CHECK_NEW_array__Array(var412); -} -var415 = ((val* (*)(val*))(var412->class->vft[COLOR_string__Object__to_s]))(var412) /* to_s on */; -((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var415) /* add on */; -} +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 */; -CHECK_NEW_array__Array(var426); -} -var429 = ((val* (*)(val*))(var426->class->vft[COLOR_string__Object__to_s]))(var426) /* to_s on */; -((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var429) /* add on */; -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 */; -CHECK_NEW_array__Array(var440); -} -var443 = ((val* (*)(val*))(var440->class->vft[COLOR_string__Object__to_s]))(var440) /* to_s on */; -((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var443) /* add on */; -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 */; -} else { -} -var449 = ((val* (*)(val*, val*))(self->class->vft[COLOR_separate_compiler__SeparateCompilerVisitor__type_info]))(self, var_value) /* type_info on */; -var_value_type_info = var449; -var451 = ((val* (*)(val*))(var_compiler->class->vft[COLOR_abstract_compiler__AbstractCompiler__modelbuilder]))(var_compiler) /* modelbuilder on */; -var452 = ((val* (*)(val*))(var451->class->vft[COLOR_modelbuilder__ModelBuilder__toolcontext]))(var451) /* toolcontext on */; -var453 = ((val* (*)(val*))(var452->class->vft[COLOR_separate_compiler__ToolContext__opt_phmod_typing]))(var452) /* opt_phmod_typing on */; -var454 = ((val* (*)(val*))(var453->class->vft[COLOR_opts__Option__value]))(var453) /* value on */; -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 */; -var458 = ((val* (*)(val*))(var457->class->vft[COLOR_modelbuilder__ModelBuilder__toolcontext]))(var457) /* toolcontext on */; -var459 = ((val* (*)(val*))(var458->class->vft[COLOR_separate_compiler__ToolContext__opt_phand_typing]))(var458) /* opt_phand_typing on */; -var460 = ((val* (*)(val*))(var459->class->vft[COLOR_opts__Option__value]))(var459) /* value on */; -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 */; -CHECK_NEW_array__Array(var477); -} -var480 = ((val* (*)(val*))(var477->class->vft[COLOR_string__Object__to_s]))(var477) /* to_s on */; -((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var480) /* add on */; -} 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 */; -CHECK_NEW_array__Array(var496); -} -var499 = ((val* (*)(val*))(var496->class->vft[COLOR_string__Object__to_s]))(var496) /* to_s on */; -((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var499) /* add on */; -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 */; -CHECK_NEW_array__Array(var505); -} -var508 = ((val* (*)(val*))(var505->class->vft[COLOR_string__Object__to_s]))(var505) /* to_s on */; -((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var508) /* add on */; -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 */; -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 */; +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 */; +} +var430 = ((val* (*)(val*))(var427->class->vft[COLOR_string__Object__to_s]))(var427) /* to_s on */; +((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var430) /* add on */; } +} +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 */; +} +var444 = ((val* (*)(val*))(var441->class->vft[COLOR_string__Object__to_s]))(var441) /* to_s on */; +((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var444) /* add on */; +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 */; +} +var458 = ((val* (*)(val*))(var455->class->vft[COLOR_string__Object__to_s]))(var455) /* to_s on */; +((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var458) /* add on */; +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 */; +} else { +} +var464 = ((val* (*)(val*, val*))(self->class->vft[COLOR_separate_compiler__SeparateCompilerVisitor__type_info]))(self, var_value) /* type_info on */; +var_value_type_info = var464; +var466 = ((val* (*)(val*))(var_compiler->class->vft[COLOR_abstract_compiler__AbstractCompiler__modelbuilder]))(var_compiler) /* modelbuilder on */; +var467 = ((val* (*)(val*))(var466->class->vft[COLOR_modelbuilder__ModelBuilder__toolcontext]))(var466) /* toolcontext on */; +var468 = ((val* (*)(val*))(var467->class->vft[COLOR_separate_compiler__ToolContext__opt_phmod_typing]))(var467) /* opt_phmod_typing on */; +var469 = ((val* (*)(val*))(var468->class->vft[COLOR_opts__Option__value]))(var468) /* value on */; +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 */; +var473 = ((val* (*)(val*))(var472->class->vft[COLOR_modelbuilder__ModelBuilder__toolcontext]))(var472) /* toolcontext on */; +var474 = ((val* (*)(val*))(var473->class->vft[COLOR_separate_compiler__ToolContext__opt_phand_typing]))(var473) /* opt_phand_typing on */; +var475 = ((val* (*)(val*))(var474->class->vft[COLOR_opts__Option__value]))(var474) /* value on */; +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 */; +} +var495 = ((val* (*)(val*))(var492->class->vft[COLOR_string__Object__to_s]))(var492) /* to_s on */; +((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var495) /* add on */; +} 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 */; +} +var514 = ((val* (*)(val*))(var511->class->vft[COLOR_string__Object__to_s]))(var511) /* to_s on */; +((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var514) /* add on */; +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 */; +} +var523 = ((val* (*)(val*))(var520->class->vft[COLOR_string__Object__to_s]))(var520) /* to_s on */; +((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var523) /* add on */; 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 */; 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 */; -CHECK_NEW_array__Array(var534); -} -var537 = ((val* (*)(val*))(var534->class->vft[COLOR_string__Object__to_s]))(var534) /* to_s on */; -((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var537) /* add on */; -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 */; +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 */; +} +var552 = ((val* (*)(val*))(var549->class->vft[COLOR_string__Object__to_s]))(var549) /* to_s on */; +((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var552) /* add on */; +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 */; 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 */; +((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var559) /* add on */; } 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 */; -CHECK_NEW_array__Array(var47); } var50 = ((val* (*)(val*))(var47->class->vft[COLOR_string__Object__to_s]))(var47) /* to_s on */; ((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var50) /* add on */; @@ -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 */; -CHECK_NEW_array__Array(var76); } var79 = ((val* (*)(val*))(var76->class->vft[COLOR_string__Object__to_s]))(var76) /* to_s on */; ((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var79) /* add on */; @@ -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 */; -CHECK_NEW_array__Array(var88); } var91 = ((val* (*)(val*))(var88->class->vft[COLOR_string__Object__to_s]))(var88) /* to_s on */; ((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__require_declaration]))(self, var91) /* require_declaration on */; @@ -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 */; -CHECK_NEW_array__Array(var113); } var116 = ((val* (*)(val*))(var113->class->vft[COLOR_string__Object__to_s]))(var113) /* to_s on */; ((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var116) /* add on */; @@ -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 */; -CHECK_NEW_array__Array(var152); } var155 = ((val* (*)(val*))(var152->class->vft[COLOR_string__Object__to_s]))(var152) /* to_s on */; ((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var155) /* add on */; @@ -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 */; -CHECK_NEW_array__Array(var16); } var19 = ((val* (*)(val*))(var16->class->vft[COLOR_string__Object__to_s]))(var16) /* to_s on */; ((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add_decl]))(self, var19) /* add_decl on */; @@ -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 */; -CHECK_NEW_array__Array(var43); } var46 = ((val* (*)(val*))(var43->class->vft[COLOR_string__Object__to_s]))(var43) /* to_s on */; ((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var46) /* add on */; } else { -if (varonce47) { -var48 = varonce47; +var48 = ((val* (*)(val*))(var_value->class->vft[COLOR_abstract_compiler__RuntimeVariable__mtype]))(var_value) /* mtype on */; +/* 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 */; +/* 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 */; +var55 = ((val* (*)(val*))(var54->class->vft[COLOR_model__MClass__kind]))(var54) /* kind on */; +var56 = ((val* (*)(val*))(self->class->vft[COLOR_model__Object__extern_kind]))(self) /* extern_kind on */; +var57 = ((short int (*)(val*, val*))(var55->class->vft[COLOR_kernel__Object___61d_61d]))(var55, var56) /* == on */; +var47 = var57; +} else { +var47 = var_; } -var52 = ((val* (*)(val*))(var_value->class->vft[COLOR_abstract_compiler__RuntimeVariable__mtype]))(var_value) /* mtype on */; -var53 = ((val* (*)(val*))(var52->class->vft[COLOR_abstract_compiler__MType__c_name]))(var52) /* c_name on */; -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 */; -CHECK_NEW_array__Array(var54); -} -var57 = ((val* (*)(val*))(var54->class->vft[COLOR_string__Object__to_s]))(var54) /* to_s on */; -((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__require_declaration]))(self, var57) /* require_declaration on */; +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 */; -var64 = ((val* (*)(val*))(var63->class->vft[COLOR_abstract_compiler__MType__c_name]))(var63) /* c_name on */; -if (varonce65) { -var66 = varonce65; +/* 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 */; -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 */; +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 */; +} +var77 = ((val* (*)(val*))(var74->class->vft[COLOR_string__Object__to_s]))(var74) /* to_s on */; +((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var77) /* add on */; +} 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 */; +var84 = ((val* (*)(val*))(var83->class->vft[COLOR_abstract_compiler__MType__c_name]))(var83) /* c_name on */; +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 */; +} +var88 = ((val* (*)(val*))(var85->class->vft[COLOR_string__Object__to_s]))(var85) /* to_s on */; +((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__require_declaration]))(self, var88) /* require_declaration on */; +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 */; +var95 = ((val* (*)(val*))(var94->class->vft[COLOR_abstract_compiler__MType__c_name]))(var94) /* c_name on */; +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 */; +} +var104 = ((val* (*)(val*))(var101->class->vft[COLOR_string__Object__to_s]))(var101) /* to_s on */; +((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var104) /* add on */; } -var73 = ((val* (*)(val*))(var70->class->vft[COLOR_string__Object__to_s]))(var70) /* to_s on */; -((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var73) /* add on */; } 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 */; -CHECK_NEW_array__Array(var45); } var48 = ((val* (*)(val*))(var45->class->vft[COLOR_string__Object__to_s]))(var45) /* to_s on */; ((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var48) /* add on */; @@ -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 */; -CHECK_NEW_array__Array(var74); } var77 = ((val* (*)(val*))(var74->class->vft[COLOR_string__Object__to_s]))(var74) /* to_s on */; ((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var77) /* add on */; @@ -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 */; -CHECK_NEW_array__Array(var86); } var89 = ((val* (*)(val*))(var86->class->vft[COLOR_string__Object__to_s]))(var86) /* to_s on */; ((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__require_declaration]))(self, var89) /* require_declaration on */; @@ -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 */; -CHECK_NEW_array__Array(var111); } var114 = ((val* (*)(val*))(var111->class->vft[COLOR_string__Object__to_s]))(var111) /* to_s on */; ((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var114) /* add on */; @@ -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 */; -CHECK_NEW_array__Array(var125); } var128 = ((val* (*)(val*))(var125->class->vft[COLOR_string__Object__to_s]))(var125) /* to_s on */; ((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var128) /* add on */; @@ -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 */; -CHECK_NEW_array__Array(var146); } var149 = ((val* (*)(val*))(var146->class->vft[COLOR_string__Object__to_s]))(var146) /* to_s on */; ((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var149) /* add on */; @@ -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 */; -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_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 */; -CHECK_NEW_array__Array(var166); } var169 = ((val* (*)(val*))(var166->class->vft[COLOR_string__Object__to_s]))(var166) /* to_s on */; ((void (*)(val*, val*))(var_test->class->vft[COLOR_abstract_collection__SimpleCollection__add]))(var_test, var169) /* add on */; @@ -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 */; -CHECK_NEW_array__Array(var181); } var184 = ((val* (*)(val*))(var181->class->vft[COLOR_string__Object__to_s]))(var181) /* to_s on */; ((void (*)(val*, val*))(var_test->class->vft[COLOR_abstract_collection__SimpleCollection__add]))(var_test, var184) /* add on */; @@ -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 */; -CHECK_NEW_array__Array(var215); } var218 = ((val* (*)(val*))(var215->class->vft[COLOR_string__Object__to_s]))(var215) /* to_s on */; ((void (*)(val*, val*))(var_test->class->vft[COLOR_abstract_collection__SimpleCollection__add]))(var_test, var218) /* add on */; @@ -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 */; -CHECK_NEW_array__Array(var238); } var241 = ((val* (*)(val*))(var238->class->vft[COLOR_string__Object__to_s]))(var238) /* to_s on */; ((void (*)(val*, val*))(var_test->class->vft[COLOR_abstract_collection__SimpleCollection__add]))(var_test, var241) /* add on */; @@ -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 */; -CHECK_NEW_array__Array(var269); } var272 = ((val* (*)(val*))(var269->class->vft[COLOR_string__Object__to_s]))(var269) /* to_s on */; ((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var272) /* add on */; @@ -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 */; -CHECK_NEW_array__Array(var288); } var291 = ((val* (*)(val*))(var288->class->vft[COLOR_string__Object__to_s]))(var288) /* to_s on */; ((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var291) /* add on */; @@ -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 */; +var299 = ((val* (*)(val*))(var_primitive->class->vft[COLOR_separate_compiler__MType__c_instance_name]))(var_primitive) /* c_instance_name on */; 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 */; +var310 = ((val* (*)(val*))(var_primitive->class->vft[COLOR_separate_compiler__MType__c_instance_name]))(var_primitive) /* c_instance_name on */; 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 */; -CHECK_NEW_array__Array(var321); } var324 = ((val* (*)(val*))(var321->class->vft[COLOR_string__Object__to_s]))(var321) /* to_s on */; ((void (*)(val*, val*))(var_test->class->vft[COLOR_abstract_collection__SimpleCollection__add]))(var_test, var324) /* add on */; @@ -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 */; -CHECK_NEW_array__Array(var339); } var342 = ((val* (*)(val*))(var339->class->vft[COLOR_string__Object__to_s]))(var339) /* to_s on */; ((void (*)(val*, val*))(var_test->class->vft[COLOR_abstract_collection__SimpleCollection__add]))(var_test, var342) /* add on */; var343 = NEW_array__Array(&type_array__Arraystring__String); ((void (*)(val*))(var343->class->vft[COLOR_array__Array__init]))(var343) /* init on */; -CHECK_NEW_array__Array(var343); var_s = var343; var344 = ((val* (*)(val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__compiler]))(self) /* compiler on */; var345 = ((val* (*)(val*))(var344->class->vft[COLOR_separate_compiler__SeparateCompiler__box_kinds]))(var344) /* box_kinds on */; @@ -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 */; +var366 = ((val* (*)(val*))(var_t->class->vft[COLOR_separate_compiler__MClass__c_instance_name]))(var_t) /* c_instance_name on */; 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 */; +var377 = ((val* (*)(val*))(var_t->class->vft[COLOR_separate_compiler__MClass__c_instance_name]))(var_t) /* c_instance_name on */; 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 */; -CHECK_NEW_array__Array(var388); } var392 = ((val* (*)(val*))(var388->class->vft[COLOR_string__Object__to_s]))(var388) /* to_s on */; ((void (*)(val*, val*))(var_s->class->vft[COLOR_abstract_collection__SimpleCollection__add]))(var_s, var392) /* add on */; @@ -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 */; -CHECK_NEW_array__Array(var409); } var412 = ((val* (*)(val*))(var409->class->vft[COLOR_string__Object__to_s]))(var409) /* to_s on */; ((void (*)(val*, val*))(var_test->class->vft[COLOR_abstract_collection__SimpleCollection__add]))(var_test, var412) /* add on */; @@ -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 */; -CHECK_NEW_array__Array(var428); } var431 = ((val* (*)(val*))(var428->class->vft[COLOR_string__Object__to_s]))(var428) /* to_s on */; ((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var431) /* add on */; @@ -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 */; -CHECK_NEW_array__Array(var458); } var461 = ((val* (*)(val*))(var458->class->vft[COLOR_string__Object__to_s]))(var458) /* to_s on */; ((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var461) /* add on */; @@ -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 */; -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_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 */; -CHECK_NEW_array__Array(var32); } var35 = ((val* (*)(val*))(var32->class->vft[COLOR_string__Object__to_s]))(var32) /* to_s on */; ((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var35) /* add on */; @@ -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 */; -CHECK_NEW_range__Range(var39); var44 = ((val* (*)(val*))(var39->class->vft[COLOR_abstract_collection__Collection__iterator]))(var39) /* iterator on */; for(;;) { var45 = ((short int (*)(val*))(var44->class->vft[COLOR_abstract_collection__Iterator__is_ok]))(var44) /* is_ok on */; @@ -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 */; -CHECK_NEW_array__Array(var77); } var81 = ((val* (*)(val*))(var77->class->vft[COLOR_string__Object__to_s]))(var77) /* to_s on */; ((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var81) /* add on */; @@ -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 */; -CHECK_NEW_array__Array(var90); } var93 = ((val* (*)(val*, val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__send]))(self, var89, var90) /* send on */; var93; -((void (*)(val*, val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__check_init_instance]))(self, var_res, var_arraytype) /* check_init_instance on */; 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 */; -CHECK_NEW_array__Array(var6); } var9 = ((val* (*)(val*, val*))(var5->class->vft[COLOR_model__MClass__get_mtype]))(var5, var6) /* get_mtype on */; 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 */; -CHECK_NEW_array__Array(var17); } var20 = ((val* (*)(val*))(var17->class->vft[COLOR_string__Object__to_s]))(var17) /* to_s on */; ((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__require_declaration]))(self, var20) /* require_declaration on */; @@ -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 */; var_compiler = var22; var23 = ((short int (*)(val*))(var_mtype->class->vft[COLOR_model__MType__need_anchor]))(var_mtype) /* need_anchor on */; if (var23){ +((void (*)(val*, val*))(self->class->vft[COLOR_separate_compiler__SeparateCompilerVisitor__hardening_live_open_type]))(self, var_mtype) /* hardening_live_open_type on */; var24 = ((val* (*)(val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__frame]))(self) /* frame on */; 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 */; } @@ -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 */; var27 = ((val* (*)(val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__frame]))(self) /* frame on */; 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 */; } @@ -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 */; -CHECK_NEW_array__Array(var76); } var79 = ((val* (*)(val*))(var76->class->vft[COLOR_string__Object__to_s]))(var76) /* to_s on */; var80 = ((val* (*)(val*, val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__new_expr]))(self, var79, var_mtype) /* new_expr on */; @@ -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 */; -CHECK_NEW_array__Array(var109); } var112 = ((val* (*)(val*))(var109->class->vft[COLOR_string__Object__to_s]))(var109) /* to_s on */; var113 = ((val* (*)(val*, val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__new_expr]))(self, var112, var_mtype) /* new_expr on */; @@ -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 */; -CHECK_NEW_array__Array(var121); } var124 = ((val* (*)(val*))(var121->class->vft[COLOR_string__Object__to_s]))(var121) /* to_s on */; ((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__require_declaration]))(self, var124) /* require_declaration on */; @@ -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 */; -CHECK_NEW_array__Array(var148); } var151 = ((val* (*)(val*))(var148->class->vft[COLOR_string__Object__to_s]))(var148) /* to_s on */; var152 = ((val* (*)(val*, val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__new_expr]))(self, var151, var_mtype) /* new_expr on */;