X-Git-Url: http://nitlanguage.org diff --git a/c_src/separate_erasure_compiler.sep.1.c b/c_src/separate_erasure_compiler.sep.1.c index fb34031..4e47e47 100644 --- a/c_src/separate_erasure_compiler.sep.1.c +++ b/c_src/separate_erasure_compiler.sep.1.c @@ -5,8 +5,9 @@ val* var /* : OptionBool */; val* var1 /* : OptionBool */; var1 = self->attrs[COLOR_separate_erasure_compiler__ToolContext___64dopt_erasure].val; /* @opt_erasure on */ if (var1 == NULL) { -fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Uninitialized attribute @opt_erasure", "src/separate_erasure_compiler.nit", 22); -exit(1); +fprintf(stderr, "Runtime error: %s", "Uninitialized attribute @opt_erasure"); +fprintf(stderr, " (%s:%d)\n", "src/separate_erasure_compiler.nit", 22); +show_backtrace(1); } var = var1; RET_LABEL:; @@ -37,8 +38,9 @@ val* var /* : OptionBool */; val* var1 /* : OptionBool */; var1 = self->attrs[COLOR_separate_erasure_compiler__ToolContext___64dopt_no_check_erasure_cast].val; /* @opt_no_check_erasure_cast on */ if (var1 == NULL) { -fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Uninitialized attribute @opt_no_check_erasure_cast", "src/separate_erasure_compiler.nit", 24); -exit(1); +fprintf(stderr, "Runtime error: %s", "Uninitialized attribute @opt_no_check_erasure_cast"); +fprintf(stderr, " (%s:%d)\n", "src/separate_erasure_compiler.nit", 24); +show_backtrace(1); } var = var1; RET_LABEL:; @@ -82,7 +84,6 @@ var5 = NEW_array__NativeArray(var4, &type_array__NativeArrayopts__Option); ((struct instance_array__NativeArray*)var5)->values[0] = (val*) var1; ((struct instance_array__NativeArray*)var5)->values[1] = (val*) var2; ((void (*)(val*, val*, long))(var3->class->vft[COLOR_array__Array__with_native]))(var3, var5, var4) /* with_native on */; -CHECK_NEW_array__Array(var3); } ((void (*)(val*, val*))(var->class->vft[COLOR_opts__OptionContext__add_option]))(var, var3) /* add_option on */; RET_LABEL:; @@ -92,10 +93,10 @@ void VIRTUAL_separate_erasure_compiler__ToolContext__init(val* self) { separate_erasure_compiler__ToolContext__init(self); RET_LABEL:; } -/* method separate_erasure_compiler#ModelBuilder#run_separate_erasure_compiler for (self: ModelBuilder, MModule, RapidTypeAnalysis) */ +/* method separate_erasure_compiler#ModelBuilder#run_separate_erasure_compiler for (self: ModelBuilder, MModule, nullable RapidTypeAnalysis) */ void separate_erasure_compiler__ModelBuilder__run_separate_erasure_compiler(val* self, val* p0, val* p1) { val* var_mainmodule /* var mainmodule: MModule */; -val* var_runtime_type_analysis /* var runtime_type_analysis: RapidTypeAnalysis */; +val* var_runtime_type_analysis /* var runtime_type_analysis: nullable RapidTypeAnalysis */; long var /* : Int */; long var_time0 /* var time0: Int */; val* var1 /* : ToolContext */; @@ -216,7 +217,6 @@ var6 = 1; ((void (*)(val*, val*, long))(var1->class->vft[COLOR_toolcontext__ToolContext__info]))(var1, var2, var6) /* info on */; var7 = NEW_separate_erasure_compiler__SeparateErasureCompiler(&type_separate_erasure_compiler__SeparateErasureCompiler); ((void (*)(val*, val*, val*, val*))(var7->class->vft[COLOR_separate_erasure_compiler__SeparateErasureCompiler__init]))(var7, var_mainmodule, self, var_runtime_type_analysis) /* init on */; -CHECK_NEW_separate_erasure_compiler__SeparateErasureCompiler(var7); var_compiler = var7; ((void (*)(val*))(var_compiler->class->vft[COLOR_abstract_compiler__AbstractCompiler__compile_header]))(var_compiler) /* compile_header on */; var8 = ((val* (*)(val*))(self->class->vft[COLOR_modelbuilder__ModelBuilder__toolcontext]))(self) /* toolcontext on */; @@ -231,7 +231,7 @@ varonce9 = var10; } var14 = 2; ((void (*)(val*, val*, long))(var8->class->vft[COLOR_toolcontext__ToolContext__info]))(var8, var10, var14) /* info on */; -var15 = ((val* (*)(val*))(var_mainmodule->class->vft[COLOR_model_base__MModule__name]))(var_mainmodule) /* name on */; +var15 = ((val* (*)(val*))(var_mainmodule->class->vft[COLOR_mmodule__MModule__name]))(var_mainmodule) /* name on */; if (varonce16) { var17 = varonce16; } else { @@ -248,13 +248,12 @@ var23 = NEW_array__NativeArray(var22, &type_array__NativeArraykernel__Object); ((struct instance_array__NativeArray*)var23)->values[0] = (val*) var15; ((struct instance_array__NativeArray*)var23)->values[1] = (val*) var17; ((void (*)(val*, val*, long))(var21->class->vft[COLOR_array__Array__with_native]))(var21, var23, var22) /* with_native on */; -CHECK_NEW_array__Array(var21); } var24 = ((val* (*)(val*))(var21->class->vft[COLOR_string__Object__to_s]))(var21) /* to_s on */; var25 = ((val* (*)(val*, val*))(var_compiler->class->vft[COLOR_abstract_compiler__AbstractCompiler__new_file]))(var_compiler, var24) /* new_file on */; var25; ((void (*)(val*))(var_compiler->class->vft[COLOR_separate_compiler__SeparateCompiler__do_property_coloring]))(var_compiler) /* do_property_coloring on */; -var26 = ((val* (*)(val*))(var_mainmodule->class->vft[COLOR_model_base__MModule__in_importation]))(var_mainmodule) /* in_importation on */; +var26 = ((val* (*)(val*))(var_mainmodule->class->vft[COLOR_mmodule__MModule__in_importation]))(var_mainmodule) /* in_importation on */; var27 = ((val* (*)(val*))(var26->class->vft[COLOR_poset__POSetElement__greaters]))(var26) /* greaters on */; var28 = ((val* (*)(val*))(var27->class->vft[COLOR_abstract_collection__Collection__iterator]))(var27) /* iterator on */; for(;;) { @@ -280,13 +279,14 @@ CONTINUE_label35: (void)0; BREAK_label35: (void)0; var36 = ((val* (*)(val*))(var_compiler->class->vft[COLOR_separate_erasure_compiler__SeparateErasureCompiler__vt_layout]))(var_compiler) /* vt_layout on */; if (var36 == NULL) { -fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Reciever is null", "src/separate_erasure_compiler.nit", 52); -exit(1); +fprintf(stderr, "Runtime error: %s", "Receiver is null"); +fprintf(stderr, " (%s:%d)\n", "src/separate_erasure_compiler.nit", 52); +show_backtrace(1); } else { var37 = ((val* (*)(val*))(var36->class->vft[COLOR_layout_builders__Layout__pos]))(var36) /* pos on */; } ((void (*)(val*, val*))(var_compiler->class->vft[COLOR_separate_compiler__SeparateCompiler__compile_color_consts]))(var_compiler, var37) /* compile_color_consts on */; -var38 = ((val* (*)(val*))(var_mainmodule->class->vft[COLOR_model_base__MModule__name]))(var_mainmodule) /* name on */; +var38 = ((val* (*)(val*))(var_mainmodule->class->vft[COLOR_mmodule__MModule__name]))(var_mainmodule) /* name on */; if (varonce39) { var40 = varonce39; } else { @@ -303,13 +303,12 @@ var46 = NEW_array__NativeArray(var45, &type_array__NativeArraykernel__Object); ((struct instance_array__NativeArray*)var46)->values[0] = (val*) var38; ((struct instance_array__NativeArray*)var46)->values[1] = (val*) var40; ((void (*)(val*, val*, long))(var44->class->vft[COLOR_array__Array__with_native]))(var44, var46, var45) /* with_native on */; -CHECK_NEW_array__Array(var44); } var47 = ((val* (*)(val*))(var44->class->vft[COLOR_string__Object__to_s]))(var44) /* to_s on */; var48 = ((val* (*)(val*, val*))(var_compiler->class->vft[COLOR_abstract_compiler__AbstractCompiler__new_file]))(var_compiler, var47) /* new_file on */; var48; ((void (*)(val*))(var_compiler->class->vft[COLOR_abstract_compiler__AbstractCompiler__compile_main_function]))(var_compiler) /* compile_main_function on */; -var49 = ((val* (*)(val*))(var_mainmodule->class->vft[COLOR_model_base__MModule__in_importation]))(var_mainmodule) /* in_importation on */; +var49 = ((val* (*)(val*))(var_mainmodule->class->vft[COLOR_mmodule__MModule__in_importation]))(var_mainmodule) /* in_importation on */; var50 = ((val* (*)(val*))(var49->class->vft[COLOR_poset__POSetElement__greaters]))(var49) /* greaters on */; var51 = ((val* (*)(val*))(var50->class->vft[COLOR_abstract_collection__Collection__iterator]))(var50) /* iterator on */; for(;;) { @@ -334,12 +333,11 @@ var63 = NEW_array__NativeArray(var62, &type_array__NativeArraykernel__Object); ((struct instance_array__NativeArray*)var63)->values[0] = (val*) var57; ((struct instance_array__NativeArray*)var63)->values[1] = (val*) var_m54; ((void (*)(val*, val*, long))(var61->class->vft[COLOR_array__Array__with_native]))(var61, var63, var62) /* with_native on */; -CHECK_NEW_array__Array(var61); } var64 = ((val* (*)(val*))(var61->class->vft[COLOR_string__Object__to_s]))(var61) /* to_s on */; var65 = 2; ((void (*)(val*, val*, long))(var55->class->vft[COLOR_toolcontext__ToolContext__info]))(var55, var64, var65) /* info on */; -var66 = ((val* (*)(val*))(var_m54->class->vft[COLOR_model_base__MModule__name]))(var_m54) /* name on */; +var66 = ((val* (*)(val*))(var_m54->class->vft[COLOR_mmodule__MModule__name]))(var_m54) /* name on */; if (varonce67) { var68 = varonce67; } else { @@ -356,7 +354,6 @@ var74 = NEW_array__NativeArray(var73, &type_array__NativeArraykernel__Object); ((struct instance_array__NativeArray*)var74)->values[0] = (val*) var66; ((struct instance_array__NativeArray*)var74)->values[1] = (val*) var68; ((void (*)(val*, val*, long))(var72->class->vft[COLOR_array__Array__with_native]))(var72, var74, var73) /* with_native on */; -CHECK_NEW_array__Array(var72); } var75 = ((val* (*)(val*))(var72->class->vft[COLOR_string__Object__to_s]))(var72) /* to_s on */; var76 = ((val* (*)(val*, val*))(var_compiler->class->vft[COLOR_abstract_compiler__AbstractCompiler__new_file]))(var_compiler, var75) /* new_file on */; @@ -403,7 +400,6 @@ var96 = BOX_kernel__Int(var85); /* autobox from Int to Object */ ((struct instance_array__NativeArray*)var95)->values[1] = (val*) var96; ((struct instance_array__NativeArray*)var95)->values[2] = (val*) var89; ((void (*)(val*, val*, long))(var93->class->vft[COLOR_array__Array__with_native]))(var93, var95, var94) /* with_native on */; -CHECK_NEW_array__Array(var93); } var97 = ((val* (*)(val*))(var93->class->vft[COLOR_string__Object__to_s]))(var93) /* to_s on */; var98 = 2; @@ -411,7 +407,7 @@ var98 = 2; ((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__ModelBuilder__write_and_make]))(self, var_compiler) /* write_and_make on */; RET_LABEL:; } -/* method separate_erasure_compiler#ModelBuilder#run_separate_erasure_compiler for (self: Object, MModule, RapidTypeAnalysis) */ +/* method separate_erasure_compiler#ModelBuilder#run_separate_erasure_compiler for (self: Object, MModule, nullable RapidTypeAnalysis) */ void VIRTUAL_separate_erasure_compiler__ModelBuilder__run_separate_erasure_compiler(val* self, val* p0, val* p1) { separate_erasure_compiler__ModelBuilder__run_separate_erasure_compiler(self, p0, p1); RET_LABEL:; @@ -472,11 +468,11 @@ void VIRTUAL_separate_erasure_compiler__SeparateErasureCompiler__vt_layout_61d(v separate_erasure_compiler__SeparateErasureCompiler__vt_layout_61d(self, p0); RET_LABEL:; } -/* method separate_erasure_compiler#SeparateErasureCompiler#init for (self: SeparateErasureCompiler, MModule, ModelBuilder, RapidTypeAnalysis) */ +/* method separate_erasure_compiler#SeparateErasureCompiler#init for (self: SeparateErasureCompiler, MModule, ModelBuilder, nullable RapidTypeAnalysis) */ void separate_erasure_compiler__SeparateErasureCompiler__init(val* self, val* p0, val* p1, val* p2) { val* var_mainmodule /* var mainmodule: MModule */; val* var_mmbuilder /* var mmbuilder: ModelBuilder */; -val* var_runtime_type_analysis /* var runtime_type_analysis: RapidTypeAnalysis */; +val* var_runtime_type_analysis /* var runtime_type_analysis: nullable RapidTypeAnalysis */; val* var /* : HashSet[MClass] */; val* var1 /* : Model */; val* var2 /* : Array[MClass] */; @@ -539,11 +535,9 @@ var = NEW_hash_collection__HashSet(&type_hash_collection__HashSetmodel__MClass); var1 = ((val* (*)(val*))(var_mmbuilder->class->vft[COLOR_modelbuilder__ModelBuilder__model]))(var_mmbuilder) /* model on */; var2 = ((val* (*)(val*))(var1->class->vft[COLOR_model__Model__mclasses]))(var1) /* mclasses on */; ((void (*)(val*, val*))(var->class->vft[COLOR_hash_collection__HashSet__from]))(var, var2) /* from on */; -CHECK_NEW_hash_collection__HashSet(var); var_mclasses = var; var3 = NEW_layout_builders__MClassColorer(&type_layout_builders__MClassColorer); ((void (*)(val*, val*))(var3->class->vft[COLOR_layout_builders__MClassColorer__init]))(var3, var_mainmodule) /* init on */; -CHECK_NEW_layout_builders__MClassColorer(var3); var_class_colorer = var3; var4 = ((val* (*)(val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompiler__modelbuilder]))(self) /* modelbuilder on */; var5 = ((val* (*)(val*))(var4->class->vft[COLOR_modelbuilder__ModelBuilder__toolcontext]))(var4) /* toolcontext on */; @@ -554,9 +548,7 @@ if (var8){ var9 = NEW_layout_builders__MClassHasher(&type_layout_builders__MClassHasher); var10 = NEW_layout_builders__PHModOperator(&type_layout_builders__PHModOperator); ((void (*)(val*))(var10->class->vft[COLOR_layout_builders__PHModOperator__init]))(var10) /* init on */; -CHECK_NEW_layout_builders__PHModOperator(var10); ((void (*)(val*, val*, val*))(var9->class->vft[COLOR_layout_builders__MClassHasher__init]))(var9, var10, var_mainmodule) /* init on */; -CHECK_NEW_layout_builders__MClassHasher(var9); var_layout_builder = var9; var11 = ((val* (*)(val*, val*))(var_class_colorer->class->vft[COLOR_layout_builders__TypingLayoutBuilder__build_layout]))(var_class_colorer, var_mclasses) /* build_layout on */; var11; @@ -570,9 +562,7 @@ if (var16){ var17 = NEW_layout_builders__MClassHasher(&type_layout_builders__MClassHasher); var18 = NEW_layout_builders__PHAndOperator(&type_layout_builders__PHAndOperator); ((void (*)(val*))(var18->class->vft[COLOR_layout_builders__PHAndOperator__init]))(var18) /* init on */; -CHECK_NEW_layout_builders__PHAndOperator(var18); ((void (*)(val*, val*, val*))(var17->class->vft[COLOR_layout_builders__MClassHasher__init]))(var17, var18, var_mainmodule) /* init on */; -CHECK_NEW_layout_builders__MClassHasher(var17); var_layout_builder = var17; var19 = ((val* (*)(val*, val*))(var_class_colorer->class->vft[COLOR_layout_builders__TypingLayoutBuilder__build_layout]))(var_class_colorer, var_mclasses) /* build_layout on */; var19; @@ -585,7 +575,6 @@ var24 = ((struct instance_kernel__Bool*)var23)->value; /* autounbox from nullabl if (var24){ var25 = NEW_layout_builders__MClassBMizer(&type_layout_builders__MClassBMizer); ((void (*)(val*, val*))(var25->class->vft[COLOR_layout_builders__MClassBMizer__init]))(var25, var_mainmodule) /* init on */; -CHECK_NEW_layout_builders__MClassBMizer(var25); var_layout_builder = var25; var26 = ((val* (*)(val*, val*))(var_class_colorer->class->vft[COLOR_layout_builders__TypingLayoutBuilder__build_layout]))(var_class_colorer, var_mclasses) /* build_layout on */; var26; @@ -600,7 +589,6 @@ var28 = ((val* (*)(val*, val*))(self->class->vft[COLOR_separate_erasure_compiler ((void (*)(val*, val*))(self->class->vft[COLOR_separate_erasure_compiler__SeparateErasureCompiler__class_tables_61d]))(self, var28) /* class_tables= on */; var29 = NEW_hash_collection__HashMap(&type_hash_collection__HashMapmodel__MClassabstract_collection__Setmodel__MVirtualTypeProp); ((void (*)(val*))(var29->class->vft[COLOR_hash_collection__HashMap__init]))(var29) /* init on */; -CHECK_NEW_hash_collection__HashMap(var29); var_vts = var29; var30 = ((val* (*)(val*))(var_mclasses->class->vft[COLOR_abstract_collection__Collection__iterator]))(var_mclasses) /* iterator on */; for(;;) { @@ -610,7 +598,6 @@ var32 = ((val* (*)(val*))(var30->class->vft[COLOR_abstract_collection__Iterator_ var_mclass = var32; var33 = NEW_hash_collection__HashSet(&type_hash_collection__HashSetmodel__MVirtualTypeProp); ((void (*)(val*))(var33->class->vft[COLOR_hash_collection__HashSet__init]))(var33) /* init on */; -CHECK_NEW_hash_collection__HashSet(var33); ((void (*)(val*, val*, val*))(var_vts->class->vft[COLOR_abstract_collection__Map___91d_93d_61d]))(var_vts, var_mclass, var33) /* []= on */; var34 = ((val* (*)(val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompiler__mainmodule]))(self) /* mainmodule on */; var35 = ((val* (*)(val*, val*))(var34->class->vft[COLOR_abstract_compiler__MModule__properties]))(var34, var_mclass) /* properties on */; @@ -643,7 +630,6 @@ CONTINUE_label41: (void)0; BREAK_label41: (void)0; var42 = NEW_layout_builders__MPropertyColorer(&type_layout_builders__MPropertyColorermodel__MVirtualTypeProp); ((void (*)(val*, val*, val*))(var42->class->vft[COLOR_layout_builders__MPropertyColorer__init]))(var42, var_mainmodule, var_class_colorer) /* init on */; -CHECK_NEW_layout_builders__MPropertyColorer(var42); var_vt_coloring = var42; var43 = ((val* (*)(val*, val*))(var_vt_coloring->class->vft[COLOR_layout_builders__PropertyLayoutBuilder__build_layout]))(var_vt_coloring, var_vts) /* build_layout on */; var_vt_layout = var43; @@ -652,7 +638,7 @@ var44 = ((val* (*)(val*, val*, val*))(self->class->vft[COLOR_separate_erasure_co ((void (*)(val*, val*))(self->class->vft[COLOR_separate_erasure_compiler__SeparateErasureCompiler__vt_layout_61d]))(self, var_vt_layout) /* vt_layout= on */; RET_LABEL:; } -/* method separate_erasure_compiler#SeparateErasureCompiler#init for (self: Object, MModule, ModelBuilder, RapidTypeAnalysis) */ +/* method separate_erasure_compiler#SeparateErasureCompiler#init for (self: Object, MModule, ModelBuilder, nullable RapidTypeAnalysis) */ void VIRTUAL_separate_erasure_compiler__SeparateErasureCompiler__init(val* self, val* p0, val* p1, val* p2) { separate_erasure_compiler__SeparateErasureCompiler__init(self, p0, p1, p2); RET_LABEL:; @@ -704,6 +690,7 @@ short int var31 /* : Bool */; short int var33 /* : Bool */; int cltype34; int idtype35; +const char* var_class_name; short int var36 /* : Bool */; val* var37 /* : Range[Int] */; long var38 /* : Int */; @@ -742,30 +729,30 @@ short int var71 /* : Bool */; short int var73 /* : Bool */; int cltype74; int idtype75; -short int var76 /* : Bool */; -val* var77 /* : Range[Int] */; -long var78 /* : Int */; -val* var79 /* : Discrete */; +const char* var_class_name76; +short int var77 /* : Bool */; +val* var78 /* : Range[Int] */; +long var79 /* : Int */; val* var80 /* : Discrete */; -val* var81 /* : Iterator[nullable Object] */; -short int var82 /* : Bool */; -val* var83 /* : nullable Object */; -long var_i84 /* var i: Int */; -long var85 /* : Int */; -val* var86 /* : null */; -val* var88 /* : Array[MPropDef] */; -val* var89 /* : Iterator[nullable Object] */; -short int var90 /* : Bool */; -val* var91 /* : nullable Object */; -val* var_mpropdef92 /* var mpropdef: MVirtualTypeDef */; -val* var93 /* : MClassDef */; -val* var94 /* : MClass */; -short int var95 /* : Bool */; +val* var81 /* : Discrete */; +val* var82 /* : Iterator[nullable Object] */; +short int var83 /* : Bool */; +val* var84 /* : nullable Object */; +long var_i85 /* var i: Int */; +long var86 /* : Int */; +val* var87 /* : null */; +val* var89 /* : Array[MPropDef] */; +val* var90 /* : Iterator[nullable Object] */; +short int var91 /* : Bool */; +val* var92 /* : nullable Object */; +val* var_mpropdef93 /* var mpropdef: MVirtualTypeDef */; +val* var94 /* : MClassDef */; +val* var95 /* : MClass */; +short int var96 /* : Bool */; var_mclasses = p0; var_layout = p1; var1 = NEW_hash_collection__HashMap(&type_hash_collection__HashMapmodel__MClassarray__Arraynullable_model__MPropDef); ((void (*)(val*))(var1->class->vft[COLOR_hash_collection__HashMap__init]))(var1) /* init on */; -CHECK_NEW_hash_collection__HashMap(var1); var_tables = var1; var2 = ((val* (*)(val*))(var_mclasses->class->vft[COLOR_abstract_collection__Collection__iterator]))(var_mclasses) /* iterator on */; for(;;) { @@ -775,11 +762,9 @@ var4 = ((val* (*)(val*))(var2->class->vft[COLOR_abstract_collection__Iterator__i var_mclass = var4; var5 = NEW_array__Array(&type_array__Arraynullable_model__MPropDef); ((void (*)(val*))(var5->class->vft[COLOR_array__Array__init]))(var5) /* init on */; -CHECK_NEW_array__Array(var5); var_table = var5; var6 = NEW_array__Array(&type_array__Arraymodel__MClass); ((void (*)(val*))(var6->class->vft[COLOR_array__Array__init]))(var6) /* init on */; -CHECK_NEW_array__Array(var6); var_parents = var6; var7 = ((val* (*)(val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompiler__mainmodule]))(self) /* mainmodule on */; var8 = ((val* (*)(val*))(var7->class->vft[COLOR_model__MModule__flatten_mclass_hierarchy]))(var7) /* flatten_mclass_hierarchy on */; @@ -836,8 +821,10 @@ var30 = ((long (*)(val*))(var_table->class->vft[COLOR_abstract_collection__Colle /* isa OTHER */ var33 = 1; /* easy isa OTHER*/ if (!var33) { -fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "lib/standard/kernel.nit", 256); -exit(1); +var_class_name = type_kernel__Int.name; +fprintf(stderr, "Runtime error: Cast failed. Expected `%s`, got `%s`", "OTHER", var_class_name); +fprintf(stderr, " (%s:%d)\n", "lib/standard/kernel.nit", 264); +show_backtrace(1); } var36 = var30 <= var_color; var31 = var36; @@ -850,7 +837,6 @@ var38 = ((long (*)(val*))(var_table->class->vft[COLOR_abstract_collection__Colle var39 = BOX_kernel__Int(var38); /* autobox from Int to Discrete */ var40 = BOX_kernel__Int(var_color); /* autobox from Int to Discrete */ ((void (*)(val*, val*, val*))(var37->class->vft[COLOR_range__Range__without_last]))(var37, var39, var40) /* without_last on */; -CHECK_NEW_range__Range(var37); var41 = ((val* (*)(val*))(var37->class->vft[COLOR_abstract_collection__Collection__iterator]))(var37) /* iterator on */; for(;;) { var42 = ((short int (*)(val*))(var41->class->vft[COLOR_abstract_collection__Iterator__is_ok]))(var41) /* is_ok on */; @@ -923,63 +909,64 @@ var70 = ((long (*)(val*))(var_table->class->vft[COLOR_abstract_collection__Colle /* isa OTHER */ var73 = 1; /* easy isa OTHER*/ if (!var73) { -fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "lib/standard/kernel.nit", 256); -exit(1); +var_class_name76 = type_kernel__Int.name; +fprintf(stderr, "Runtime error: Cast failed. Expected `%s`, got `%s`", "OTHER", var_class_name76); +fprintf(stderr, " (%s:%d)\n", "lib/standard/kernel.nit", 264); +show_backtrace(1); } -var76 = var70 <= var_color69; -var71 = var76; +var77 = var70 <= var_color69; +var71 = var77; goto RET_LABEL72; RET_LABEL72:(void)0; } if (var71){ -var77 = NEW_range__Range(&type_range__Rangekernel__Int); -var78 = ((long (*)(val*))(var_table->class->vft[COLOR_abstract_collection__Collection__length]))(var_table) /* length on */; -var79 = BOX_kernel__Int(var78); /* autobox from Int to Discrete */ -var80 = BOX_kernel__Int(var_color69); /* autobox from Int to Discrete */ -((void (*)(val*, val*, val*))(var77->class->vft[COLOR_range__Range__without_last]))(var77, var79, var80) /* without_last on */; -CHECK_NEW_range__Range(var77); -var81 = ((val* (*)(val*))(var77->class->vft[COLOR_abstract_collection__Collection__iterator]))(var77) /* iterator on */; +var78 = NEW_range__Range(&type_range__Rangekernel__Int); +var79 = ((long (*)(val*))(var_table->class->vft[COLOR_abstract_collection__Collection__length]))(var_table) /* length on */; +var80 = BOX_kernel__Int(var79); /* autobox from Int to Discrete */ +var81 = BOX_kernel__Int(var_color69); /* autobox from Int to Discrete */ +((void (*)(val*, val*, val*))(var78->class->vft[COLOR_range__Range__without_last]))(var78, var80, var81) /* without_last on */; +var82 = ((val* (*)(val*))(var78->class->vft[COLOR_abstract_collection__Collection__iterator]))(var78) /* iterator on */; for(;;) { -var82 = ((short int (*)(val*))(var81->class->vft[COLOR_abstract_collection__Iterator__is_ok]))(var81) /* is_ok on */; -if(!var82) break; -var83 = ((val* (*)(val*))(var81->class->vft[COLOR_abstract_collection__Iterator__item]))(var81) /* item on */; -var85 = ((struct instance_kernel__Int*)var83)->value; /* autounbox from nullable Object to Int */; -var_i84 = var85; -var86 = NULL; -((void (*)(val*, long, val*))(var_table->class->vft[COLOR_abstract_collection__Sequence___91d_93d_61d]))(var_table, var_i84, var86) /* []= on */; -CONTINUE_label87: (void)0; -((void (*)(val*))(var81->class->vft[COLOR_abstract_collection__Iterator__next]))(var81) /* next on */; +var83 = ((short int (*)(val*))(var82->class->vft[COLOR_abstract_collection__Iterator__is_ok]))(var82) /* is_ok on */; +if(!var83) break; +var84 = ((val* (*)(val*))(var82->class->vft[COLOR_abstract_collection__Iterator__item]))(var82) /* item on */; +var86 = ((struct instance_kernel__Int*)var84)->value; /* autounbox from nullable Object to Int */; +var_i85 = var86; +var87 = NULL; +((void (*)(val*, long, val*))(var_table->class->vft[COLOR_abstract_collection__Sequence___91d_93d_61d]))(var_table, var_i85, var87) /* []= on */; +CONTINUE_label88: (void)0; +((void (*)(val*))(var82->class->vft[COLOR_abstract_collection__Iterator__next]))(var82) /* next on */; } -BREAK_label87: (void)0; +BREAK_label88: (void)0; } else { } -var88 = ((val* (*)(val*))(var_mproperty60->class->vft[COLOR_model__MProperty__mpropdefs]))(var_mproperty60) /* mpropdefs on */; -var89 = ((val* (*)(val*))(var88->class->vft[COLOR_abstract_collection__Collection__iterator]))(var88) /* iterator on */; +var89 = ((val* (*)(val*))(var_mproperty60->class->vft[COLOR_model__MProperty__mpropdefs]))(var_mproperty60) /* mpropdefs on */; +var90 = ((val* (*)(val*))(var89->class->vft[COLOR_abstract_collection__Collection__iterator]))(var89) /* iterator on */; for(;;) { -var90 = ((short int (*)(val*))(var89->class->vft[COLOR_abstract_collection__Iterator__is_ok]))(var89) /* is_ok on */; -if(!var90) break; -var91 = ((val* (*)(val*))(var89->class->vft[COLOR_abstract_collection__Iterator__item]))(var89) /* item on */; -var_mpropdef92 = var91; -var93 = ((val* (*)(val*))(var_mpropdef92->class->vft[COLOR_model__MPropDef__mclassdef]))(var_mpropdef92) /* mclassdef on */; -var94 = ((val* (*)(val*))(var93->class->vft[COLOR_model__MClassDef__mclass]))(var93) /* mclass on */; -var95 = ((short int (*)(val*, val*))(var94->class->vft[COLOR_kernel__Object___61d_61d]))(var94, var_mclass) /* == on */; -if (var95){ -((void (*)(val*, long, val*))(var_table->class->vft[COLOR_abstract_collection__Sequence___91d_93d_61d]))(var_table, var_color69, var_mpropdef92) /* []= on */; +var91 = ((short int (*)(val*))(var90->class->vft[COLOR_abstract_collection__Iterator__is_ok]))(var90) /* is_ok on */; +if(!var91) break; +var92 = ((val* (*)(val*))(var90->class->vft[COLOR_abstract_collection__Iterator__item]))(var90) /* item on */; +var_mpropdef93 = var92; +var94 = ((val* (*)(val*))(var_mpropdef93->class->vft[COLOR_model__MPropDef__mclassdef]))(var_mpropdef93) /* mclassdef on */; +var95 = ((val* (*)(val*))(var94->class->vft[COLOR_model__MClassDef__mclass]))(var94) /* mclass on */; +var96 = ((short int (*)(val*, val*))(var95->class->vft[COLOR_kernel__Object___61d_61d]))(var95, var_mclass) /* == on */; +if (var96){ +((void (*)(val*, long, val*))(var_table->class->vft[COLOR_abstract_collection__Sequence___91d_93d_61d]))(var_table, var_color69, var_mpropdef93) /* []= on */; } else { } -CONTINUE_label96: (void)0; -((void (*)(val*))(var89->class->vft[COLOR_abstract_collection__Iterator__next]))(var89) /* next on */; +CONTINUE_label97: (void)0; +((void (*)(val*))(var90->class->vft[COLOR_abstract_collection__Iterator__next]))(var90) /* next on */; } -BREAK_label96: (void)0; +BREAK_label97: (void)0; CONTINUE_label65: (void)0; ((void (*)(val*))(var57->class->vft[COLOR_abstract_collection__Iterator__next]))(var57) /* next on */; } BREAK_label65: (void)0; ((void (*)(val*, val*, val*))(var_tables->class->vft[COLOR_abstract_collection__Map___91d_93d_61d]))(var_tables, var_mclass, var_table) /* []= on */; -CONTINUE_label97: (void)0; +CONTINUE_label98: (void)0; ((void (*)(val*))(var2->class->vft[COLOR_abstract_collection__Iterator__next]))(var2) /* next on */; } -BREAK_label97: (void)0; +BREAK_label98: (void)0; var = var_tables; goto RET_LABEL; RET_LABEL:; @@ -1037,6 +1024,7 @@ short int var27 /* : Bool */; short int var29 /* : Bool */; int cltype30; int idtype31; +const char* var_class_name; short int var32 /* : Bool */; val* var33 /* : Range[Int] */; long var34 /* : Int */; @@ -1051,7 +1039,6 @@ val* var41 /* : null */; var_mclasses = p0; var1 = NEW_hash_collection__HashMap(&type_hash_collection__HashMapmodel__MClassarray__Arraynullable_model__MClass); ((void (*)(val*))(var1->class->vft[COLOR_hash_collection__HashMap__init]))(var1) /* init on */; -CHECK_NEW_hash_collection__HashMap(var1); var_tables = var1; var2 = ((val* (*)(val*))(self->class->vft[COLOR_separate_erasure_compiler__SeparateErasureCompiler__class_layout]))(self) /* class_layout on */; var_layout = var2; @@ -1063,11 +1050,9 @@ var5 = ((val* (*)(val*))(var3->class->vft[COLOR_abstract_collection__Iterator__i var_mclass = var5; var6 = NEW_array__Array(&type_array__Arraynullable_model__MClass); ((void (*)(val*))(var6->class->vft[COLOR_array__Array__init]))(var6) /* init on */; -CHECK_NEW_array__Array(var6); var_table = var6; var7 = NEW_array__Array(&type_array__Arraymodel__MClass); ((void (*)(val*))(var7->class->vft[COLOR_array__Array__init]))(var7) /* init on */; -CHECK_NEW_array__Array(var7); var_supers = var7; var8 = ((val* (*)(val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompiler__mainmodule]))(self) /* mainmodule on */; var9 = ((val* (*)(val*))(var8->class->vft[COLOR_model__MModule__flatten_mclass_hierarchy]))(var8) /* flatten_mclass_hierarchy on */; @@ -1106,8 +1091,9 @@ var22 = ((struct instance_kernel__Int*)var21)->value; /* autounbox from nullable var_color = var22; } else { if (var_layout == NULL) { -fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Reciever is null", "src/separate_erasure_compiler.nit", 182); -exit(1); +fprintf(stderr, "Runtime error: %s", "Receiver is null"); +fprintf(stderr, " (%s:%d)\n", "src/separate_erasure_compiler.nit", 182); +show_backtrace(1); } else { var23 = ((val* (*)(val*))(var_layout->class->vft[COLOR_layout_builders__Layout__pos]))(var_layout) /* pos on */; } @@ -1121,8 +1107,10 @@ var26 = ((long (*)(val*))(var_table->class->vft[COLOR_abstract_collection__Colle /* isa OTHER */ var29 = 1; /* easy isa OTHER*/ if (!var29) { -fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "lib/standard/kernel.nit", 256); -exit(1); +var_class_name = type_kernel__Int.name; +fprintf(stderr, "Runtime error: Cast failed. Expected `%s`, got `%s`", "OTHER", var_class_name); +fprintf(stderr, " (%s:%d)\n", "lib/standard/kernel.nit", 264); +show_backtrace(1); } var32 = var26 <= var_color; var27 = var32; @@ -1135,7 +1123,6 @@ var34 = ((long (*)(val*))(var_table->class->vft[COLOR_abstract_collection__Colle var35 = BOX_kernel__Int(var34); /* autobox from Int to Discrete */ var36 = BOX_kernel__Int(var_color); /* autobox from Int to Discrete */ ((void (*)(val*, val*, val*))(var33->class->vft[COLOR_range__Range__without_last]))(var33, var35, var36) /* without_last on */; -CHECK_NEW_range__Range(var33); var37 = ((val* (*)(val*))(var33->class->vft[COLOR_abstract_collection__Collection__iterator]))(var33) /* iterator on */; for(;;) { var38 = ((short int (*)(val*))(var37->class->vft[COLOR_abstract_collection__Iterator__is_ok]))(var37) /* is_ok on */; @@ -1392,509 +1379,510 @@ val* var1 /* : MClassType */; val* var_mtype /* var mtype: MClassType */; val* var2 /* : String */; val* var_c_name /* var c_name: String */; -val* var3 /* : Map[MClass, Array[nullable MPropDef]] */; -val* var4 /* : nullable Object */; +val* var3 /* : String */; +val* var_c_instance_name /* var c_instance_name: String */; +val* var4 /* : Map[MClass, Array[nullable MPropDef]] */; +val* var5 /* : nullable Object */; val* var_vft /* var vft: Array[nullable MPropDef] */; -val* var5 /* : Map[MClass, Array[nullable MPropDef]] */; -val* var6 /* : nullable Object */; +val* var6 /* : Map[MClass, Array[nullable MPropDef]] */; +val* var7 /* : nullable Object */; val* var_attrs /* var attrs: Array[nullable MPropDef] */; -val* var7 /* : Map[MClass, Array[nullable MClass]] */; -val* var8 /* : nullable Object */; +val* var8 /* : Map[MClass, Array[nullable MClass]] */; +val* var9 /* : nullable Object */; val* var_class_table /* var class_table: Array[nullable MClass] */; -val* var9 /* : AbstractCompilerVisitor */; +val* var10 /* : AbstractCompilerVisitor */; val* var_v /* var v: SeparateCompilerVisitor */; static val* varonce; -val* var10 /* : String */; -char* var11 /* : NativeString */; -long var12 /* : Int */; -val* var13 /* : String */; -static val* varonce14; -val* var15 /* : String */; -char* var16 /* : NativeString */; -long var17 /* : Int */; -val* var18 /* : String */; -val* var19 /* : Array[Object] */; -long var20 /* : Int */; -val* var21 /* : NativeArray[Object] */; -val* var22 /* : String */; -static val* varonce23; -val* var24 /* : String */; -char* var25 /* : NativeString */; -long var26 /* : Int */; -val* var27 /* : String */; -val* var28 /* : Array[Object] */; -long var29 /* : Int */; -val* var30 /* : NativeArray[Object] */; -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 /* : Array[Object] */; -long var43 /* : Int */; -val* var44 /* : NativeArray[Object] */; -val* var45 /* : String */; -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 */; -val* var56 /* : Array[Object] */; -long var57 /* : Int */; -val* var58 /* : NativeArray[Object] */; -val* var59 /* : String */; -static val* varonce60; -val* var61 /* : String */; -char* var62 /* : NativeString */; -long var63 /* : Int */; -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] */; -val* var73 /* : String */; -val* var74 /* : nullable Layout[MClass] */; -val* var75 /* : Map[Object, Int] */; -val* var76 /* : nullable Object */; -static val* varonce77; -val* var78 /* : String */; -char* var79 /* : NativeString */; -long var80 /* : Int */; -val* var81 /* : String */; -val* var82 /* : Array[Object] */; -long var83 /* : Int */; -val* var84 /* : NativeArray[Object] */; -val* var85 /* : String */; -static val* varonce86; -val* var87 /* : String */; -char* var88 /* : NativeString */; -long var89 /* : Int */; -val* var90 /* : String */; +val* var11 /* : String */; +char* var12 /* : NativeString */; +long var13 /* : Int */; +val* var14 /* : String */; +static val* varonce15; +val* var16 /* : String */; +char* var17 /* : NativeString */; +long var18 /* : Int */; +val* var19 /* : String */; +val* var20 /* : Array[Object] */; +long var21 /* : Int */; +val* var22 /* : NativeArray[Object] */; +val* var23 /* : String */; +static val* varonce24; +val* var25 /* : String */; +char* var26 /* : NativeString */; +long var27 /* : Int */; +val* var28 /* : String */; +val* var29 /* : Array[Object] */; +long var30 /* : Int */; +val* var31 /* : NativeArray[Object] */; +val* var32 /* : String */; +static val* varonce33; +val* var34 /* : String */; +char* var35 /* : NativeString */; +long var36 /* : Int */; +val* var37 /* : String */; +static val* varonce38; +val* var39 /* : String */; +char* var40 /* : NativeString */; +long var41 /* : Int */; +val* var42 /* : String */; +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 */; +static val* varonce52; +val* var53 /* : String */; +char* var54 /* : NativeString */; +long var55 /* : Int */; +val* var56 /* : String */; +val* var57 /* : Array[Object] */; +long var58 /* : Int */; +val* var59 /* : NativeArray[Object] */; +val* var60 /* : String */; +static val* varonce61; +val* var62 /* : String */; +char* var63 /* : NativeString */; +long var64 /* : Int */; +val* var65 /* : String */; +static val* varonce66; +val* var67 /* : String */; +char* var68 /* : NativeString */; +long var69 /* : Int */; +val* var70 /* : String */; +val* var71 /* : Array[Object] */; +long var72 /* : Int */; +val* var73 /* : NativeArray[Object] */; +val* var74 /* : String */; +val* var75 /* : nullable Layout[MClass] */; +val* var76 /* : Map[Object, Int] */; +val* var77 /* : nullable Object */; +static val* varonce78; +val* var79 /* : String */; +char* var80 /* : NativeString */; +long var81 /* : Int */; +val* var82 /* : String */; +val* var83 /* : Array[Object] */; +long var84 /* : Int */; +val* var85 /* : NativeArray[Object] */; +val* var86 /* : String */; +static val* varonce87; +val* var88 /* : String */; +char* var89 /* : NativeString */; +long var90 /* : Int */; val* var91 /* : String */; -static val* varonce92; -val* var93 /* : String */; -char* var94 /* : NativeString */; -long var95 /* : Int */; -val* var96 /* : String */; -val* var97 /* : Array[Object] */; -long var98 /* : Int */; -val* var99 /* : NativeArray[Object] */; -val* var100 /* : String */; -long var101 /* : Int */; -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 /* : Object */; -val* var111 /* : String */; -val* var112 /* : nullable Layout[MClass] */; +val* var92 /* : String */; +static val* varonce93; +val* var94 /* : String */; +char* var95 /* : NativeString */; +long var96 /* : Int */; +val* var97 /* : String */; +val* var98 /* : Array[Object] */; +long var99 /* : Int */; +val* var100 /* : NativeArray[Object] */; +val* var101 /* : String */; +long var102 /* : Int */; +static val* varonce103; +val* var104 /* : String */; +char* var105 /* : NativeString */; +long var106 /* : Int */; +val* var107 /* : String */; +val* var108 /* : Array[Object] */; +long var109 /* : Int */; +val* var110 /* : NativeArray[Object] */; +val* var111 /* : Object */; +val* var112 /* : String */; +val* var113 /* : nullable Layout[MClass] */; val* var_layout /* var layout: nullable Layout[MClass] */; -short int var113 /* : Bool */; +short int var114 /* : Bool */; int cltype; int idtype; -val* var114 /* : Map[Object, Int] */; -val* var115 /* : nullable Object */; -static val* varonce116; -val* var117 /* : String */; -char* var118 /* : NativeString */; -long var119 /* : Int */; -val* var120 /* : String */; -val* var121 /* : Array[Object] */; -long var122 /* : Int */; -val* var123 /* : NativeArray[Object] */; -val* var124 /* : String */; -val* var125 /* : Map[Object, Int] */; -val* var126 /* : nullable Object */; -static val* varonce127; -val* var128 /* : String */; -char* var129 /* : NativeString */; -long var130 /* : Int */; -val* var131 /* : String */; -val* var132 /* : Array[Object] */; -long var133 /* : Int */; -val* var134 /* : NativeArray[Object] */; -val* var135 /* : String */; -short int var136 /* : Bool */; -static val* varonce137; -val* var138 /* : String */; -char* var139 /* : NativeString */; -long var140 /* : Int */; -val* var141 /* : String */; -val* var142 /* : Array[Object] */; -long var143 /* : Int */; -val* var144 /* : NativeArray[Object] */; -val* var145 /* : String */; -static val* varonce146; -val* var147 /* : String */; -char* var148 /* : NativeString */; -long var149 /* : Int */; -val* var150 /* : String */; -static val* varonce151; -val* var152 /* : String */; -char* var153 /* : NativeString */; -long var154 /* : Int */; -val* var155 /* : String */; -val* var156 /* : Array[Object] */; -long var157 /* : Int */; -val* var158 /* : NativeArray[Object] */; -val* var159 /* : String */; -static val* varonce160; -val* var161 /* : String */; -char* var162 /* : NativeString */; -long var163 /* : Int */; -val* var164 /* : String */; -static val* varonce165; -val* var166 /* : String */; -char* var167 /* : NativeString */; -long var168 /* : Int */; -val* var169 /* : String */; -static val* varonce170; -val* var171 /* : String */; -char* var172 /* : NativeString */; -long var173 /* : Int */; -val* var174 /* : String */; -val* var175 /* : Array[Object] */; -long var176 /* : Int */; -val* var177 /* : NativeArray[Object] */; -val* var178 /* : String */; -static val* varonce179; -val* var180 /* : String */; -char* var181 /* : NativeString */; -long var182 /* : Int */; -val* var183 /* : String */; -val* var184 /* : Range[Int] */; -long var185 /* : Int */; +val* var115 /* : Map[Object, Int] */; +val* var116 /* : nullable Object */; +static val* varonce117; +val* var118 /* : String */; +char* var119 /* : NativeString */; +long var120 /* : Int */; +val* var121 /* : String */; +val* var122 /* : Array[Object] */; +long var123 /* : Int */; +val* var124 /* : NativeArray[Object] */; +val* var125 /* : String */; +val* var126 /* : Map[Object, Int] */; +val* var127 /* : nullable Object */; +static val* varonce128; +val* var129 /* : String */; +char* var130 /* : NativeString */; +long var131 /* : Int */; +val* var132 /* : String */; +val* var133 /* : Array[Object] */; +long var134 /* : Int */; +val* var135 /* : NativeArray[Object] */; +val* var136 /* : String */; +short int var137 /* : Bool */; +static val* varonce138; +val* var139 /* : String */; +char* var140 /* : NativeString */; +long var141 /* : Int */; +val* var142 /* : String */; +val* var143 /* : Array[Object] */; +long var144 /* : Int */; +val* var145 /* : NativeArray[Object] */; +val* var146 /* : String */; +static val* varonce147; +val* var148 /* : String */; +char* var149 /* : NativeString */; +long var150 /* : Int */; +val* var151 /* : String */; +static val* varonce152; +val* var153 /* : String */; +char* var154 /* : NativeString */; +long var155 /* : Int */; +val* var156 /* : String */; +val* var157 /* : Array[Object] */; +long var158 /* : Int */; +val* var159 /* : NativeArray[Object] */; +val* var160 /* : String */; +static val* varonce161; +val* var162 /* : String */; +char* var163 /* : NativeString */; +long var164 /* : Int */; +val* var165 /* : String */; +static val* varonce166; +val* var167 /* : String */; +char* var168 /* : NativeString */; +long var169 /* : Int */; +val* var170 /* : String */; +static val* varonce171; +val* var172 /* : String */; +char* var173 /* : NativeString */; +long var174 /* : Int */; +val* var175 /* : String */; +val* var176 /* : Array[Object] */; +long var177 /* : Int */; +val* var178 /* : NativeArray[Object] */; +val* var179 /* : String */; +static val* varonce180; +val* var181 /* : String */; +char* var182 /* : NativeString */; +long var183 /* : Int */; +val* var184 /* : String */; +val* var185 /* : Range[Int] */; long var186 /* : Int */; -val* var187 /* : Discrete */; +long var187 /* : Int */; val* var188 /* : Discrete */; -val* var189 /* : Iterator[nullable Object] */; -short int var190 /* : Bool */; -val* var191 /* : nullable Object */; +val* var189 /* : Discrete */; +val* var190 /* : Iterator[nullable Object] */; +short int var191 /* : Bool */; +val* var192 /* : nullable Object */; long var_i /* var i: Int */; -long var192 /* : Int */; -val* var193 /* : nullable Object */; +long var193 /* : Int */; +val* var194 /* : nullable Object */; val* var_mpropdef /* var mpropdef: nullable MPropDef */; -val* var194 /* : null */; -short int var195 /* : Bool */; -static val* varonce196; -val* var197 /* : String */; -char* var198 /* : NativeString */; -long var199 /* : Int */; -val* var200 /* : String */; -short int var201 /* : Bool */; +val* var195 /* : null */; +short int var196 /* : Bool */; +static val* varonce197; +val* var198 /* : String */; +char* var199 /* : NativeString */; +long var200 /* : Int */; +val* var201 /* : String */; short int var202 /* : Bool */; +short int var203 /* : Bool */; short int var_ /* var : Bool */; -val* var203 /* : MClassDef */; -val* var204 /* : MClassType */; -val* var205 /* : String */; -static val* varonce206; -val* var207 /* : String */; -char* var208 /* : NativeString */; -long var209 /* : Int */; -val* var210 /* : String */; -short int var211 /* : Bool */; -static val* varonce212; -val* var213 /* : String */; -char* var214 /* : NativeString */; -long var215 /* : Int */; -val* var216 /* : String */; +val* var204 /* : MClassDef */; +val* var205 /* : MClassType */; +val* var206 /* : String */; +static val* varonce207; +val* var208 /* : String */; +char* var209 /* : NativeString */; +long var210 /* : Int */; +val* var211 /* : String */; +short int var212 /* : Bool */; +static val* varonce213; +val* var214 /* : String */; +char* var215 /* : NativeString */; +long var216 /* : Int */; val* var217 /* : String */; -val* var218 /* : Array[Object] */; -long var219 /* : Int */; -val* var220 /* : NativeArray[Object] */; -val* var221 /* : String */; -static val* varonce222; -val* var223 /* : String */; -char* var224 /* : NativeString */; -long var225 /* : Int */; -val* var226 /* : String */; +val* var218 /* : String */; +val* var219 /* : Array[Object] */; +long var220 /* : Int */; +val* var221 /* : NativeArray[Object] */; +val* var222 /* : String */; +static val* varonce223; +val* var224 /* : String */; +char* var225 /* : NativeString */; +long var226 /* : Int */; val* var227 /* : String */; -static val* varonce228; -val* var229 /* : String */; -char* var230 /* : NativeString */; -long var231 /* : Int */; -val* var232 /* : String */; -val* var233 /* : MModule */; -static val* varonce234; -val* var235 /* : String */; -char* var236 /* : NativeString */; -long var237 /* : Int */; -val* var238 /* : String */; -static val* varonce239; -val* var240 /* : String */; -char* var241 /* : NativeString */; -long var242 /* : Int */; -val* var243 /* : String */; -static val* varonce244; -val* var245 /* : String */; -char* var246 /* : NativeString */; -long var247 /* : Int */; -val* var248 /* : String */; -val* var249 /* : Array[Object] */; -long var250 /* : Int */; -val* var251 /* : NativeArray[Object] */; -val* var252 /* : String */; +val* var228 /* : String */; +static val* varonce229; +val* var230 /* : String */; +char* var231 /* : NativeString */; +long var232 /* : Int */; +val* var233 /* : String */; +val* var234 /* : MModule */; +static val* varonce235; +val* var236 /* : String */; +char* var237 /* : NativeString */; +long var238 /* : Int */; +val* var239 /* : String */; +static val* varonce240; +val* var241 /* : String */; +char* var242 /* : NativeString */; +long var243 /* : Int */; +val* var244 /* : String */; +static val* varonce245; +val* var246 /* : String */; +char* var247 /* : NativeString */; +long var248 /* : Int */; +val* var249 /* : String */; +val* var250 /* : Array[Object] */; +long var251 /* : Int */; +val* var252 /* : NativeArray[Object] */; val* var253 /* : String */; -val* var254 /* : Array[Object] */; -long var255 /* : Int */; -val* var256 /* : NativeArray[Object] */; -val* var257 /* : String */; -static val* varonce258; -val* var259 /* : String */; -char* var260 /* : NativeString */; -long var261 /* : Int */; -val* var262 /* : String */; +val* var254 /* : String */; +val* var255 /* : Array[Object] */; +long var256 /* : Int */; +val* var257 /* : NativeArray[Object] */; +val* var258 /* : String */; +static val* varonce259; +val* var260 /* : String */; +char* var261 /* : NativeString */; +long var262 /* : Int */; val* var263 /* : String */; -static val* varonce264; -val* var265 /* : String */; -char* var266 /* : NativeString */; -long var267 /* : Int */; -val* var268 /* : String */; -val* var269 /* : MModule */; -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 */; -static val* varonce280; -val* var281 /* : String */; -char* var282 /* : NativeString */; -long var283 /* : Int */; -val* var284 /* : String */; -val* var285 /* : Array[Object] */; -long var286 /* : Int */; -val* var287 /* : NativeArray[Object] */; -val* var288 /* : String */; -static val* varonce289; -val* var290 /* : String */; -char* var291 /* : NativeString */; -long var292 /* : Int */; -val* var293 /* : String */; -static val* varonce294; -val* var295 /* : String */; -char* var296 /* : NativeString */; -long var297 /* : Int */; -val* var298 /* : String */; -static val* varonce299; -val* var300 /* : String */; -char* var301 /* : NativeString */; -long var302 /* : Int */; -val* var303 /* : String */; -static val* varonce304; -val* var305 /* : String */; -char* var306 /* : NativeString */; -long var307 /* : Int */; -val* var308 /* : String */; -val* var309 /* : Array[Object] */; -long var310 /* : Int */; -val* var311 /* : NativeArray[Object] */; -val* var312 /* : String */; -long var313 /* : Int */; -static val* varonce314; -val* var315 /* : String */; -char* var316 /* : NativeString */; -long var317 /* : Int */; -val* var318 /* : String */; -val* var319 /* : Array[Object] */; -long var320 /* : Int */; -val* var321 /* : NativeArray[Object] */; -val* var322 /* : Object */; -val* var323 /* : String */; -static val* varonce324; -val* var325 /* : String */; -char* var326 /* : NativeString */; -long var327 /* : Int */; -val* var328 /* : String */; -val* var329 /* : Iterator[nullable Object] */; -short int var330 /* : Bool */; -val* var331 /* : nullable Object */; +val* var264 /* : String */; +static val* varonce265; +val* var266 /* : String */; +char* var267 /* : NativeString */; +long var268 /* : Int */; +val* var269 /* : String */; +val* var270 /* : MModule */; +static val* varonce271; +val* var272 /* : String */; +char* var273 /* : NativeString */; +long var274 /* : Int */; +val* var275 /* : String */; +static val* varonce276; +val* var277 /* : String */; +char* var278 /* : NativeString */; +long var279 /* : Int */; +val* var280 /* : String */; +static val* varonce281; +val* var282 /* : String */; +char* var283 /* : NativeString */; +long var284 /* : Int */; +val* var285 /* : String */; +val* var286 /* : Array[Object] */; +long var287 /* : Int */; +val* var288 /* : NativeArray[Object] */; +val* var289 /* : String */; +static val* varonce290; +val* var291 /* : String */; +char* var292 /* : NativeString */; +long var293 /* : Int */; +val* var294 /* : String */; +static val* varonce295; +val* var296 /* : String */; +char* var297 /* : NativeString */; +long var298 /* : Int */; +val* var299 /* : String */; +static val* varonce300; +val* var301 /* : String */; +char* var302 /* : NativeString */; +long var303 /* : Int */; +val* var304 /* : String */; +static val* varonce305; +val* var306 /* : String */; +char* var307 /* : NativeString */; +long var308 /* : Int */; +val* var309 /* : String */; +val* var310 /* : Array[Object] */; +long var311 /* : Int */; +val* var312 /* : NativeArray[Object] */; +val* var313 /* : String */; +long var314 /* : Int */; +static val* varonce315; +val* var316 /* : String */; +char* var317 /* : NativeString */; +long var318 /* : Int */; +val* var319 /* : String */; +val* var320 /* : Array[Object] */; +long var321 /* : Int */; +val* var322 /* : NativeArray[Object] */; +val* var323 /* : Object */; +val* var324 /* : String */; +static val* varonce325; +val* var326 /* : String */; +char* var327 /* : NativeString */; +long var328 /* : Int */; +val* var329 /* : String */; +val* var330 /* : Iterator[nullable Object] */; +short int var331 /* : Bool */; +val* var332 /* : nullable Object */; val* var_msuper /* var msuper: nullable MClass */; -val* var332 /* : null */; -short int var333 /* : Bool */; -static val* varonce334; -val* var335 /* : String */; -char* var336 /* : NativeString */; -long var337 /* : Int */; -val* var338 /* : String */; -val* var339 /* : nullable Layout[MClass] */; -val* var340 /* : Map[Object, Int] */; -val* var341 /* : nullable Object */; -static val* varonce342; -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* var351 /* : String */; -val* var352 /* : Array[Object] */; -long var353 /* : Int */; -val* var354 /* : NativeArray[Object] */; -val* var355 /* : String */; -static val* varonce357; -val* var358 /* : String */; -char* var359 /* : NativeString */; -long var360 /* : Int */; -val* var361 /* : String */; -static val* varonce362; -val* var363 /* : String */; -char* var364 /* : NativeString */; -long var365 /* : Int */; -val* var366 /* : String */; -val* var367 /* : String */; -static val* varonce368; -val* var369 /* : String */; -char* var370 /* : NativeString */; -long var371 /* : Int */; -val* var372 /* : String */; -short int var373 /* : Bool */; -val* var374 /* : CodeWriter */; -static val* varonce375; -val* var376 /* : String */; -char* var377 /* : NativeString */; -long var378 /* : Int */; +val* var333 /* : null */; +short int var334 /* : Bool */; +static val* varonce335; +val* var336 /* : String */; +char* var337 /* : NativeString */; +long var338 /* : Int */; +val* var339 /* : String */; +val* var340 /* : nullable Layout[MClass] */; +val* var341 /* : Map[Object, Int] */; +val* var342 /* : nullable Object */; +static val* varonce343; +val* var344 /* : String */; +char* var345 /* : NativeString */; +long var346 /* : Int */; +val* var347 /* : String */; +static val* varonce348; +val* var349 /* : String */; +char* var350 /* : NativeString */; +long var351 /* : Int */; +val* var352 /* : String */; +val* var353 /* : Array[Object] */; +long var354 /* : Int */; +val* var355 /* : NativeArray[Object] */; +val* var356 /* : String */; +static val* varonce358; +val* var359 /* : String */; +char* var360 /* : NativeString */; +long var361 /* : Int */; +val* var362 /* : String */; +static val* varonce363; +val* var364 /* : String */; +char* var365 /* : NativeString */; +long var366 /* : Int */; +val* var367 /* : String */; +val* var368 /* : String */; +static val* varonce369; +val* var370 /* : String */; +char* var371 /* : NativeString */; +long var372 /* : Int */; +val* var373 /* : String */; +short int var374 /* : Bool */; +short int var375 /* : Bool */; +val* var376 /* : MClass */; +val* var377 /* : String */; +static val* varonce378; val* var379 /* : String */; -static val* varonce380; -val* var381 /* : String */; -char* var382 /* : NativeString */; -long var383 /* : Int */; -val* var384 /* : String */; -val* var385 /* : Array[Object] */; -long var386 /* : Int */; -val* var387 /* : NativeArray[Object] */; -val* var388 /* : String */; +char* var380 /* : NativeString */; +long var381 /* : Int */; +val* var382 /* : String */; +short int var383 /* : Bool */; +short int var_384 /* var : Bool */; +val* var385 /* : MClass */; +val* var386 /* : MClassKind */; +val* var387 /* : MClassKind */; +short int var388 /* : Bool */; val* var389 /* : CodeWriter */; static val* varonce390; val* var391 /* : String */; char* var392 /* : NativeString */; long var393 /* : Int */; val* var394 /* : String */; -val* var395 /* : CodeWriter */; +static val* varonce395; val* var396 /* : String */; -static val* varonce397; -val* var398 /* : String */; -char* var399 /* : NativeString */; -long var400 /* : Int */; -val* var401 /* : String */; -val* var402 /* : Array[Object] */; -long var403 /* : Int */; -val* var404 /* : NativeArray[Object] */; -val* var405 /* : String */; -val* var406 /* : CodeWriter */; -static val* varonce407; -val* var408 /* : String */; -char* var409 /* : NativeString */; -long var410 /* : Int */; +char* var397 /* : NativeString */; +long var398 /* : Int */; +val* var399 /* : String */; +val* var400 /* : Array[Object] */; +long var401 /* : Int */; +val* var402 /* : NativeArray[Object] */; +val* var403 /* : String */; +val* var404 /* : CodeWriter */; +static val* varonce405; +val* var406 /* : String */; +char* var407 /* : NativeString */; +long var408 /* : Int */; +val* var409 /* : String */; +val* var410 /* : CodeWriter */; val* var411 /* : String */; -val* var412 /* : CodeWriter */; -static val* varonce413; -val* var414 /* : String */; -char* var415 /* : NativeString */; -long var416 /* : Int */; -val* var417 /* : String */; -static val* varonce418; -val* var419 /* : String */; -char* var420 /* : NativeString */; -long var421 /* : Int */; -val* var422 /* : String */; +static val* varonce412; +val* var413 /* : String */; +char* var414 /* : NativeString */; +long var415 /* : Int */; +val* var416 /* : String */; +val* var417 /* : Array[Object] */; +long var418 /* : Int */; +val* var419 /* : NativeArray[Object] */; +val* var420 /* : String */; +val* var421 /* : CodeWriter */; +static val* varonce422; val* var423 /* : String */; -static val* varonce424; -val* var425 /* : String */; -char* var426 /* : NativeString */; -long var427 /* : Int */; +char* var424 /* : NativeString */; +long var425 /* : Int */; +val* var426 /* : String */; +static val* varonce427; val* var428 /* : String */; -val* var429 /* : Array[Object] */; +char* var429 /* : NativeString */; long var430 /* : Int */; -val* var431 /* : NativeArray[Object] */; -val* var432 /* : String */; -static val* varonce433; -val* var434 /* : String */; -char* var435 /* : NativeString */; -long var436 /* : Int */; +val* var431 /* : String */; +val* var432 /* : Array[Object] */; +long var433 /* : Int */; +val* var434 /* : NativeArray[Object] */; +val* var435 /* : String */; +static val* varonce436; val* var437 /* : String */; -static val* varonce438; -val* var439 /* : String */; -char* var440 /* : NativeString */; -long var441 /* : Int */; +char* var438 /* : NativeString */; +long var439 /* : Int */; +val* var440 /* : String */; +static val* varonce441; val* var442 /* : String */; -val* var443 /* : Array[Object] */; +char* var443 /* : NativeString */; long var444 /* : Int */; -val* var445 /* : NativeArray[Object] */; +val* var445 /* : String */; val* var446 /* : String */; static val* varonce447; val* var448 /* : String */; char* var449 /* : NativeString */; long var450 /* : Int */; val* var451 /* : String */; -val* var452 /* : String */; -static val* varonce453; -val* var454 /* : String */; -char* var455 /* : NativeString */; -long var456 /* : Int */; +val* var452 /* : Array[Object] */; +long var453 /* : Int */; +val* var454 /* : NativeArray[Object] */; +val* var455 /* : String */; +static val* varonce456; val* var457 /* : String */; -val* var458 /* : String */; -static val* varonce459; +char* var458 /* : NativeString */; +long var459 /* : Int */; val* var460 /* : String */; -char* var461 /* : NativeString */; -long var462 /* : Int */; -val* var463 /* : String */; -val* var464 /* : Array[Object] */; -long var465 /* : Int */; -val* var466 /* : NativeArray[Object] */; -val* var467 /* : String */; -static val* varonce468; +static val* varonce461; +val* var462 /* : String */; +char* var463 /* : NativeString */; +long var464 /* : Int */; +val* var465 /* : String */; +val* var466 /* : Array[Object] */; +long var467 /* : Int */; +val* var468 /* : NativeArray[Object] */; val* var469 /* : String */; -char* var470 /* : NativeString */; -long var471 /* : Int */; -val* var472 /* : String */; -static val* varonce473; +static val* varonce470; +val* var471 /* : String */; +char* var472 /* : NativeString */; +long var473 /* : Int */; val* var474 /* : String */; -char* var475 /* : NativeString */; -long var476 /* : Int */; +val* var475 /* : String */; +static val* varonce476; val* var477 /* : String */; -static val* varonce478; -val* var479 /* : String */; -char* var480 /* : NativeString */; -long var481 /* : Int */; -val* var482 /* : String */; -val* var483 /* : Array[Object] */; -long var484 /* : Int */; -val* var485 /* : NativeArray[Object] */; +char* var478 /* : NativeString */; +long var479 /* : Int */; +val* var480 /* : String */; +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* var487 /* : Array[Object] */; +long var488 /* : Int */; +val* var489 /* : NativeArray[Object] */; +val* var490 /* : String */; +static val* varonce491; +val* var492 /* : String */; +char* var493 /* : NativeString */; +long var494 /* : Int */; val* var495 /* : String */; static val* varonce496; val* var497 /* : String */; @@ -1915,24 +1903,24 @@ val* var511 /* : String */; char* var512 /* : NativeString */; long var513 /* : Int */; val* var514 /* : String */; -static val* varonce515; -val* var516 /* : String */; -char* var517 /* : NativeString */; -long var518 /* : Int */; -val* var519 /* : String */; -static val* varonce520; -val* var521 /* : String */; -char* var522 /* : NativeString */; -long var523 /* : Int */; -val* var524 /* : String */; +val* var515 /* : Array[Object] */; +long var516 /* : Int */; +val* var517 /* : NativeArray[Object] */; +val* var518 /* : String */; +static val* varonce519; +val* var520 /* : String */; +char* var521 /* : NativeString */; +long var522 /* : Int */; +val* var523 /* : String */; +static val* varonce524; val* var525 /* : String */; -static val* varonce526; -val* var527 /* : String */; -char* var528 /* : NativeString */; -long var529 /* : Int */; -val* var530 /* : String */; -short int var531 /* : Bool */; -val* var532 /* : CodeWriter */; +char* var526 /* : NativeString */; +long var527 /* : Int */; +val* var528 /* : String */; +val* var529 /* : Array[Object] */; +long var530 /* : Int */; +val* var531 /* : NativeArray[Object] */; +val* var532 /* : String */; static val* varonce533; val* var534 /* : String */; char* var535 /* : NativeString */; @@ -1943,92 +1931,90 @@ val* var539 /* : String */; char* var540 /* : NativeString */; long var541 /* : Int */; val* var542 /* : String */; -val* var543 /* : Array[Object] */; -long var544 /* : Int */; -val* var545 /* : NativeArray[Object] */; -val* var546 /* : String */; -val* var547 /* : CodeWriter */; -static val* varonce548; -val* var549 /* : String */; -char* var550 /* : NativeString */; -long var551 /* : Int */; -val* var552 /* : String */; -val* var553 /* : CodeWriter */; -static val* varonce554; -val* var555 /* : String */; -char* var556 /* : NativeString */; -long var557 /* : Int */; -val* var558 /* : String */; -val* var559 /* : CodeWriter */; -static val* varonce560; -val* var561 /* : String */; -char* var562 /* : NativeString */; -long var563 /* : Int */; -val* var564 /* : String */; -static val* varonce565; -val* var566 /* : String */; -char* var567 /* : NativeString */; -long var568 /* : Int */; +static val* varonce543; +val* var544 /* : String */; +char* var545 /* : NativeString */; +long var546 /* : Int */; +val* var547 /* : String */; +val* var548 /* : String */; +static val* varonce549; +val* var550 /* : String */; +char* var551 /* : NativeString */; +long var552 /* : Int */; +val* var553 /* : String */; +short int var554 /* : Bool */; +val* var555 /* : CodeWriter */; +static val* varonce556; +val* var557 /* : String */; +char* var558 /* : NativeString */; +long var559 /* : Int */; +val* var560 /* : String */; +static val* varonce561; +val* var562 /* : String */; +char* var563 /* : NativeString */; +long var564 /* : Int */; +val* var565 /* : String */; +val* var566 /* : Array[Object] */; +long var567 /* : Int */; +val* var568 /* : NativeArray[Object] */; val* var569 /* : String */; -val* var570 /* : Array[Object] */; -long var571 /* : Int */; -val* var572 /* : NativeArray[Object] */; -val* var573 /* : String */; -val* var574 /* : String */; -static val* varonce575; -val* var576 /* : String */; -char* var577 /* : NativeString */; -long var578 /* : Int */; -val* var579 /* : String */; -static val* varonce580; +val* var570 /* : CodeWriter */; +static val* varonce571; +val* var572 /* : String */; +char* var573 /* : NativeString */; +long var574 /* : Int */; +val* var575 /* : String */; +val* var576 /* : CodeWriter */; +static val* varonce577; +val* var578 /* : String */; +char* var579 /* : NativeString */; +long var580 /* : Int */; val* var581 /* : String */; -char* var582 /* : NativeString */; -long var583 /* : Int */; +val* var582 /* : CodeWriter */; +static val* varonce583; val* var584 /* : String */; -val* var585 /* : Array[Object] */; +char* var585 /* : NativeString */; long var586 /* : Int */; -val* var587 /* : NativeArray[Object] */; -val* var588 /* : String */; -static val* varonce589; -val* var590 /* : String */; -char* var591 /* : NativeString */; -long var592 /* : Int */; -val* var593 /* : String */; -static val* varonce594; -val* var595 /* : String */; -char* var596 /* : NativeString */; -long var597 /* : Int */; -val* var598 /* : String */; -val* var599 /* : Array[Object] */; -long var600 /* : Int */; -val* var601 /* : NativeArray[Object] */; +val* var587 /* : String */; +static val* varonce588; +val* var589 /* : String */; +char* var590 /* : NativeString */; +long var591 /* : Int */; +val* var592 /* : String */; +val* var593 /* : Array[Object] */; +long var594 /* : Int */; +val* var595 /* : NativeArray[Object] */; +val* var596 /* : String */; +val* var597 /* : String */; +static val* varonce598; +val* var599 /* : String */; +char* var600 /* : NativeString */; +long var601 /* : Int */; val* var602 /* : String */; -val* var603 /* : String */; -static val* varonce604; -val* var605 /* : String */; -char* var606 /* : NativeString */; -long var607 /* : Int */; -val* var608 /* : String */; -static val* varonce609; -val* var610 /* : String */; -char* var611 /* : NativeString */; -long var612 /* : Int */; +static val* varonce603; +val* var604 /* : String */; +char* var605 /* : NativeString */; +long var606 /* : Int */; +val* var607 /* : String */; +val* var608 /* : Array[Object] */; +long var609 /* : Int */; +val* var610 /* : NativeArray[Object] */; +val* var611 /* : String */; +static val* varonce612; val* var613 /* : String */; -val* var614 /* : Array[Object] */; +char* var614 /* : NativeString */; long var615 /* : Int */; -val* var616 /* : NativeArray[Object] */; -val* var617 /* : String */; -static val* varonce618; -val* var619 /* : String */; -char* var620 /* : NativeString */; -long var621 /* : Int */; -val* var622 /* : String */; -val* var623 /* : RuntimeVariable */; -val* var_res /* var res: RuntimeVariable */; -short int var624 /* : Bool */; -val* var625 /* : Array[MType] */; -val* var626 /* : nullable Object */; -val* var_mtype_elt /* var mtype_elt: MType */; +val* var616 /* : String */; +static val* varonce617; +val* var618 /* : String */; +char* var619 /* : NativeString */; +long var620 /* : Int */; +val* var621 /* : String */; +val* var622 /* : Array[Object] */; +long var623 /* : Int */; +val* var624 /* : NativeArray[Object] */; +val* var625 /* : String */; +val* var626 /* : String */; static val* varonce627; val* var628 /* : String */; char* var629 /* : NativeString */; @@ -2039,29 +2025,31 @@ val* var633 /* : String */; char* var634 /* : NativeString */; long var635 /* : Int */; val* var636 /* : String */; -val* var637 /* : String */; -static val* varonce638; -val* var639 /* : String */; -char* var640 /* : NativeString */; -long var641 /* : Int */; +val* var637 /* : Array[Object] */; +long var638 /* : Int */; +val* var639 /* : NativeArray[Object] */; +val* var640 /* : String */; +static val* varonce641; val* var642 /* : String */; -val* var643 /* : Array[Object] */; +char* var643 /* : NativeString */; long var644 /* : Int */; -val* var645 /* : NativeArray[Object] */; -val* var646 /* : String */; -static val* varonce647; -val* var648 /* : String */; -char* var649 /* : NativeString */; -long var650 /* : Int */; +val* var645 /* : String */; +val* var646 /* : RuntimeVariable */; +val* var_res /* var res: RuntimeVariable */; +short int var647 /* : Bool */; +val* var648 /* : Array[MType] */; +val* var649 /* : nullable Object */; +val* var_mtype_elt /* var mtype_elt: MType */; +static val* varonce650; val* var651 /* : String */; -val* var652 /* : Array[Object] */; +char* var652 /* : NativeString */; long var653 /* : Int */; -val* var654 /* : NativeArray[Object] */; -val* var655 /* : String */; -static val* varonce656; -val* var657 /* : String */; -char* var658 /* : NativeString */; -long var659 /* : Int */; +val* var654 /* : String */; +static val* varonce655; +val* var656 /* : String */; +char* var657 /* : NativeString */; +long var658 /* : Int */; +val* var659 /* : String */; val* var660 /* : String */; static val* varonce661; val* var662 /* : String */; @@ -2077,87 +2065,87 @@ val* var671 /* : String */; char* var672 /* : NativeString */; long var673 /* : Int */; val* var674 /* : String */; -static val* varonce675; -val* var676 /* : String */; -char* var677 /* : NativeString */; -long var678 /* : Int */; -val* var679 /* : String */; -val* var680 /* : Array[Object] */; -long var681 /* : Int */; -val* var682 /* : NativeArray[Object] */; +val* var675 /* : Array[Object] */; +long var676 /* : Int */; +val* var677 /* : NativeArray[Object] */; +val* var678 /* : String */; +static val* varonce679; +val* var680 /* : String */; +char* var681 /* : NativeString */; +long var682 /* : Int */; val* var683 /* : String */; static val* varonce684; val* var685 /* : String */; char* var686 /* : NativeString */; long var687 /* : Int */; val* var688 /* : String */; -static val* varonce689; -val* var690 /* : String */; -char* var691 /* : NativeString */; -long var692 /* : Int */; -val* var693 /* : String */; -val* var694 /* : Array[Object] */; -long var695 /* : Int */; -val* var696 /* : NativeArray[Object] */; +val* var689 /* : Array[Object] */; +long var690 /* : Int */; +val* var691 /* : NativeArray[Object] */; +val* var692 /* : String */; +static val* varonce693; +val* var694 /* : String */; +char* var695 /* : NativeString */; +long var696 /* : Int */; val* var697 /* : String */; -val* var698 /* : String */; -static val* varonce699; -val* var700 /* : String */; -char* var701 /* : NativeString */; -long var702 /* : Int */; -val* var703 /* : String */; -static val* varonce704; -val* var705 /* : String */; -char* var706 /* : NativeString */; -long var707 /* : Int */; +static val* varonce698; +val* var699 /* : String */; +char* var700 /* : NativeString */; +long var701 /* : Int */; +val* var702 /* : String */; +val* var703 /* : Array[Object] */; +long var704 /* : Int */; +val* var705 /* : NativeArray[Object] */; +val* var706 /* : String */; +static val* varonce707; val* var708 /* : String */; -val* var709 /* : Array[Object] */; +char* var709 /* : NativeString */; long var710 /* : Int */; -val* var711 /* : NativeArray[Object] */; -val* var712 /* : String */; -static val* varonce713; -val* var714 /* : String */; -char* var715 /* : NativeString */; -long var716 /* : Int */; -val* var717 /* : String */; -static val* varonce718; -val* var719 /* : String */; -char* var720 /* : NativeString */; -long var721 /* : Int */; -val* var722 /* : String */; -val* var723 /* : Array[Object] */; -long var724 /* : Int */; -val* var725 /* : NativeArray[Object] */; +val* var711 /* : String */; +static val* varonce712; +val* var713 /* : String */; +char* var714 /* : NativeString */; +long var715 /* : Int */; +val* var716 /* : String */; +val* var717 /* : Array[Object] */; +long var718 /* : Int */; +val* var719 /* : NativeArray[Object] */; +val* var720 /* : String */; +val* var721 /* : String */; +static val* varonce722; +val* var723 /* : String */; +char* var724 /* : NativeString */; +long var725 /* : Int */; val* var726 /* : String */; -val* var727 /* : String */; -static val* varonce728; -val* var729 /* : String */; -char* var730 /* : NativeString */; -long var731 /* : Int */; -val* var732 /* : String */; -static val* varonce733; -val* var734 /* : String */; -char* var735 /* : NativeString */; -long var736 /* : Int */; +static val* varonce727; +val* var728 /* : String */; +char* var729 /* : NativeString */; +long var730 /* : Int */; +val* var731 /* : String */; +val* var732 /* : Array[Object] */; +long var733 /* : Int */; +val* var734 /* : NativeArray[Object] */; +val* var735 /* : String */; +static val* varonce736; val* var737 /* : String */; -val* var738 /* : Array[Object] */; +char* var738 /* : NativeString */; long var739 /* : Int */; -val* var740 /* : NativeArray[Object] */; -val* var741 /* : String */; -static val* varonce742; -val* var743 /* : String */; -char* var744 /* : NativeString */; -long var745 /* : Int */; -val* var746 /* : String */; -val* var747 /* : RuntimeVariable */; -val* var_res748 /* var res: RuntimeVariable */; -short int var749 /* : Bool */; -static val* varonce750; -val* var751 /* : String */; -char* var752 /* : NativeString */; -long var753 /* : Int */; -val* var754 /* : String */; -long var755 /* : Int */; +val* var740 /* : String */; +static val* varonce741; +val* var742 /* : String */; +char* var743 /* : NativeString */; +long var744 /* : Int */; +val* var745 /* : String */; +val* var746 /* : Array[Object] */; +long var747 /* : Int */; +val* var748 /* : NativeArray[Object] */; +val* var749 /* : String */; +val* var750 /* : String */; +static val* varonce751; +val* var752 /* : String */; +char* var753 /* : NativeString */; +long var754 /* : Int */; +val* var755 /* : String */; static val* varonce756; val* var757 /* : String */; char* var758 /* : NativeString */; @@ -2166,1120 +2154,1112 @@ val* var760 /* : String */; val* var761 /* : Array[Object] */; long var762 /* : Int */; val* var763 /* : NativeArray[Object] */; -val* var764 /* : Object */; -val* var765 /* : String */; -static val* varonce766; -val* var767 /* : String */; -char* var768 /* : NativeString */; -long var769 /* : Int */; -val* var770 /* : String */; -val* var771 /* : Array[Object] */; -long var772 /* : Int */; -val* var773 /* : NativeArray[Object] */; +val* var764 /* : String */; +static val* varonce765; +val* var766 /* : String */; +char* var767 /* : NativeString */; +long var768 /* : Int */; +val* var769 /* : String */; +val* var770 /* : RuntimeVariable */; +val* var_res771 /* var res: RuntimeVariable */; +short int var772 /* : Bool */; +static val* varonce773; val* var774 /* : String */; -static val* varonce775; -val* var776 /* : String */; -char* var777 /* : NativeString */; +char* var775 /* : NativeString */; +long var776 /* : Int */; +val* var777 /* : String */; long var778 /* : Int */; -val* var779 /* : String */; -static val* varonce780; -val* var781 /* : String */; -char* var782 /* : NativeString */; -long var783 /* : Int */; -val* var784 /* : String */; -val* var785 /* : Array[Object] */; -long var786 /* : Int */; -val* var787 /* : NativeArray[Object] */; +static val* varonce779; +val* var780 /* : String */; +char* var781 /* : NativeString */; +long var782 /* : Int */; +val* var783 /* : String */; +val* var784 /* : Array[Object] */; +long var785 /* : Int */; +val* var786 /* : NativeArray[Object] */; +val* var787 /* : Object */; val* var788 /* : String */; static val* varonce789; val* var790 /* : String */; char* var791 /* : NativeString */; long var792 /* : Int */; val* var793 /* : String */; -static val* varonce794; -val* var795 /* : String */; -char* var796 /* : NativeString */; -long var797 /* : Int */; -val* var798 /* : String */; -val* var799 /* : Array[Object] */; -long var800 /* : Int */; -val* var801 /* : NativeArray[Object] */; +val* var794 /* : Array[Object] */; +long var795 /* : Int */; +val* var796 /* : NativeArray[Object] */; +val* var797 /* : String */; +static val* varonce798; +val* var799 /* : String */; +char* var800 /* : NativeString */; +long var801 /* : Int */; val* var802 /* : String */; static val* varonce803; val* var804 /* : String */; char* var805 /* : NativeString */; long var806 /* : Int */; val* var807 /* : String */; +val* var808 /* : Array[Object] */; +long var809 /* : Int */; +val* var810 /* : NativeArray[Object] */; +val* var811 /* : String */; +static val* varonce812; +val* var813 /* : String */; +char* var814 /* : NativeString */; +long var815 /* : Int */; +val* var816 /* : String */; +static val* varonce817; +val* var818 /* : String */; +char* var819 /* : NativeString */; +long var820 /* : Int */; +val* var821 /* : String */; +val* var822 /* : Array[Object] */; +long var823 /* : Int */; +val* var824 /* : NativeArray[Object] */; +val* var825 /* : String */; +static val* varonce826; +val* var827 /* : String */; +char* var828 /* : NativeString */; +long var829 /* : Int */; +val* var830 /* : String */; var_mclass = p0; var = ((val* (*)(val*))(var_mclass->class->vft[COLOR_model__MClass__intro]))(var_mclass) /* intro on */; var1 = ((val* (*)(val*))(var->class->vft[COLOR_model__MClassDef__bound_mtype]))(var) /* bound_mtype on */; var_mtype = var1; var2 = ((val* (*)(val*))(var_mclass->class->vft[COLOR_abstract_compiler__MClass__c_name]))(var_mclass) /* c_name on */; var_c_name = var2; -var3 = ((val* (*)(val*))(self->class->vft[COLOR_separate_compiler__SeparateCompiler__method_tables]))(self) /* method_tables on */; -var4 = ((val* (*)(val*, val*))(var3->class->vft[COLOR_abstract_collection__MapRead___91d_93d]))(var3, var_mclass) /* [] on */; -var_vft = var4; -var5 = ((val* (*)(val*))(self->class->vft[COLOR_separate_compiler__SeparateCompiler__attr_tables]))(self) /* attr_tables on */; -var6 = ((val* (*)(val*, val*))(var5->class->vft[COLOR_abstract_collection__MapRead___91d_93d]))(var5, var_mclass) /* [] on */; -var_attrs = var6; -var7 = ((val* (*)(val*))(self->class->vft[COLOR_separate_erasure_compiler__SeparateErasureCompiler__class_tables]))(self) /* class_tables on */; -var8 = ((val* (*)(val*, val*))(var7->class->vft[COLOR_abstract_collection__MapRead___91d_93d]))(var7, var_mclass) /* [] on */; -var_class_table = var8; -var9 = ((val* (*)(val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompiler__new_visitor]))(self) /* new_visitor on */; -var_v = var9; +var3 = ((val* (*)(val*))(var_mclass->class->vft[COLOR_separate_compiler__MClass__c_instance_name]))(var_mclass) /* c_instance_name on */; +var_c_instance_name = var3; +var4 = ((val* (*)(val*))(self->class->vft[COLOR_separate_compiler__SeparateCompiler__method_tables]))(self) /* method_tables on */; +var5 = ((val* (*)(val*, val*))(var4->class->vft[COLOR_abstract_collection__MapRead___91d_93d]))(var4, var_mclass) /* [] on */; +var_vft = var5; +var6 = ((val* (*)(val*))(self->class->vft[COLOR_separate_compiler__SeparateCompiler__attr_tables]))(self) /* attr_tables on */; +var7 = ((val* (*)(val*, val*))(var6->class->vft[COLOR_abstract_collection__MapRead___91d_93d]))(var6, var_mclass) /* [] on */; +var_attrs = var7; +var8 = ((val* (*)(val*))(self->class->vft[COLOR_separate_erasure_compiler__SeparateErasureCompiler__class_tables]))(self) /* class_tables on */; +var9 = ((val* (*)(val*, val*))(var8->class->vft[COLOR_abstract_collection__MapRead___91d_93d]))(var8, var_mclass) /* [] on */; +var_class_table = var9; +var10 = ((val* (*)(val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompiler__new_visitor]))(self) /* new_visitor on */; +var_v = var10; if (varonce) { -var10 = varonce; -} else { -var11 = "/* runtime class "; -var12 = 17; -var13 = string__NativeString__to_s_with_length(var11, var12); -var10 = var13; -varonce = var10; -} -if (varonce14) { -var15 = varonce14; -} else { -var16 = " */"; -var17 = 3; -var18 = string__NativeString__to_s_with_length(var16, var17); -var15 = var18; -varonce14 = var15; -} -var19 = NEW_array__Array(&type_array__Arraykernel__Object); -{ /* var19 = array_instance Array[Object] */ -var20 = 3; -var21 = NEW_array__NativeArray(var20, &type_array__NativeArraykernel__Object); -((struct instance_array__NativeArray*)var21)->values[0] = (val*) var10; -((struct instance_array__NativeArray*)var21)->values[1] = (val*) var_c_name; -((struct instance_array__NativeArray*)var21)->values[2] = (val*) var15; -((void (*)(val*, val*, long))(var19->class->vft[COLOR_array__Array__with_native]))(var19, var21, var20) /* with_native on */; -CHECK_NEW_array__Array(var19); -} -var22 = ((val* (*)(val*))(var19->class->vft[COLOR_string__Object__to_s]))(var19) /* to_s on */; -((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add_decl]))(var_v, var22) /* add_decl on */; -if (varonce23) { -var24 = varonce23; -} else { -var25 = "class_"; -var26 = 6; -var27 = string__NativeString__to_s_with_length(var25, var26); -var24 = var27; -varonce23 = var24; -} -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*) var24; -((struct instance_array__NativeArray*)var30)->values[1] = (val*) var_c_name; -((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 */; -if (varonce32) { -var33 = varonce32; -} else { -var34 = "extern const struct class class_"; -var35 = 32; -var36 = string__NativeString__to_s_with_length(var34, var35); -var33 = var36; -varonce32 = var33; -} -if (varonce37) { -var38 = varonce37; +var11 = varonce; +} else { +var12 = "/* runtime class "; +var13 = 17; +var14 = string__NativeString__to_s_with_length(var12, var13); +var11 = var14; +varonce = var11; +} +if (varonce15) { +var16 = varonce15; +} else { +var17 = " */"; +var18 = 3; +var19 = string__NativeString__to_s_with_length(var17, var18); +var16 = var19; +varonce15 = var16; +} +var20 = NEW_array__Array(&type_array__Arraykernel__Object); +{ /* var20 = array_instance Array[Object] */ +var21 = 3; +var22 = NEW_array__NativeArray(var21, &type_array__NativeArraykernel__Object); +((struct instance_array__NativeArray*)var22)->values[0] = (val*) var11; +((struct instance_array__NativeArray*)var22)->values[1] = (val*) var_c_name; +((struct instance_array__NativeArray*)var22)->values[2] = (val*) var16; +((void (*)(val*, val*, long))(var20->class->vft[COLOR_array__Array__with_native]))(var20, var22, var21) /* with_native on */; +} +var23 = ((val* (*)(val*))(var20->class->vft[COLOR_string__Object__to_s]))(var20) /* to_s on */; +((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add_decl]))(var_v, var23) /* add_decl on */; +if (varonce24) { +var25 = varonce24; +} else { +var26 = "class_"; +var27 = 6; +var28 = string__NativeString__to_s_with_length(var26, var27); +var25 = var28; +varonce24 = var25; +} +var29 = NEW_array__Array(&type_array__Arraykernel__Object); +{ /* var29 = array_instance Array[Object] */ +var30 = 2; +var31 = NEW_array__NativeArray(var30, &type_array__NativeArraykernel__Object); +((struct instance_array__NativeArray*)var31)->values[0] = (val*) var25; +((struct instance_array__NativeArray*)var31)->values[1] = (val*) var_c_name; +((void (*)(val*, val*, long))(var29->class->vft[COLOR_array__Array__with_native]))(var29, var31, var30) /* with_native on */; +} +var32 = ((val* (*)(val*))(var29->class->vft[COLOR_string__Object__to_s]))(var29) /* to_s on */; +if (varonce33) { +var34 = varonce33; } else { -var39 = ";"; -var40 = 1; -var41 = string__NativeString__to_s_with_length(var39, var40); -var38 = var41; -varonce37 = var38; +var35 = "extern const struct class class_"; +var36 = 32; +var37 = string__NativeString__to_s_with_length(var35, var36); +var34 = var37; +varonce33 = var34; } -var42 = NEW_array__Array(&type_array__Arraykernel__Object); -{ /* var42 = array_instance Array[Object] */ -var43 = 3; -var44 = NEW_array__NativeArray(var43, &type_array__NativeArraykernel__Object); -((struct instance_array__NativeArray*)var44)->values[0] = (val*) var33; -((struct instance_array__NativeArray*)var44)->values[1] = (val*) var_c_name; -((struct instance_array__NativeArray*)var44)->values[2] = (val*) var38; -((void (*)(val*, val*, long))(var42->class->vft[COLOR_array__Array__with_native]))(var42, var44, var43) /* with_native on */; -CHECK_NEW_array__Array(var42); -} -var45 = ((val* (*)(val*))(var42->class->vft[COLOR_string__Object__to_s]))(var42) /* to_s on */; -((void (*)(val*, val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompiler__provide_declaration]))(self, var31, var45) /* provide_declaration on */; -if (varonce46) { -var47 = varonce46; +if (varonce38) { +var39 = varonce38; } else { -var48 = "extern const struct type_table type_table_"; -var49 = 42; -var50 = string__NativeString__to_s_with_length(var48, var49); -var47 = var50; -varonce46 = var47; +var40 = ";"; +var41 = 1; +var42 = string__NativeString__to_s_with_length(var40, var41); +var39 = var42; +varonce38 = var39; } -if (varonce51) { -var52 = varonce51; -} else { -var53 = ";"; -var54 = 1; -var55 = string__NativeString__to_s_with_length(var53, var54); -var52 = var55; -varonce51 = var52; +var43 = NEW_array__Array(&type_array__Arraykernel__Object); +{ /* var43 = array_instance Array[Object] */ +var44 = 3; +var45 = NEW_array__NativeArray(var44, &type_array__NativeArraykernel__Object); +((struct instance_array__NativeArray*)var45)->values[0] = (val*) var34; +((struct instance_array__NativeArray*)var45)->values[1] = (val*) var_c_name; +((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 */; } -var56 = NEW_array__Array(&type_array__Arraykernel__Object); -{ /* var56 = array_instance Array[Object] */ -var57 = 3; -var58 = NEW_array__NativeArray(var57, &type_array__NativeArraykernel__Object); -((struct instance_array__NativeArray*)var58)->values[0] = (val*) var47; -((struct instance_array__NativeArray*)var58)->values[1] = (val*) var_c_name; -((struct instance_array__NativeArray*)var58)->values[2] = (val*) var52; -((void (*)(val*, val*, long))(var56->class->vft[COLOR_array__Array__with_native]))(var56, var58, var57) /* with_native on */; -CHECK_NEW_array__Array(var56); -} -var59 = ((val* (*)(val*))(var56->class->vft[COLOR_string__Object__to_s]))(var56) /* to_s on */; -((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add_decl]))(var_v, var59) /* add_decl on */; -if (varonce60) { -var61 = varonce60; +var46 = ((val* (*)(val*))(var43->class->vft[COLOR_string__Object__to_s]))(var43) /* to_s on */; +((void (*)(val*, val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompiler__provide_declaration]))(self, var32, var46) /* provide_declaration on */; +if (varonce47) { +var48 = varonce47; } else { -var62 = "const struct class class_"; -var63 = 25; -var64 = string__NativeString__to_s_with_length(var62, var63); -var61 = var64; -varonce60 = var61; +var49 = "extern const struct type_table type_table_"; +var50 = 42; +var51 = string__NativeString__to_s_with_length(var49, var50); +var48 = var51; +varonce47 = var48; } -if (varonce65) { -var66 = varonce65; +if (varonce52) { +var53 = varonce52; } else { -var67 = " = {"; -var68 = 4; -var69 = string__NativeString__to_s_with_length(var67, var68); -var66 = var69; -varonce65 = var66; -} -var70 = NEW_array__Array(&type_array__Arraykernel__Object); -{ /* var70 = array_instance Array[Object] */ -var71 = 3; -var72 = NEW_array__NativeArray(var71, &type_array__NativeArraykernel__Object); -((struct instance_array__NativeArray*)var72)->values[0] = (val*) var61; -((struct instance_array__NativeArray*)var72)->values[1] = (val*) var_c_name; -((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); +var54 = ";"; +var55 = 1; +var56 = string__NativeString__to_s_with_length(var54, var55); +var53 = var56; +varonce52 = var53; } -var73 = ((val* (*)(val*))(var70->class->vft[COLOR_string__Object__to_s]))(var70) /* to_s on */; -((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add_decl]))(var_v, var73) /* add_decl on */; -var74 = ((val* (*)(val*))(self->class->vft[COLOR_separate_erasure_compiler__SeparateErasureCompiler__class_layout]))(self) /* class_layout on */; -if (var74 == NULL) { -fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Reciever is null", "src/separate_erasure_compiler.nit", 235); -exit(1); -} else { -var75 = ((val* (*)(val*))(var74->class->vft[COLOR_layout_builders__Layout__ids]))(var74) /* ids on */; -} -var76 = ((val* (*)(val*, val*))(var75->class->vft[COLOR_abstract_collection__MapRead___91d_93d]))(var75, var_mclass) /* [] on */; -if (varonce77) { -var78 = varonce77; -} else { -var79 = ","; -var80 = 1; -var81 = string__NativeString__to_s_with_length(var79, var80); -var78 = var81; -varonce77 = var78; -} -var82 = NEW_array__Array(&type_array__Arraykernel__Object); -{ /* var82 = array_instance Array[Object] */ -var83 = 2; -var84 = NEW_array__NativeArray(var83, &type_array__NativeArraykernel__Object); -((struct instance_array__NativeArray*)var84)->values[0] = (val*) var76; -((struct instance_array__NativeArray*)var84)->values[1] = (val*) var78; -((void (*)(val*, val*, long))(var82->class->vft[COLOR_array__Array__with_native]))(var82, var84, var83) /* with_native on */; -CHECK_NEW_array__Array(var82); -} -var85 = ((val* (*)(val*))(var82->class->vft[COLOR_string__Object__to_s]))(var82) /* to_s on */; -((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add_decl]))(var_v, var85) /* add_decl on */; -if (varonce86) { -var87 = varonce86; +var57 = NEW_array__Array(&type_array__Arraykernel__Object); +{ /* var57 = array_instance Array[Object] */ +var58 = 3; +var59 = NEW_array__NativeArray(var58, &type_array__NativeArraykernel__Object); +((struct instance_array__NativeArray*)var59)->values[0] = (val*) var48; +((struct instance_array__NativeArray*)var59)->values[1] = (val*) var_c_name; +((struct instance_array__NativeArray*)var59)->values[2] = (val*) var53; +((void (*)(val*, val*, long))(var57->class->vft[COLOR_array__Array__with_native]))(var57, var59, var58) /* with_native on */; +} +var60 = ((val* (*)(val*))(var57->class->vft[COLOR_string__Object__to_s]))(var57) /* to_s on */; +((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add_decl]))(var_v, var60) /* add_decl on */; +if (varonce61) { +var62 = varonce61; } else { -var88 = "\""; -var89 = 1; -var90 = string__NativeString__to_s_with_length(var88, var89); -var87 = var90; -varonce86 = var87; +var63 = "const struct class class_"; +var64 = 25; +var65 = string__NativeString__to_s_with_length(var63, var64); +var62 = var65; +varonce61 = var62; } -var91 = ((val* (*)(val*))(var_mclass->class->vft[COLOR_model__MClass__name]))(var_mclass) /* name on */; -if (varonce92) { -var93 = varonce92; -} else { -var94 = "\", /* class_name_string */"; -var95 = 26; -var96 = string__NativeString__to_s_with_length(var94, var95); -var93 = var96; -varonce92 = var93; -} -var97 = NEW_array__Array(&type_array__Arraykernel__Object); -{ /* var97 = array_instance Array[Object] */ -var98 = 3; -var99 = NEW_array__NativeArray(var98, &type_array__NativeArraykernel__Object); -((struct instance_array__NativeArray*)var99)->values[0] = (val*) var87; -((struct instance_array__NativeArray*)var99)->values[1] = (val*) var91; -((struct instance_array__NativeArray*)var99)->values[2] = (val*) var93; -((void (*)(val*, val*, long))(var97->class->vft[COLOR_array__Array__with_native]))(var97, var99, var98) /* with_native on */; -CHECK_NEW_array__Array(var97); -} -var100 = ((val* (*)(val*))(var97->class->vft[COLOR_string__Object__to_s]))(var97) /* to_s on */; -((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add_decl]))(var_v, var100) /* add_decl on */; -var101 = ((long (*)(val*, val*))(self->class->vft[COLOR_separate_compiler__SeparateCompiler__box_kind_of]))(self, var_mclass) /* box_kind_of on */; -if (varonce102) { -var103 = varonce102; +if (varonce66) { +var67 = varonce66; +} else { +var68 = " = {"; +var69 = 4; +var70 = string__NativeString__to_s_with_length(var68, var69); +var67 = var70; +varonce66 = var67; +} +var71 = NEW_array__Array(&type_array__Arraykernel__Object); +{ /* var71 = array_instance Array[Object] */ +var72 = 3; +var73 = NEW_array__NativeArray(var72, &type_array__NativeArraykernel__Object); +((struct instance_array__NativeArray*)var73)->values[0] = (val*) var62; +((struct instance_array__NativeArray*)var73)->values[1] = (val*) var_c_name; +((struct instance_array__NativeArray*)var73)->values[2] = (val*) var67; +((void (*)(val*, val*, long))(var71->class->vft[COLOR_array__Array__with_native]))(var71, var73, var72) /* with_native on */; +} +var74 = ((val* (*)(val*))(var71->class->vft[COLOR_string__Object__to_s]))(var71) /* to_s on */; +((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add_decl]))(var_v, var74) /* add_decl on */; +var75 = ((val* (*)(val*))(self->class->vft[COLOR_separate_erasure_compiler__SeparateErasureCompiler__class_layout]))(self) /* class_layout on */; +if (var75 == NULL) { +fprintf(stderr, "Runtime error: %s", "Receiver is null"); +fprintf(stderr, " (%s:%d)\n", "src/separate_erasure_compiler.nit", 236); +show_backtrace(1); +} else { +var76 = ((val* (*)(val*))(var75->class->vft[COLOR_layout_builders__Layout__ids]))(var75) /* ids on */; +} +var77 = ((val* (*)(val*, val*))(var76->class->vft[COLOR_abstract_collection__MapRead___91d_93d]))(var76, var_mclass) /* [] on */; +if (varonce78) { +var79 = varonce78; +} else { +var80 = ","; +var81 = 1; +var82 = string__NativeString__to_s_with_length(var80, var81); +var79 = var82; +varonce78 = var79; +} +var83 = NEW_array__Array(&type_array__Arraykernel__Object); +{ /* var83 = array_instance Array[Object] */ +var84 = 2; +var85 = NEW_array__NativeArray(var84, &type_array__NativeArraykernel__Object); +((struct instance_array__NativeArray*)var85)->values[0] = (val*) var77; +((struct instance_array__NativeArray*)var85)->values[1] = (val*) var79; +((void (*)(val*, val*, long))(var83->class->vft[COLOR_array__Array__with_native]))(var83, var85, var84) /* with_native on */; +} +var86 = ((val* (*)(val*))(var83->class->vft[COLOR_string__Object__to_s]))(var83) /* to_s on */; +((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add_decl]))(var_v, var86) /* add_decl on */; +if (varonce87) { +var88 = varonce87; +} else { +var89 = "\""; +var90 = 1; +var91 = string__NativeString__to_s_with_length(var89, var90); +var88 = var91; +varonce87 = var88; +} +var92 = ((val* (*)(val*))(var_mclass->class->vft[COLOR_model__MClass__name]))(var_mclass) /* name on */; +if (varonce93) { +var94 = varonce93; } else { -var104 = ", /* box_kind */"; -var105 = 16; -var106 = string__NativeString__to_s_with_length(var104, var105); -var103 = var106; -varonce102 = var103; +var95 = "\", /* class_name_string */"; +var96 = 26; +var97 = string__NativeString__to_s_with_length(var95, var96); +var94 = var97; +varonce93 = var94; } -var107 = NEW_array__Array(&type_array__Arraykernel__Object); -{ /* var107 = array_instance Array[Object] */ -var108 = 2; -var109 = NEW_array__NativeArray(var108, &type_array__NativeArraykernel__Object); -var110 = BOX_kernel__Int(var101); /* autobox from Int to Object */ -((struct instance_array__NativeArray*)var109)->values[0] = (val*) var110; -((struct instance_array__NativeArray*)var109)->values[1] = (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); -} -var111 = ((val* (*)(val*))(var107->class->vft[COLOR_string__Object__to_s]))(var107) /* to_s on */; -((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add_decl]))(var_v, var111) /* add_decl on */; -var112 = ((val* (*)(val*))(self->class->vft[COLOR_separate_erasure_compiler__SeparateErasureCompiler__class_layout]))(self) /* class_layout on */; -var_layout = var112; +var98 = NEW_array__Array(&type_array__Arraykernel__Object); +{ /* var98 = array_instance Array[Object] */ +var99 = 3; +var100 = NEW_array__NativeArray(var99, &type_array__NativeArraykernel__Object); +((struct instance_array__NativeArray*)var100)->values[0] = (val*) var88; +((struct instance_array__NativeArray*)var100)->values[1] = (val*) var92; +((struct instance_array__NativeArray*)var100)->values[2] = (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*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add_decl]))(var_v, var101) /* add_decl on */; +var102 = ((long (*)(val*, val*))(self->class->vft[COLOR_separate_compiler__SeparateCompiler__box_kind_of]))(self, var_mclass) /* box_kind_of on */; +if (varonce103) { +var104 = varonce103; +} else { +var105 = ", /* box_kind */"; +var106 = 16; +var107 = string__NativeString__to_s_with_length(var105, var106); +var104 = var107; +varonce103 = var104; +} +var108 = NEW_array__Array(&type_array__Arraykernel__Object); +{ /* var108 = array_instance Array[Object] */ +var109 = 2; +var110 = NEW_array__NativeArray(var109, &type_array__NativeArraykernel__Object); +var111 = BOX_kernel__Int(var102); /* autobox from Int to Object */ +((struct instance_array__NativeArray*)var110)->values[0] = (val*) var111; +((struct instance_array__NativeArray*)var110)->values[1] = (val*) var104; +((void (*)(val*, val*, long))(var108->class->vft[COLOR_array__Array__with_native]))(var108, var110, var109) /* with_native on */; +} +var112 = ((val* (*)(val*))(var108->class->vft[COLOR_string__Object__to_s]))(var108) /* to_s on */; +((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add_decl]))(var_v, var112) /* add_decl on */; +var113 = ((val* (*)(val*))(self->class->vft[COLOR_separate_erasure_compiler__SeparateErasureCompiler__class_layout]))(self) /* class_layout on */; +var_layout = var113; /* isa PHLayout[MClass, MClass] */ cltype = type_layout_builders__PHLayoutmodel__MClassmodel__MClass.color; idtype = type_layout_builders__PHLayoutmodel__MClassmodel__MClass.id; if(var_layout == NULL) { -var113 = 0; +var114 = 0; } else { if(cltype >= var_layout->type->table_size) { -var113 = 0; +var114 = 0; } else { -var113 = var_layout->type->type_table[cltype] == idtype; +var114 = var_layout->type->type_table[cltype] == idtype; } } -if (var113){ -var114 = ((val* (*)(val*))(var_layout->class->vft[COLOR_layout_builders__PHLayout__masks]))(var_layout) /* masks on */; -var115 = ((val* (*)(val*, val*))(var114->class->vft[COLOR_abstract_collection__MapRead___91d_93d]))(var114, var_mclass) /* [] on */; -if (varonce116) { -var117 = varonce116; +if (var114){ +var115 = ((val* (*)(val*))(var_layout->class->vft[COLOR_layout_builders__PHLayout__masks]))(var_layout) /* masks on */; +var116 = ((val* (*)(val*, val*))(var115->class->vft[COLOR_abstract_collection__MapRead___91d_93d]))(var115, var_mclass) /* [] on */; +if (varonce117) { +var118 = varonce117; } else { -var118 = ","; -var119 = 1; -var120 = string__NativeString__to_s_with_length(var118, var119); -var117 = var120; -varonce116 = var117; +var119 = ","; +var120 = 1; +var121 = string__NativeString__to_s_with_length(var119, var120); +var118 = var121; +varonce117 = var118; } -var121 = NEW_array__Array(&type_array__Arraykernel__Object); -{ /* var121 = array_instance Array[Object] */ -var122 = 2; -var123 = NEW_array__NativeArray(var122, &type_array__NativeArraykernel__Object); -((struct instance_array__NativeArray*)var123)->values[0] = (val*) var115; -((struct instance_array__NativeArray*)var123)->values[1] = (val*) var117; -((void (*)(val*, val*, long))(var121->class->vft[COLOR_array__Array__with_native]))(var121, var123, var122) /* with_native on */; -CHECK_NEW_array__Array(var121); +var122 = NEW_array__Array(&type_array__Arraykernel__Object); +{ /* var122 = array_instance Array[Object] */ +var123 = 2; +var124 = NEW_array__NativeArray(var123, &type_array__NativeArraykernel__Object); +((struct instance_array__NativeArray*)var124)->values[0] = (val*) var116; +((struct instance_array__NativeArray*)var124)->values[1] = (val*) var118; +((void (*)(val*, val*, long))(var122->class->vft[COLOR_array__Array__with_native]))(var122, var124, var123) /* with_native on */; } -var124 = ((val* (*)(val*))(var121->class->vft[COLOR_string__Object__to_s]))(var121) /* to_s on */; -((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add_decl]))(var_v, var124) /* add_decl on */; +var125 = ((val* (*)(val*))(var122->class->vft[COLOR_string__Object__to_s]))(var122) /* to_s on */; +((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add_decl]))(var_v, var125) /* add_decl on */; } else { if (var_layout == NULL) { -fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Reciever is null", "src/separate_erasure_compiler.nit", 242); -exit(1); +fprintf(stderr, "Runtime error: %s", "Receiver is null"); +fprintf(stderr, " (%s:%d)\n", "src/separate_erasure_compiler.nit", 243); +show_backtrace(1); } else { -var125 = ((val* (*)(val*))(var_layout->class->vft[COLOR_layout_builders__Layout__pos]))(var_layout) /* pos on */; +var126 = ((val* (*)(val*))(var_layout->class->vft[COLOR_layout_builders__Layout__pos]))(var_layout) /* pos on */; } -var126 = ((val* (*)(val*, val*))(var125->class->vft[COLOR_abstract_collection__MapRead___91d_93d]))(var125, var_mclass) /* [] on */; -if (varonce127) { -var128 = varonce127; +var127 = ((val* (*)(val*, val*))(var126->class->vft[COLOR_abstract_collection__MapRead___91d_93d]))(var126, var_mclass) /* [] on */; +if (varonce128) { +var129 = varonce128; } else { -var129 = ","; -var130 = 1; -var131 = string__NativeString__to_s_with_length(var129, var130); -var128 = var131; -varonce127 = var128; -} -var132 = NEW_array__Array(&type_array__Arraykernel__Object); -{ /* var132 = array_instance Array[Object] */ -var133 = 2; -var134 = NEW_array__NativeArray(var133, &type_array__NativeArraykernel__Object); -((struct instance_array__NativeArray*)var134)->values[0] = (val*) var126; -((struct instance_array__NativeArray*)var134)->values[1] = (val*) var128; -((void (*)(val*, val*, long))(var132->class->vft[COLOR_array__Array__with_native]))(var132, var134, var133) /* with_native on */; -CHECK_NEW_array__Array(var132); +var130 = ","; +var131 = 1; +var132 = string__NativeString__to_s_with_length(var130, var131); +var129 = var132; +varonce128 = var129; } -var135 = ((val* (*)(val*))(var132->class->vft[COLOR_string__Object__to_s]))(var132) /* to_s on */; -((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add_decl]))(var_v, var135) /* add_decl on */; +var133 = NEW_array__Array(&type_array__Arraykernel__Object); +{ /* var133 = array_instance Array[Object] */ +var134 = 2; +var135 = NEW_array__NativeArray(var134, &type_array__NativeArraykernel__Object); +((struct instance_array__NativeArray*)var135)->values[0] = (val*) var127; +((struct instance_array__NativeArray*)var135)->values[1] = (val*) var129; +((void (*)(val*, val*, long))(var133->class->vft[COLOR_array__Array__with_native]))(var133, var135, var134) /* with_native on */; +} +var136 = ((val* (*)(val*))(var133->class->vft[COLOR_string__Object__to_s]))(var133) /* to_s on */; +((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add_decl]))(var_v, var136) /* add_decl on */; +} +var137 = ((short int (*)(val*, val*))(self->class->vft[COLOR_separate_erasure_compiler__SeparateErasureCompiler__build_class_vts_table]))(self, var_mclass) /* build_class_vts_table on */; +if (var137){ +if (varonce138) { +var139 = varonce138; +} else { +var140 = "vts_table_"; +var141 = 10; +var142 = string__NativeString__to_s_with_length(var140, var141); +var139 = var142; +varonce138 = var139; +} +var143 = NEW_array__Array(&type_array__Arraykernel__Object); +{ /* var143 = array_instance Array[Object] */ +var144 = 2; +var145 = NEW_array__NativeArray(var144, &type_array__NativeArraykernel__Object); +((struct instance_array__NativeArray*)var145)->values[0] = (val*) var139; +((struct instance_array__NativeArray*)var145)->values[1] = (val*) var_c_name; +((void (*)(val*, val*, long))(var143->class->vft[COLOR_array__Array__with_native]))(var143, var145, var144) /* with_native on */; +} +var146 = ((val* (*)(val*))(var143->class->vft[COLOR_string__Object__to_s]))(var143) /* to_s on */; +((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__require_declaration]))(var_v, var146) /* require_declaration on */; +if (varonce147) { +var148 = varonce147; +} else { +var149 = "&vts_table_"; +var150 = 11; +var151 = string__NativeString__to_s_with_length(var149, var150); +var148 = var151; +varonce147 = var148; } -var136 = ((short int (*)(val*, val*))(self->class->vft[COLOR_separate_erasure_compiler__SeparateErasureCompiler__build_class_vts_table]))(self, var_mclass) /* build_class_vts_table on */; -if (var136){ -if (varonce137) { -var138 = varonce137; +if (varonce152) { +var153 = varonce152; } else { -var139 = "vts_table_"; -var140 = 10; -var141 = string__NativeString__to_s_with_length(var139, var140); -var138 = var141; -varonce137 = var138; +var154 = ","; +var155 = 1; +var156 = string__NativeString__to_s_with_length(var154, var155); +var153 = var156; +varonce152 = var153; } -var142 = NEW_array__Array(&type_array__Arraykernel__Object); -{ /* var142 = array_instance Array[Object] */ -var143 = 2; -var144 = NEW_array__NativeArray(var143, &type_array__NativeArraykernel__Object); -((struct instance_array__NativeArray*)var144)->values[0] = (val*) var138; -((struct instance_array__NativeArray*)var144)->values[1] = (val*) var_c_name; -((void (*)(val*, val*, long))(var142->class->vft[COLOR_array__Array__with_native]))(var142, var144, var143) /* with_native on */; -CHECK_NEW_array__Array(var142); -} -var145 = ((val* (*)(val*))(var142->class->vft[COLOR_string__Object__to_s]))(var142) /* to_s on */; -((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__require_declaration]))(var_v, var145) /* require_declaration on */; -if (varonce146) { -var147 = varonce146; -} else { -var148 = "&vts_table_"; -var149 = 11; -var150 = string__NativeString__to_s_with_length(var148, var149); -var147 = var150; -varonce146 = var147; -} -if (varonce151) { -var152 = varonce151; -} else { -var153 = ","; -var154 = 1; -var155 = string__NativeString__to_s_with_length(var153, var154); -var152 = var155; -varonce151 = var152; -} -var156 = NEW_array__Array(&type_array__Arraykernel__Object); -{ /* var156 = array_instance Array[Object] */ -var157 = 3; -var158 = NEW_array__NativeArray(var157, &type_array__NativeArraykernel__Object); -((struct instance_array__NativeArray*)var158)->values[0] = (val*) var147; -((struct instance_array__NativeArray*)var158)->values[1] = (val*) var_c_name; -((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*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add_decl]))(var_v, var159) /* add_decl on */; -} else { -if (varonce160) { -var161 = varonce160; -} else { -var162 = "NULL,"; -var163 = 5; -var164 = string__NativeString__to_s_with_length(var162, var163); -var161 = var164; -varonce160 = var161; -} -((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add_decl]))(var_v, var161) /* add_decl on */; -} -if (varonce165) { -var166 = varonce165; -} else { -var167 = "&type_table_"; -var168 = 12; -var169 = string__NativeString__to_s_with_length(var167, var168); -var166 = var169; -varonce165 = var166; -} -if (varonce170) { -var171 = varonce170; -} else { -var172 = ","; -var173 = 1; -var174 = string__NativeString__to_s_with_length(var172, var173); -var171 = var174; -varonce170 = var171; -} -var175 = NEW_array__Array(&type_array__Arraykernel__Object); -{ /* var175 = array_instance Array[Object] */ -var176 = 3; -var177 = NEW_array__NativeArray(var176, &type_array__NativeArraykernel__Object); -((struct instance_array__NativeArray*)var177)->values[0] = (val*) var166; -((struct instance_array__NativeArray*)var177)->values[1] = (val*) var_c_name; -((struct instance_array__NativeArray*)var177)->values[2] = (val*) var171; -((void (*)(val*, val*, long))(var175->class->vft[COLOR_array__Array__with_native]))(var175, var177, var176) /* with_native on */; -CHECK_NEW_array__Array(var175); -} -var178 = ((val* (*)(val*))(var175->class->vft[COLOR_string__Object__to_s]))(var175) /* to_s on */; -((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add_decl]))(var_v, var178) /* add_decl on */; -if (varonce179) { -var180 = varonce179; -} else { -var181 = "{"; -var182 = 1; -var183 = string__NativeString__to_s_with_length(var181, var182); -var180 = var183; -varonce179 = var180; -} -((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add_decl]))(var_v, var180) /* add_decl on */; -var184 = NEW_range__Range(&type_range__Rangekernel__Int); -var185 = 0; -var186 = ((long (*)(val*))(var_vft->class->vft[COLOR_abstract_collection__Collection__length]))(var_vft) /* length on */; -var187 = BOX_kernel__Int(var185); /* autobox from Int to Discrete */ +var157 = NEW_array__Array(&type_array__Arraykernel__Object); +{ /* var157 = array_instance Array[Object] */ +var158 = 3; +var159 = NEW_array__NativeArray(var158, &type_array__NativeArraykernel__Object); +((struct instance_array__NativeArray*)var159)->values[0] = (val*) var148; +((struct instance_array__NativeArray*)var159)->values[1] = (val*) var_c_name; +((struct instance_array__NativeArray*)var159)->values[2] = (val*) var153; +((void (*)(val*, val*, long))(var157->class->vft[COLOR_array__Array__with_native]))(var157, var159, var158) /* with_native on */; +} +var160 = ((val* (*)(val*))(var157->class->vft[COLOR_string__Object__to_s]))(var157) /* to_s on */; +((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add_decl]))(var_v, var160) /* add_decl on */; +} else { +if (varonce161) { +var162 = varonce161; +} else { +var163 = "NULL,"; +var164 = 5; +var165 = string__NativeString__to_s_with_length(var163, var164); +var162 = var165; +varonce161 = var162; +} +((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add_decl]))(var_v, var162) /* add_decl on */; +} +if (varonce166) { +var167 = varonce166; +} else { +var168 = "&type_table_"; +var169 = 12; +var170 = string__NativeString__to_s_with_length(var168, var169); +var167 = var170; +varonce166 = var167; +} +if (varonce171) { +var172 = varonce171; +} else { +var173 = ","; +var174 = 1; +var175 = string__NativeString__to_s_with_length(var173, var174); +var172 = var175; +varonce171 = var172; +} +var176 = NEW_array__Array(&type_array__Arraykernel__Object); +{ /* var176 = array_instance Array[Object] */ +var177 = 3; +var178 = NEW_array__NativeArray(var177, &type_array__NativeArraykernel__Object); +((struct instance_array__NativeArray*)var178)->values[0] = (val*) var167; +((struct instance_array__NativeArray*)var178)->values[1] = (val*) var_c_name; +((struct instance_array__NativeArray*)var178)->values[2] = (val*) var172; +((void (*)(val*, val*, long))(var176->class->vft[COLOR_array__Array__with_native]))(var176, var178, var177) /* with_native on */; +} +var179 = ((val* (*)(val*))(var176->class->vft[COLOR_string__Object__to_s]))(var176) /* to_s on */; +((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add_decl]))(var_v, var179) /* add_decl on */; +if (varonce180) { +var181 = varonce180; +} else { +var182 = "{"; +var183 = 1; +var184 = string__NativeString__to_s_with_length(var182, var183); +var181 = var184; +varonce180 = var181; +} +((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add_decl]))(var_v, var181) /* add_decl on */; +var185 = NEW_range__Range(&type_range__Rangekernel__Int); +var186 = 0; +var187 = ((long (*)(val*))(var_vft->class->vft[COLOR_abstract_collection__Collection__length]))(var_vft) /* length on */; var188 = BOX_kernel__Int(var186); /* autobox from Int to Discrete */ -((void (*)(val*, val*, val*))(var184->class->vft[COLOR_range__Range__without_last]))(var184, var187, var188) /* without_last on */; -CHECK_NEW_range__Range(var184); -var189 = ((val* (*)(val*))(var184->class->vft[COLOR_abstract_collection__Collection__iterator]))(var184) /* iterator on */; +var189 = BOX_kernel__Int(var187); /* autobox from Int to Discrete */ +((void (*)(val*, val*, val*))(var185->class->vft[COLOR_range__Range__without_last]))(var185, var188, var189) /* without_last on */; +var190 = ((val* (*)(val*))(var185->class->vft[COLOR_abstract_collection__Collection__iterator]))(var185) /* iterator on */; for(;;) { -var190 = ((short int (*)(val*))(var189->class->vft[COLOR_abstract_collection__Iterator__is_ok]))(var189) /* is_ok on */; -if(!var190) break; -var191 = ((val* (*)(val*))(var189->class->vft[COLOR_abstract_collection__Iterator__item]))(var189) /* item on */; -var192 = ((struct instance_kernel__Int*)var191)->value; /* autounbox from nullable Object to Int */; -var_i = var192; -var193 = ((val* (*)(val*, long))(var_vft->class->vft[COLOR_abstract_collection__SequenceRead___91d_93d]))(var_vft, var_i) /* [] on */; -var_mpropdef = var193; -var194 = NULL; +var191 = ((short int (*)(val*))(var190->class->vft[COLOR_abstract_collection__Iterator__is_ok]))(var190) /* is_ok on */; +if(!var191) break; +var192 = ((val* (*)(val*))(var190->class->vft[COLOR_abstract_collection__Iterator__item]))(var190) /* item on */; +var193 = ((struct instance_kernel__Int*)var192)->value; /* autounbox from nullable Object to Int */; +var_i = var193; +var194 = ((val* (*)(val*, long))(var_vft->class->vft[COLOR_abstract_collection__SequenceRead___91d_93d]))(var_vft, var_i) /* [] on */; +var_mpropdef = var194; +var195 = NULL; if (var_mpropdef == NULL) { -var195 = 1; /* is null */ +var196 = 1; /* is null */ } else { -var195 = 0; /* arg is null but recv is not */ +var196 = 0; /* arg is null but recv is not */ } -if (var195){ -if (varonce196) { -var197 = varonce196; +if (var196){ +if (varonce197) { +var198 = varonce197; } else { -var198 = "NULL, /* empty */"; -var199 = 17; -var200 = string__NativeString__to_s_with_length(var198, var199); -var197 = var200; -varonce196 = var197; +var199 = "NULL, /* empty */"; +var200 = 17; +var201 = string__NativeString__to_s_with_length(var199, var200); +var198 = var201; +varonce197 = var198; } -((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add_decl]))(var_v, var197) /* add_decl on */; +((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add_decl]))(var_v, var198) /* add_decl on */; } else { -var202 = 1; -var_ = var202; -if (var202){ -var201 = var_; -} else { -var203 = ((val* (*)(val*))(var_mpropdef->class->vft[COLOR_model__MPropDef__mclassdef]))(var_mpropdef) /* mclassdef on */; -var204 = ((val* (*)(val*))(var203->class->vft[COLOR_model__MClassDef__bound_mtype]))(var203) /* bound_mtype on */; -var205 = ((val* (*)(val*))(var204->class->vft[COLOR_abstract_compiler__MType__ctype]))(var204) /* ctype on */; -if (varonce206) { -var207 = varonce206; -} else { -var208 = "val*"; -var209 = 4; -var210 = string__NativeString__to_s_with_length(var208, var209); -var207 = var210; -varonce206 = var207; -} -var211 = ((short int (*)(val*, val*))(var205->class->vft[COLOR_kernel__Object___33d_61d]))(var205, var207) /* != on */; -var201 = var211; -} -if (var201){ -if (varonce212) { -var213 = varonce212; -} else { -var214 = "VIRTUAL_"; -var215 = 8; -var216 = string__NativeString__to_s_with_length(var214, var215); -var213 = var216; -varonce212 = var213; -} -var217 = ((val* (*)(val*))(var_mpropdef->class->vft[COLOR_abstract_compiler__MPropDef__c_name]))(var_mpropdef) /* c_name on */; -var218 = NEW_array__Array(&type_array__Arraykernel__Object); -{ /* var218 = array_instance Array[Object] */ -var219 = 2; -var220 = NEW_array__NativeArray(var219, &type_array__NativeArraykernel__Object); -((struct instance_array__NativeArray*)var220)->values[0] = (val*) var213; -((struct instance_array__NativeArray*)var220)->values[1] = (val*) var217; -((void (*)(val*, val*, long))(var218->class->vft[COLOR_array__Array__with_native]))(var218, var220, var219) /* with_native on */; -CHECK_NEW_array__Array(var218); -} -var221 = ((val* (*)(val*))(var218->class->vft[COLOR_string__Object__to_s]))(var218) /* to_s on */; -((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__require_declaration]))(var_v, var221) /* require_declaration on */; -if (varonce222) { -var223 = varonce222; -} else { -var224 = "(nitmethod_t)VIRTUAL_"; -var225 = 21; -var226 = string__NativeString__to_s_with_length(var224, var225); -var223 = var226; -varonce222 = var223; -} -var227 = ((val* (*)(val*))(var_mpropdef->class->vft[COLOR_abstract_compiler__MPropDef__c_name]))(var_mpropdef) /* c_name on */; -if (varonce228) { -var229 = varonce228; -} else { -var230 = ", /* pointer to "; -var231 = 16; -var232 = string__NativeString__to_s_with_length(var230, var231); -var229 = var232; -varonce228 = var229; -} -var233 = ((val* (*)(val*))(var_mclass->class->vft[COLOR_model__MClass__intro_mmodule]))(var_mclass) /* intro_mmodule on */; -if (varonce234) { -var235 = varonce234; +var203 = 1; +var_ = var203; +if (var203){ +var202 = var_; } else { -var236 = ":"; -var237 = 1; -var238 = string__NativeString__to_s_with_length(var236, var237); -var235 = var238; -varonce234 = var235; +var204 = ((val* (*)(val*))(var_mpropdef->class->vft[COLOR_model__MPropDef__mclassdef]))(var_mpropdef) /* mclassdef on */; +var205 = ((val* (*)(val*))(var204->class->vft[COLOR_model__MClassDef__bound_mtype]))(var204) /* bound_mtype on */; +var206 = ((val* (*)(val*))(var205->class->vft[COLOR_abstract_compiler__MType__ctype]))(var205) /* ctype on */; +if (varonce207) { +var208 = varonce207; +} else { +var209 = "val*"; +var210 = 4; +var211 = string__NativeString__to_s_with_length(var209, var210); +var208 = var211; +varonce207 = var208; } -if (varonce239) { -var240 = varonce239; -} else { -var241 = ":"; -var242 = 1; -var243 = string__NativeString__to_s_with_length(var241, var242); -var240 = var243; -varonce239 = var240; -} -if (varonce244) { -var245 = varonce244; -} else { -var246 = " */"; -var247 = 3; -var248 = string__NativeString__to_s_with_length(var246, var247); -var245 = var248; -varonce244 = var245; -} -var249 = NEW_array__Array(&type_array__Arraykernel__Object); -{ /* var249 = array_instance Array[Object] */ -var250 = 9; -var251 = NEW_array__NativeArray(var250, &type_array__NativeArraykernel__Object); -((struct instance_array__NativeArray*)var251)->values[0] = (val*) var223; -((struct instance_array__NativeArray*)var251)->values[1] = (val*) var227; -((struct instance_array__NativeArray*)var251)->values[2] = (val*) var229; -((struct instance_array__NativeArray*)var251)->values[3] = (val*) var233; -((struct instance_array__NativeArray*)var251)->values[4] = (val*) var235; -((struct instance_array__NativeArray*)var251)->values[5] = (val*) var_mclass; -((struct instance_array__NativeArray*)var251)->values[6] = (val*) var240; -((struct instance_array__NativeArray*)var251)->values[7] = (val*) var_mpropdef; -((struct instance_array__NativeArray*)var251)->values[8] = (val*) var245; -((void (*)(val*, val*, long))(var249->class->vft[COLOR_array__Array__with_native]))(var249, var251, var250) /* with_native on */; -CHECK_NEW_array__Array(var249); -} -var252 = ((val* (*)(val*))(var249->class->vft[COLOR_string__Object__to_s]))(var249) /* to_s on */; -((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add_decl]))(var_v, var252) /* add_decl on */; -} else { -var253 = ((val* (*)(val*))(var_mpropdef->class->vft[COLOR_abstract_compiler__MPropDef__c_name]))(var_mpropdef) /* c_name on */; -var254 = NEW_array__Array(&type_array__Arraykernel__Object); -{ /* var254 = array_instance Array[Object] */ -var255 = 1; -var256 = NEW_array__NativeArray(var255, &type_array__NativeArraykernel__Object); -((struct instance_array__NativeArray*)var256)->values[0] = (val*) var253; -((void (*)(val*, val*, long))(var254->class->vft[COLOR_array__Array__with_native]))(var254, var256, var255) /* with_native on */; -CHECK_NEW_array__Array(var254); -} -var257 = ((val* (*)(val*))(var254->class->vft[COLOR_string__Object__to_s]))(var254) /* to_s on */; -((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__require_declaration]))(var_v, var257) /* require_declaration on */; -if (varonce258) { -var259 = varonce258; -} else { -var260 = "(nitmethod_t)"; -var261 = 13; -var262 = string__NativeString__to_s_with_length(var260, var261); -var259 = var262; -varonce258 = var259; -} -var263 = ((val* (*)(val*))(var_mpropdef->class->vft[COLOR_abstract_compiler__MPropDef__c_name]))(var_mpropdef) /* c_name on */; -if (varonce264) { -var265 = varonce264; -} else { -var266 = ", /* pointer to "; -var267 = 16; -var268 = string__NativeString__to_s_with_length(var266, var267); -var265 = var268; -varonce264 = var265; -} -var269 = ((val* (*)(val*))(var_mclass->class->vft[COLOR_model__MClass__intro_mmodule]))(var_mclass) /* intro_mmodule on */; -if (varonce270) { -var271 = varonce270; -} else { -var272 = ":"; -var273 = 1; -var274 = string__NativeString__to_s_with_length(var272, var273); -var271 = var274; -varonce270 = var271; -} -if (varonce275) { -var276 = varonce275; -} else { -var277 = ":"; -var278 = 1; -var279 = string__NativeString__to_s_with_length(var277, var278); -var276 = var279; -varonce275 = var276; -} -if (varonce280) { -var281 = varonce280; -} else { -var282 = " */"; -var283 = 3; -var284 = string__NativeString__to_s_with_length(var282, var283); -var281 = var284; -varonce280 = var281; -} -var285 = NEW_array__Array(&type_array__Arraykernel__Object); -{ /* var285 = array_instance Array[Object] */ -var286 = 9; -var287 = NEW_array__NativeArray(var286, &type_array__NativeArraykernel__Object); -((struct instance_array__NativeArray*)var287)->values[0] = (val*) var259; -((struct instance_array__NativeArray*)var287)->values[1] = (val*) var263; -((struct instance_array__NativeArray*)var287)->values[2] = (val*) var265; -((struct instance_array__NativeArray*)var287)->values[3] = (val*) var269; -((struct instance_array__NativeArray*)var287)->values[4] = (val*) var271; -((struct instance_array__NativeArray*)var287)->values[5] = (val*) var_mclass; -((struct instance_array__NativeArray*)var287)->values[6] = (val*) var276; -((struct instance_array__NativeArray*)var287)->values[7] = (val*) var_mpropdef; -((struct instance_array__NativeArray*)var287)->values[8] = (val*) var281; -((void (*)(val*, val*, long))(var285->class->vft[COLOR_array__Array__with_native]))(var285, var287, var286) /* with_native on */; -CHECK_NEW_array__Array(var285); -} -var288 = ((val* (*)(val*))(var285->class->vft[COLOR_string__Object__to_s]))(var285) /* to_s on */; -((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add_decl]))(var_v, var288) /* add_decl on */; +var212 = ((short int (*)(val*, val*))(var206->class->vft[COLOR_kernel__Object___33d_61d]))(var206, var208) /* != on */; +var202 = var212; } +if (var202){ +if (varonce213) { +var214 = varonce213; +} else { +var215 = "VIRTUAL_"; +var216 = 8; +var217 = string__NativeString__to_s_with_length(var215, var216); +var214 = var217; +varonce213 = var214; +} +var218 = ((val* (*)(val*))(var_mpropdef->class->vft[COLOR_abstract_compiler__MPropDef__c_name]))(var_mpropdef) /* c_name on */; +var219 = NEW_array__Array(&type_array__Arraykernel__Object); +{ /* var219 = array_instance Array[Object] */ +var220 = 2; +var221 = NEW_array__NativeArray(var220, &type_array__NativeArraykernel__Object); +((struct instance_array__NativeArray*)var221)->values[0] = (val*) var214; +((struct instance_array__NativeArray*)var221)->values[1] = (val*) var218; +((void (*)(val*, val*, long))(var219->class->vft[COLOR_array__Array__with_native]))(var219, var221, var220) /* with_native on */; +} +var222 = ((val* (*)(val*))(var219->class->vft[COLOR_string__Object__to_s]))(var219) /* to_s on */; +((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__require_declaration]))(var_v, var222) /* require_declaration on */; +if (varonce223) { +var224 = varonce223; +} else { +var225 = "(nitmethod_t)VIRTUAL_"; +var226 = 21; +var227 = string__NativeString__to_s_with_length(var225, var226); +var224 = var227; +varonce223 = var224; +} +var228 = ((val* (*)(val*))(var_mpropdef->class->vft[COLOR_abstract_compiler__MPropDef__c_name]))(var_mpropdef) /* c_name on */; +if (varonce229) { +var230 = varonce229; +} else { +var231 = ", /* pointer to "; +var232 = 16; +var233 = string__NativeString__to_s_with_length(var231, var232); +var230 = var233; +varonce229 = var230; +} +var234 = ((val* (*)(val*))(var_mclass->class->vft[COLOR_model__MClass__intro_mmodule]))(var_mclass) /* intro_mmodule on */; +if (varonce235) { +var236 = varonce235; +} else { +var237 = ":"; +var238 = 1; +var239 = string__NativeString__to_s_with_length(var237, var238); +var236 = var239; +varonce235 = var236; +} +if (varonce240) { +var241 = varonce240; +} else { +var242 = ":"; +var243 = 1; +var244 = string__NativeString__to_s_with_length(var242, var243); +var241 = var244; +varonce240 = var241; +} +if (varonce245) { +var246 = varonce245; +} else { +var247 = " */"; +var248 = 3; +var249 = string__NativeString__to_s_with_length(var247, var248); +var246 = var249; +varonce245 = var246; +} +var250 = NEW_array__Array(&type_array__Arraykernel__Object); +{ /* var250 = array_instance Array[Object] */ +var251 = 9; +var252 = NEW_array__NativeArray(var251, &type_array__NativeArraykernel__Object); +((struct instance_array__NativeArray*)var252)->values[0] = (val*) var224; +((struct instance_array__NativeArray*)var252)->values[1] = (val*) var228; +((struct instance_array__NativeArray*)var252)->values[2] = (val*) var230; +((struct instance_array__NativeArray*)var252)->values[3] = (val*) var234; +((struct instance_array__NativeArray*)var252)->values[4] = (val*) var236; +((struct instance_array__NativeArray*)var252)->values[5] = (val*) var_mclass; +((struct instance_array__NativeArray*)var252)->values[6] = (val*) var241; +((struct instance_array__NativeArray*)var252)->values[7] = (val*) var_mpropdef; +((struct instance_array__NativeArray*)var252)->values[8] = (val*) var246; +((void (*)(val*, val*, long))(var250->class->vft[COLOR_array__Array__with_native]))(var250, var252, var251) /* with_native on */; +} +var253 = ((val* (*)(val*))(var250->class->vft[COLOR_string__Object__to_s]))(var250) /* to_s on */; +((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add_decl]))(var_v, var253) /* add_decl on */; +} else { +var254 = ((val* (*)(val*))(var_mpropdef->class->vft[COLOR_abstract_compiler__MPropDef__c_name]))(var_mpropdef) /* c_name on */; +var255 = NEW_array__Array(&type_array__Arraykernel__Object); +{ /* var255 = array_instance Array[Object] */ +var256 = 1; +var257 = NEW_array__NativeArray(var256, &type_array__NativeArraykernel__Object); +((struct instance_array__NativeArray*)var257)->values[0] = (val*) var254; +((void (*)(val*, val*, long))(var255->class->vft[COLOR_array__Array__with_native]))(var255, var257, var256) /* with_native on */; } -CONTINUE_label: (void)0; -((void (*)(val*))(var189->class->vft[COLOR_abstract_collection__Iterator__next]))(var189) /* next on */; +var258 = ((val* (*)(val*))(var255->class->vft[COLOR_string__Object__to_s]))(var255) /* to_s on */; +((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__require_declaration]))(var_v, var258) /* require_declaration on */; +if (varonce259) { +var260 = varonce259; +} else { +var261 = "(nitmethod_t)"; +var262 = 13; +var263 = string__NativeString__to_s_with_length(var261, var262); +var260 = var263; +varonce259 = var260; +} +var264 = ((val* (*)(val*))(var_mpropdef->class->vft[COLOR_abstract_compiler__MPropDef__c_name]))(var_mpropdef) /* c_name on */; +if (varonce265) { +var266 = varonce265; +} else { +var267 = ", /* pointer to "; +var268 = 16; +var269 = string__NativeString__to_s_with_length(var267, var268); +var266 = var269; +varonce265 = var266; +} +var270 = ((val* (*)(val*))(var_mclass->class->vft[COLOR_model__MClass__intro_mmodule]))(var_mclass) /* intro_mmodule on */; +if (varonce271) { +var272 = varonce271; +} else { +var273 = ":"; +var274 = 1; +var275 = string__NativeString__to_s_with_length(var273, var274); +var272 = var275; +varonce271 = var272; } -BREAK_label: (void)0; -if (varonce289) { -var290 = varonce289; -} else { -var291 = "}"; -var292 = 1; -var293 = string__NativeString__to_s_with_length(var291, var292); -var290 = var293; -varonce289 = var290; -} -((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add_decl]))(var_v, var290) /* add_decl on */; -if (varonce294) { -var295 = varonce294; -} else { -var296 = "};"; -var297 = 2; -var298 = string__NativeString__to_s_with_length(var296, var297); -var295 = var298; -varonce294 = var295; -} -((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add_decl]))(var_v, var295) /* add_decl on */; -if (varonce299) { -var300 = varonce299; -} else { -var301 = "const struct type_table type_table_"; -var302 = 35; -var303 = string__NativeString__to_s_with_length(var301, var302); -var300 = var303; -varonce299 = var300; +if (varonce276) { +var277 = varonce276; +} else { +var278 = ":"; +var279 = 1; +var280 = string__NativeString__to_s_with_length(var278, var279); +var277 = var280; +varonce276 = var277; } -if (varonce304) { -var305 = varonce304; +if (varonce281) { +var282 = varonce281; } else { -var306 = " = {"; -var307 = 4; -var308 = string__NativeString__to_s_with_length(var306, var307); -var305 = var308; -varonce304 = var305; +var283 = " */"; +var284 = 3; +var285 = string__NativeString__to_s_with_length(var283, var284); +var282 = var285; +varonce281 = var282; } -var309 = NEW_array__Array(&type_array__Arraykernel__Object); -{ /* var309 = array_instance Array[Object] */ -var310 = 3; -var311 = NEW_array__NativeArray(var310, &type_array__NativeArraykernel__Object); -((struct instance_array__NativeArray*)var311)->values[0] = (val*) var300; -((struct instance_array__NativeArray*)var311)->values[1] = (val*) var_c_name; -((struct instance_array__NativeArray*)var311)->values[2] = (val*) var305; -((void (*)(val*, val*, long))(var309->class->vft[COLOR_array__Array__with_native]))(var309, var311, var310) /* with_native on */; -CHECK_NEW_array__Array(var309); +var286 = NEW_array__Array(&type_array__Arraykernel__Object); +{ /* var286 = array_instance Array[Object] */ +var287 = 9; +var288 = NEW_array__NativeArray(var287, &type_array__NativeArraykernel__Object); +((struct instance_array__NativeArray*)var288)->values[0] = (val*) var260; +((struct instance_array__NativeArray*)var288)->values[1] = (val*) var264; +((struct instance_array__NativeArray*)var288)->values[2] = (val*) var266; +((struct instance_array__NativeArray*)var288)->values[3] = (val*) var270; +((struct instance_array__NativeArray*)var288)->values[4] = (val*) var272; +((struct instance_array__NativeArray*)var288)->values[5] = (val*) var_mclass; +((struct instance_array__NativeArray*)var288)->values[6] = (val*) var277; +((struct instance_array__NativeArray*)var288)->values[7] = (val*) var_mpropdef; +((struct instance_array__NativeArray*)var288)->values[8] = (val*) var282; +((void (*)(val*, val*, long))(var286->class->vft[COLOR_array__Array__with_native]))(var286, var288, var287) /* with_native on */; } -var312 = ((val* (*)(val*))(var309->class->vft[COLOR_string__Object__to_s]))(var309) /* to_s on */; -((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add_decl]))(var_v, var312) /* add_decl on */; -var313 = ((long (*)(val*))(var_class_table->class->vft[COLOR_abstract_collection__Collection__length]))(var_class_table) /* length on */; -if (varonce314) { -var315 = varonce314; -} else { -var316 = ","; -var317 = 1; -var318 = string__NativeString__to_s_with_length(var316, var317); -var315 = var318; -varonce314 = var315; -} -var319 = NEW_array__Array(&type_array__Arraykernel__Object); -{ /* var319 = array_instance Array[Object] */ -var320 = 2; -var321 = NEW_array__NativeArray(var320, &type_array__NativeArraykernel__Object); -var322 = BOX_kernel__Int(var313); /* autobox from Int to Object */ -((struct instance_array__NativeArray*)var321)->values[0] = (val*) var322; -((struct instance_array__NativeArray*)var321)->values[1] = (val*) var315; -((void (*)(val*, val*, long))(var319->class->vft[COLOR_array__Array__with_native]))(var319, var321, var320) /* with_native on */; -CHECK_NEW_array__Array(var319); -} -var323 = ((val* (*)(val*))(var319->class->vft[COLOR_string__Object__to_s]))(var319) /* to_s on */; -((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add_decl]))(var_v, var323) /* add_decl on */; -if (varonce324) { -var325 = varonce324; -} else { -var326 = "{"; -var327 = 1; -var328 = string__NativeString__to_s_with_length(var326, var327); -var325 = var328; -varonce324 = var325; -} -((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add_decl]))(var_v, var325) /* add_decl on */; -var329 = ((val* (*)(val*))(var_class_table->class->vft[COLOR_abstract_collection__Collection__iterator]))(var_class_table) /* iterator on */; +var289 = ((val* (*)(val*))(var286->class->vft[COLOR_string__Object__to_s]))(var286) /* to_s on */; +((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add_decl]))(var_v, var289) /* add_decl on */; +} +} +CONTINUE_label: (void)0; +((void (*)(val*))(var190->class->vft[COLOR_abstract_collection__Iterator__next]))(var190) /* next on */; +} +BREAK_label: (void)0; +if (varonce290) { +var291 = varonce290; +} else { +var292 = "}"; +var293 = 1; +var294 = string__NativeString__to_s_with_length(var292, var293); +var291 = var294; +varonce290 = var291; +} +((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add_decl]))(var_v, var291) /* add_decl on */; +if (varonce295) { +var296 = varonce295; +} else { +var297 = "};"; +var298 = 2; +var299 = string__NativeString__to_s_with_length(var297, var298); +var296 = var299; +varonce295 = var296; +} +((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add_decl]))(var_v, var296) /* add_decl on */; +if (varonce300) { +var301 = varonce300; +} else { +var302 = "const struct type_table type_table_"; +var303 = 35; +var304 = string__NativeString__to_s_with_length(var302, var303); +var301 = var304; +varonce300 = var301; +} +if (varonce305) { +var306 = varonce305; +} else { +var307 = " = {"; +var308 = 4; +var309 = string__NativeString__to_s_with_length(var307, var308); +var306 = var309; +varonce305 = var306; +} +var310 = NEW_array__Array(&type_array__Arraykernel__Object); +{ /* var310 = array_instance Array[Object] */ +var311 = 3; +var312 = NEW_array__NativeArray(var311, &type_array__NativeArraykernel__Object); +((struct instance_array__NativeArray*)var312)->values[0] = (val*) var301; +((struct instance_array__NativeArray*)var312)->values[1] = (val*) var_c_name; +((struct instance_array__NativeArray*)var312)->values[2] = (val*) var306; +((void (*)(val*, val*, long))(var310->class->vft[COLOR_array__Array__with_native]))(var310, var312, var311) /* with_native on */; +} +var313 = ((val* (*)(val*))(var310->class->vft[COLOR_string__Object__to_s]))(var310) /* to_s on */; +((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add_decl]))(var_v, var313) /* add_decl on */; +var314 = ((long (*)(val*))(var_class_table->class->vft[COLOR_abstract_collection__Collection__length]))(var_class_table) /* length on */; +if (varonce315) { +var316 = varonce315; +} else { +var317 = ","; +var318 = 1; +var319 = string__NativeString__to_s_with_length(var317, var318); +var316 = var319; +varonce315 = var316; +} +var320 = NEW_array__Array(&type_array__Arraykernel__Object); +{ /* var320 = array_instance Array[Object] */ +var321 = 2; +var322 = NEW_array__NativeArray(var321, &type_array__NativeArraykernel__Object); +var323 = BOX_kernel__Int(var314); /* autobox from Int to Object */ +((struct instance_array__NativeArray*)var322)->values[0] = (val*) var323; +((struct instance_array__NativeArray*)var322)->values[1] = (val*) var316; +((void (*)(val*, val*, long))(var320->class->vft[COLOR_array__Array__with_native]))(var320, var322, var321) /* with_native on */; +} +var324 = ((val* (*)(val*))(var320->class->vft[COLOR_string__Object__to_s]))(var320) /* to_s on */; +((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add_decl]))(var_v, var324) /* add_decl on */; +if (varonce325) { +var326 = varonce325; +} else { +var327 = "{"; +var328 = 1; +var329 = string__NativeString__to_s_with_length(var327, var328); +var326 = var329; +varonce325 = var326; +} +((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add_decl]))(var_v, var326) /* add_decl on */; +var330 = ((val* (*)(val*))(var_class_table->class->vft[COLOR_abstract_collection__Collection__iterator]))(var_class_table) /* iterator on */; for(;;) { -var330 = ((short int (*)(val*))(var329->class->vft[COLOR_abstract_collection__Iterator__is_ok]))(var329) /* is_ok on */; -if(!var330) break; -var331 = ((val* (*)(val*))(var329->class->vft[COLOR_abstract_collection__Iterator__item]))(var329) /* item on */; -var_msuper = var331; -var332 = NULL; +var331 = ((short int (*)(val*))(var330->class->vft[COLOR_abstract_collection__Iterator__is_ok]))(var330) /* is_ok on */; +if(!var331) break; +var332 = ((val* (*)(val*))(var330->class->vft[COLOR_abstract_collection__Iterator__item]))(var330) /* item on */; +var_msuper = var332; +var333 = NULL; if (var_msuper == NULL) { -var333 = 1; /* is null */ -} else { -var333 = 0; /* arg is null but recv is not */ -} -if (var333){ -if (varonce334) { -var335 = varonce334; -} else { -var336 = "-1, /* empty */"; -var337 = 15; -var338 = string__NativeString__to_s_with_length(var336, var337); -var335 = var338; -varonce334 = var335; -} -((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add_decl]))(var_v, var335) /* add_decl on */; -} else { -var339 = ((val* (*)(val*))(self->class->vft[COLOR_separate_erasure_compiler__SeparateErasureCompiler__class_layout]))(self) /* class_layout on */; -if (var339 == NULL) { -fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Reciever is null", "src/separate_erasure_compiler.nit", 278); -exit(1); -} else { -var340 = ((val* (*)(val*))(var339->class->vft[COLOR_layout_builders__Layout__ids]))(var339) /* ids on */; -} -var341 = ((val* (*)(val*, val*))(var340->class->vft[COLOR_abstract_collection__MapRead___91d_93d]))(var340, var_msuper) /* [] on */; -if (varonce342) { -var343 = varonce342; -} else { -var344 = ", /* "; -var345 = 5; -var346 = string__NativeString__to_s_with_length(var344, var345); -var343 = var346; -varonce342 = var343; -} -if (varonce347) { -var348 = varonce347; -} else { -var349 = " */"; -var350 = 3; -var351 = string__NativeString__to_s_with_length(var349, var350); -var348 = var351; -varonce347 = var348; -} -var352 = NEW_array__Array(&type_array__Arraykernel__Object); -{ /* var352 = array_instance Array[Object] */ -var353 = 4; -var354 = NEW_array__NativeArray(var353, &type_array__NativeArraykernel__Object); -((struct instance_array__NativeArray*)var354)->values[0] = (val*) var341; -((struct instance_array__NativeArray*)var354)->values[1] = (val*) var343; -((struct instance_array__NativeArray*)var354)->values[2] = (val*) var_msuper; -((struct instance_array__NativeArray*)var354)->values[3] = (val*) var348; -((void (*)(val*, val*, long))(var352->class->vft[COLOR_array__Array__with_native]))(var352, var354, var353) /* with_native on */; -CHECK_NEW_array__Array(var352); -} -var355 = ((val* (*)(val*))(var352->class->vft[COLOR_string__Object__to_s]))(var352) /* to_s on */; -((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add_decl]))(var_v, var355) /* add_decl on */; -} -CONTINUE_label356: (void)0; -((void (*)(val*))(var329->class->vft[COLOR_abstract_collection__Iterator__next]))(var329) /* next on */; -} -BREAK_label356: (void)0; -if (varonce357) { -var358 = varonce357; -} else { -var359 = "}"; -var360 = 1; -var361 = string__NativeString__to_s_with_length(var359, var360); -var358 = var361; -varonce357 = var358; -} -((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add_decl]))(var_v, var358) /* add_decl on */; -if (varonce362) { -var363 = varonce362; -} else { -var364 = "};"; -var365 = 2; -var366 = string__NativeString__to_s_with_length(var364, var365); -var363 = var366; -varonce362 = var363; -} -((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add_decl]))(var_v, var363) /* add_decl on */; -var367 = ((val* (*)(val*))(var_mtype->class->vft[COLOR_abstract_compiler__MType__ctype]))(var_mtype) /* ctype on */; -if (varonce368) { -var369 = varonce368; -} else { -var370 = "val*"; -var371 = 4; -var372 = string__NativeString__to_s_with_length(var370, var371); -var369 = var372; -varonce368 = var369; -} -var373 = ((short int (*)(val*, val*))(var367->class->vft[COLOR_kernel__Object___33d_61d]))(var367, var369) /* != on */; -if (var373){ -var374 = ((val* (*)(val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompiler__header]))(self) /* header on */; -if (varonce375) { -var376 = varonce375; -} else { -var377 = "struct instance_"; -var378 = 16; -var379 = string__NativeString__to_s_with_length(var377, var378); -var376 = var379; -varonce375 = var376; -} -if (varonce380) { -var381 = varonce380; -} else { -var382 = " {"; -var383 = 2; -var384 = string__NativeString__to_s_with_length(var382, var383); -var381 = var384; -varonce380 = var381; -} -var385 = NEW_array__Array(&type_array__Arraykernel__Object); -{ /* var385 = array_instance Array[Object] */ -var386 = 3; -var387 = NEW_array__NativeArray(var386, &type_array__NativeArraykernel__Object); -((struct instance_array__NativeArray*)var387)->values[0] = (val*) var376; -((struct instance_array__NativeArray*)var387)->values[1] = (val*) var_c_name; -((struct instance_array__NativeArray*)var387)->values[2] = (val*) var381; -((void (*)(val*, val*, long))(var385->class->vft[COLOR_array__Array__with_native]))(var385, var387, var386) /* with_native on */; -CHECK_NEW_array__Array(var385); -} -var388 = ((val* (*)(val*))(var385->class->vft[COLOR_string__Object__to_s]))(var385) /* to_s on */; -((void (*)(val*, val*))(var374->class->vft[COLOR_abstract_compiler__CodeWriter__add_decl]))(var374, var388) /* add_decl on */; +var334 = 1; /* is null */ +} else { +var334 = 0; /* arg is null but recv is not */ +} +if (var334){ +if (varonce335) { +var336 = varonce335; +} else { +var337 = "-1, /* empty */"; +var338 = 15; +var339 = string__NativeString__to_s_with_length(var337, var338); +var336 = var339; +varonce335 = var336; +} +((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add_decl]))(var_v, var336) /* add_decl on */; +} else { +var340 = ((val* (*)(val*))(self->class->vft[COLOR_separate_erasure_compiler__SeparateErasureCompiler__class_layout]))(self) /* class_layout on */; +if (var340 == NULL) { +fprintf(stderr, "Runtime error: %s", "Receiver is null"); +fprintf(stderr, " (%s:%d)\n", "src/separate_erasure_compiler.nit", 279); +show_backtrace(1); +} else { +var341 = ((val* (*)(val*))(var340->class->vft[COLOR_layout_builders__Layout__ids]))(var340) /* ids on */; +} +var342 = ((val* (*)(val*, val*))(var341->class->vft[COLOR_abstract_collection__MapRead___91d_93d]))(var341, var_msuper) /* [] on */; +if (varonce343) { +var344 = varonce343; +} else { +var345 = ", /* "; +var346 = 5; +var347 = string__NativeString__to_s_with_length(var345, var346); +var344 = var347; +varonce343 = var344; +} +if (varonce348) { +var349 = varonce348; +} else { +var350 = " */"; +var351 = 3; +var352 = string__NativeString__to_s_with_length(var350, var351); +var349 = var352; +varonce348 = var349; +} +var353 = NEW_array__Array(&type_array__Arraykernel__Object); +{ /* var353 = array_instance Array[Object] */ +var354 = 4; +var355 = NEW_array__NativeArray(var354, &type_array__NativeArraykernel__Object); +((struct instance_array__NativeArray*)var355)->values[0] = (val*) var342; +((struct instance_array__NativeArray*)var355)->values[1] = (val*) var344; +((struct instance_array__NativeArray*)var355)->values[2] = (val*) var_msuper; +((struct instance_array__NativeArray*)var355)->values[3] = (val*) var349; +((void (*)(val*, val*, long))(var353->class->vft[COLOR_array__Array__with_native]))(var353, var355, var354) /* with_native on */; +} +var356 = ((val* (*)(val*))(var353->class->vft[COLOR_string__Object__to_s]))(var353) /* to_s on */; +((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add_decl]))(var_v, var356) /* add_decl on */; +} +CONTINUE_label357: (void)0; +((void (*)(val*))(var330->class->vft[COLOR_abstract_collection__Iterator__next]))(var330) /* next on */; +} +BREAK_label357: (void)0; +if (varonce358) { +var359 = varonce358; +} else { +var360 = "}"; +var361 = 1; +var362 = string__NativeString__to_s_with_length(var360, var361); +var359 = var362; +varonce358 = var359; +} +((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add_decl]))(var_v, var359) /* add_decl on */; +if (varonce363) { +var364 = varonce363; +} else { +var365 = "};"; +var366 = 2; +var367 = string__NativeString__to_s_with_length(var365, var366); +var364 = var367; +varonce363 = var364; +} +((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add_decl]))(var_v, var364) /* add_decl on */; +var368 = ((val* (*)(val*))(var_mtype->class->vft[COLOR_abstract_compiler__MType__ctype]))(var_mtype) /* ctype on */; +if (varonce369) { +var370 = varonce369; +} else { +var371 = "val*"; +var372 = 4; +var373 = string__NativeString__to_s_with_length(var371, var372); +var370 = var373; +varonce369 = var370; +} +var374 = ((short int (*)(val*, val*))(var368->class->vft[COLOR_kernel__Object___33d_61d]))(var368, var370) /* != on */; +if (var374){ +var376 = ((val* (*)(val*))(var_mtype->class->vft[COLOR_model__MClassType__mclass]))(var_mtype) /* mclass on */; +var377 = ((val* (*)(val*))(var376->class->vft[COLOR_model__MClass__name]))(var376) /* name on */; +if (varonce378) { +var379 = varonce378; +} else { +var380 = "Pointer"; +var381 = 7; +var382 = string__NativeString__to_s_with_length(var380, var381); +var379 = var382; +varonce378 = var379; +} +var383 = ((short int (*)(val*, val*))(var377->class->vft[COLOR_kernel__Object___61d_61d]))(var377, var379) /* == on */; +var_384 = var383; +if (var383){ +var375 = var_384; +} else { +var385 = ((val* (*)(val*))(var_mtype->class->vft[COLOR_model__MClassType__mclass]))(var_mtype) /* mclass on */; +var386 = ((val* (*)(val*))(var385->class->vft[COLOR_model__MClass__kind]))(var385) /* kind on */; +var387 = ((val* (*)(val*))(self->class->vft[COLOR_model__Object__extern_kind]))(self) /* extern_kind on */; +var388 = ((short int (*)(val*, val*))(var386->class->vft[COLOR_kernel__Object___33d_61d]))(var386, var387) /* != on */; +var375 = var388; +} +if (var375){ var389 = ((val* (*)(val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompiler__header]))(self) /* header on */; if (varonce390) { var391 = varonce390; } else { -var392 = "const struct class *class;"; -var393 = 26; +var392 = "struct instance_"; +var393 = 16; var394 = string__NativeString__to_s_with_length(var392, var393); var391 = var394; varonce390 = var391; } -((void (*)(val*, val*))(var389->class->vft[COLOR_abstract_compiler__CodeWriter__add_decl]))(var389, var391) /* add_decl on */; -var395 = ((val* (*)(val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompiler__header]))(self) /* header on */; -var396 = ((val* (*)(val*))(var_mtype->class->vft[COLOR_abstract_compiler__MType__ctype]))(var_mtype) /* ctype on */; -if (varonce397) { -var398 = varonce397; -} else { -var399 = " value;"; -var400 = 7; -var401 = string__NativeString__to_s_with_length(var399, var400); -var398 = var401; -varonce397 = var398; -} -var402 = NEW_array__Array(&type_array__Arraykernel__Object); -{ /* var402 = array_instance Array[Object] */ -var403 = 2; -var404 = NEW_array__NativeArray(var403, &type_array__NativeArraykernel__Object); -((struct instance_array__NativeArray*)var404)->values[0] = (val*) var396; -((struct instance_array__NativeArray*)var404)->values[1] = (val*) var398; -((void (*)(val*, val*, long))(var402->class->vft[COLOR_array__Array__with_native]))(var402, var404, var403) /* with_native on */; -CHECK_NEW_array__Array(var402); -} -var405 = ((val* (*)(val*))(var402->class->vft[COLOR_string__Object__to_s]))(var402) /* to_s on */; -((void (*)(val*, val*))(var395->class->vft[COLOR_abstract_compiler__CodeWriter__add_decl]))(var395, var405) /* add_decl on */; -var406 = ((val* (*)(val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompiler__header]))(self) /* header on */; -if (varonce407) { -var408 = varonce407; +if (varonce395) { +var396 = varonce395; +} else { +var397 = " {"; +var398 = 2; +var399 = string__NativeString__to_s_with_length(var397, var398); +var396 = var399; +varonce395 = var396; +} +var400 = NEW_array__Array(&type_array__Arraykernel__Object); +{ /* var400 = array_instance Array[Object] */ +var401 = 3; +var402 = NEW_array__NativeArray(var401, &type_array__NativeArraykernel__Object); +((struct instance_array__NativeArray*)var402)->values[0] = (val*) var391; +((struct instance_array__NativeArray*)var402)->values[1] = (val*) var_c_instance_name; +((struct instance_array__NativeArray*)var402)->values[2] = (val*) var396; +((void (*)(val*, val*, long))(var400->class->vft[COLOR_array__Array__with_native]))(var400, var402, var401) /* with_native on */; +} +var403 = ((val* (*)(val*))(var400->class->vft[COLOR_string__Object__to_s]))(var400) /* to_s on */; +((void (*)(val*, val*))(var389->class->vft[COLOR_abstract_compiler__CodeWriter__add_decl]))(var389, var403) /* add_decl on */; +var404 = ((val* (*)(val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompiler__header]))(self) /* header on */; +if (varonce405) { +var406 = varonce405; } else { -var409 = "};"; -var410 = 2; -var411 = string__NativeString__to_s_with_length(var409, var410); -var408 = var411; -varonce407 = var408; +var407 = "const struct class *class;"; +var408 = 26; +var409 = string__NativeString__to_s_with_length(var407, var408); +var406 = var409; +varonce405 = var406; +} +((void (*)(val*, val*))(var404->class->vft[COLOR_abstract_compiler__CodeWriter__add_decl]))(var404, var406) /* add_decl on */; +var410 = ((val* (*)(val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompiler__header]))(self) /* header on */; +var411 = ((val* (*)(val*))(var_mtype->class->vft[COLOR_abstract_compiler__MType__ctype]))(var_mtype) /* ctype on */; +if (varonce412) { +var413 = varonce412; +} else { +var414 = " value;"; +var415 = 7; +var416 = string__NativeString__to_s_with_length(var414, var415); +var413 = var416; +varonce412 = var413; } -((void (*)(val*, val*))(var406->class->vft[COLOR_abstract_compiler__CodeWriter__add_decl]))(var406, var408) /* add_decl on */; -var412 = ((val* (*)(val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompiler__header]))(self) /* header on */; -if (varonce413) { -var414 = varonce413; -} else { -var415 = "val* BOX_"; -var416 = 9; -var417 = string__NativeString__to_s_with_length(var415, var416); -var414 = var417; -varonce413 = var414; -} -if (varonce418) { -var419 = varonce418; -} else { -var420 = "("; -var421 = 1; -var422 = string__NativeString__to_s_with_length(var420, var421); -var419 = var422; -varonce418 = var419; -} -var423 = ((val* (*)(val*))(var_mtype->class->vft[COLOR_abstract_compiler__MType__ctype]))(var_mtype) /* ctype on */; -if (varonce424) { -var425 = varonce424; -} else { -var426 = ");"; -var427 = 2; -var428 = string__NativeString__to_s_with_length(var426, var427); -var425 = var428; -varonce424 = var425; -} -var429 = NEW_array__Array(&type_array__Arraykernel__Object); -{ /* var429 = array_instance Array[Object] */ -var430 = 5; -var431 = NEW_array__NativeArray(var430, &type_array__NativeArraykernel__Object); -((struct instance_array__NativeArray*)var431)->values[0] = (val*) var414; -((struct instance_array__NativeArray*)var431)->values[1] = (val*) var_c_name; -((struct instance_array__NativeArray*)var431)->values[2] = (val*) var419; -((struct instance_array__NativeArray*)var431)->values[3] = (val*) var423; -((struct instance_array__NativeArray*)var431)->values[4] = (val*) var425; -((void (*)(val*, val*, long))(var429->class->vft[COLOR_array__Array__with_native]))(var429, var431, var430) /* with_native on */; -CHECK_NEW_array__Array(var429); -} -var432 = ((val* (*)(val*))(var429->class->vft[COLOR_string__Object__to_s]))(var429) /* to_s on */; -((void (*)(val*, val*))(var412->class->vft[COLOR_abstract_compiler__CodeWriter__add_decl]))(var412, var432) /* add_decl on */; -if (varonce433) { -var434 = varonce433; -} else { -var435 = "/* allocate "; -var436 = 12; -var437 = string__NativeString__to_s_with_length(var435, var436); -var434 = var437; -varonce433 = var434; -} -if (varonce438) { -var439 = varonce438; -} else { -var440 = " */"; -var441 = 3; -var442 = string__NativeString__to_s_with_length(var440, var441); -var439 = var442; -varonce438 = var439; -} -var443 = NEW_array__Array(&type_array__Arraykernel__Object); -{ /* var443 = array_instance Array[Object] */ -var444 = 3; -var445 = NEW_array__NativeArray(var444, &type_array__NativeArraykernel__Object); -((struct instance_array__NativeArray*)var445)->values[0] = (val*) var434; -((struct instance_array__NativeArray*)var445)->values[1] = (val*) var_mtype; -((struct instance_array__NativeArray*)var445)->values[2] = (val*) var439; -((void (*)(val*, val*, long))(var443->class->vft[COLOR_array__Array__with_native]))(var443, var445, var444) /* with_native on */; -CHECK_NEW_array__Array(var443); -} -var446 = ((val* (*)(val*))(var443->class->vft[COLOR_string__Object__to_s]))(var443) /* to_s on */; -((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add_decl]))(var_v, var446) /* add_decl on */; +var417 = NEW_array__Array(&type_array__Arraykernel__Object); +{ /* var417 = array_instance Array[Object] */ +var418 = 2; +var419 = NEW_array__NativeArray(var418, &type_array__NativeArraykernel__Object); +((struct instance_array__NativeArray*)var419)->values[0] = (val*) var411; +((struct instance_array__NativeArray*)var419)->values[1] = (val*) var413; +((void (*)(val*, val*, long))(var417->class->vft[COLOR_array__Array__with_native]))(var417, var419, var418) /* with_native on */; +} +var420 = ((val* (*)(val*))(var417->class->vft[COLOR_string__Object__to_s]))(var417) /* to_s on */; +((void (*)(val*, val*))(var410->class->vft[COLOR_abstract_compiler__CodeWriter__add_decl]))(var410, var420) /* add_decl on */; +var421 = ((val* (*)(val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompiler__header]))(self) /* header on */; +if (varonce422) { +var423 = varonce422; +} else { +var424 = "};"; +var425 = 2; +var426 = string__NativeString__to_s_with_length(var424, var425); +var423 = var426; +varonce422 = var423; +} +((void (*)(val*, val*))(var421->class->vft[COLOR_abstract_compiler__CodeWriter__add_decl]))(var421, var423) /* add_decl on */; +} else { +} +if (varonce427) { +var428 = varonce427; +} else { +var429 = "BOX_"; +var430 = 4; +var431 = string__NativeString__to_s_with_length(var429, var430); +var428 = var431; +varonce427 = var428; +} +var432 = NEW_array__Array(&type_array__Arraykernel__Object); +{ /* var432 = array_instance Array[Object] */ +var433 = 2; +var434 = NEW_array__NativeArray(var433, &type_array__NativeArraykernel__Object); +((struct instance_array__NativeArray*)var434)->values[0] = (val*) var428; +((struct instance_array__NativeArray*)var434)->values[1] = (val*) var_c_name; +((void (*)(val*, val*, long))(var432->class->vft[COLOR_array__Array__with_native]))(var432, var434, var433) /* with_native on */; +} +var435 = ((val* (*)(val*))(var432->class->vft[COLOR_string__Object__to_s]))(var432) /* to_s on */; +if (varonce436) { +var437 = varonce436; +} else { +var438 = "val* BOX_"; +var439 = 9; +var440 = string__NativeString__to_s_with_length(var438, var439); +var437 = var440; +varonce436 = var437; +} +if (varonce441) { +var442 = varonce441; +} else { +var443 = "("; +var444 = 1; +var445 = string__NativeString__to_s_with_length(var443, var444); +var442 = var445; +varonce441 = var442; +} +var446 = ((val* (*)(val*))(var_mtype->class->vft[COLOR_abstract_compiler__MType__ctype]))(var_mtype) /* ctype on */; if (varonce447) { var448 = varonce447; } else { -var449 = "val* BOX_"; -var450 = 9; +var449 = ");"; +var450 = 2; var451 = string__NativeString__to_s_with_length(var449, var450); var448 = var451; varonce447 = var448; } -var452 = ((val* (*)(val*))(var_mtype->class->vft[COLOR_abstract_compiler__MType__c_name]))(var_mtype) /* c_name on */; -if (varonce453) { -var454 = varonce453; +var452 = NEW_array__Array(&type_array__Arraykernel__Object); +{ /* var452 = array_instance Array[Object] */ +var453 = 5; +var454 = NEW_array__NativeArray(var453, &type_array__NativeArraykernel__Object); +((struct instance_array__NativeArray*)var454)->values[0] = (val*) var437; +((struct instance_array__NativeArray*)var454)->values[1] = (val*) var_c_name; +((struct instance_array__NativeArray*)var454)->values[2] = (val*) var442; +((struct instance_array__NativeArray*)var454)->values[3] = (val*) var446; +((struct instance_array__NativeArray*)var454)->values[4] = (val*) var448; +((void (*)(val*, val*, long))(var452->class->vft[COLOR_array__Array__with_native]))(var452, var454, var453) /* with_native on */; +} +var455 = ((val* (*)(val*))(var452->class->vft[COLOR_string__Object__to_s]))(var452) /* to_s on */; +((void (*)(val*, val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompiler__provide_declaration]))(self, var435, var455) /* provide_declaration on */; +if (varonce456) { +var457 = varonce456; +} else { +var458 = "/* allocate "; +var459 = 12; +var460 = string__NativeString__to_s_with_length(var458, var459); +var457 = var460; +varonce456 = var457; +} +if (varonce461) { +var462 = varonce461; +} else { +var463 = " */"; +var464 = 3; +var465 = string__NativeString__to_s_with_length(var463, var464); +var462 = var465; +varonce461 = var462; +} +var466 = NEW_array__Array(&type_array__Arraykernel__Object); +{ /* var466 = array_instance Array[Object] */ +var467 = 3; +var468 = NEW_array__NativeArray(var467, &type_array__NativeArraykernel__Object); +((struct instance_array__NativeArray*)var468)->values[0] = (val*) var457; +((struct instance_array__NativeArray*)var468)->values[1] = (val*) var_mtype; +((struct instance_array__NativeArray*)var468)->values[2] = (val*) var462; +((void (*)(val*, val*, long))(var466->class->vft[COLOR_array__Array__with_native]))(var466, var468, var467) /* with_native on */; +} +var469 = ((val* (*)(val*))(var466->class->vft[COLOR_string__Object__to_s]))(var466) /* to_s on */; +((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add_decl]))(var_v, var469) /* add_decl on */; +if (varonce470) { +var471 = varonce470; +} else { +var472 = "val* BOX_"; +var473 = 9; +var474 = string__NativeString__to_s_with_length(var472, var473); +var471 = var474; +varonce470 = var471; +} +var475 = ((val* (*)(val*))(var_mtype->class->vft[COLOR_abstract_compiler__MType__c_name]))(var_mtype) /* c_name on */; +if (varonce476) { +var477 = varonce476; +} else { +var478 = "("; +var479 = 1; +var480 = string__NativeString__to_s_with_length(var478, var479); +var477 = var480; +varonce476 = var477; +} +var481 = ((val* (*)(val*))(var_mtype->class->vft[COLOR_abstract_compiler__MType__ctype]))(var_mtype) /* ctype on */; +if (varonce482) { +var483 = varonce482; } else { -var455 = "("; -var456 = 1; -var457 = string__NativeString__to_s_with_length(var455, var456); -var454 = var457; -varonce453 = var454; +var484 = " value) {"; +var485 = 9; +var486 = string__NativeString__to_s_with_length(var484, var485); +var483 = var486; +varonce482 = var483; } -var458 = ((val* (*)(val*))(var_mtype->class->vft[COLOR_abstract_compiler__MType__ctype]))(var_mtype) /* ctype on */; -if (varonce459) { -var460 = varonce459; +var487 = NEW_array__Array(&type_array__Arraykernel__Object); +{ /* var487 = array_instance Array[Object] */ +var488 = 5; +var489 = NEW_array__NativeArray(var488, &type_array__NativeArraykernel__Object); +((struct instance_array__NativeArray*)var489)->values[0] = (val*) var471; +((struct instance_array__NativeArray*)var489)->values[1] = (val*) var475; +((struct instance_array__NativeArray*)var489)->values[2] = (val*) var477; +((struct instance_array__NativeArray*)var489)->values[3] = (val*) var481; +((struct instance_array__NativeArray*)var489)->values[4] = (val*) var483; +((void (*)(val*, val*, long))(var487->class->vft[COLOR_array__Array__with_native]))(var487, var489, var488) /* with_native on */; +} +var490 = ((val* (*)(val*))(var487->class->vft[COLOR_string__Object__to_s]))(var487) /* to_s on */; +((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add_decl]))(var_v, var490) /* add_decl on */; +if (varonce491) { +var492 = varonce491; } else { -var461 = " value) {"; -var462 = 9; -var463 = string__NativeString__to_s_with_length(var461, var462); -var460 = var463; -varonce459 = var460; +var493 = "struct instance_"; +var494 = 16; +var495 = string__NativeString__to_s_with_length(var493, var494); +var492 = var495; +varonce491 = var492; } -var464 = NEW_array__Array(&type_array__Arraykernel__Object); -{ /* var464 = array_instance Array[Object] */ -var465 = 5; -var466 = NEW_array__NativeArray(var465, &type_array__NativeArraykernel__Object); -((struct instance_array__NativeArray*)var466)->values[0] = (val*) var448; -((struct instance_array__NativeArray*)var466)->values[1] = (val*) var452; -((struct instance_array__NativeArray*)var466)->values[2] = (val*) var454; -((struct instance_array__NativeArray*)var466)->values[3] = (val*) var458; -((struct instance_array__NativeArray*)var466)->values[4] = (val*) var460; -((void (*)(val*, val*, long))(var464->class->vft[COLOR_array__Array__with_native]))(var464, var466, var465) /* with_native on */; -CHECK_NEW_array__Array(var464); -} -var467 = ((val* (*)(val*))(var464->class->vft[COLOR_string__Object__to_s]))(var464) /* to_s on */; -((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add_decl]))(var_v, var467) /* add_decl on */; -if (varonce468) { -var469 = varonce468; -} else { -var470 = "struct instance_"; -var471 = 16; -var472 = string__NativeString__to_s_with_length(var470, var471); -var469 = var472; -varonce468 = var469; -} -if (varonce473) { -var474 = varonce473; -} else { -var475 = "*res = nit_alloc(sizeof(struct instance_"; -var476 = 40; -var477 = string__NativeString__to_s_with_length(var475, var476); -var474 = var477; -varonce473 = var474; -} -if (varonce478) { -var479 = varonce478; -} else { -var480 = "));"; -var481 = 3; -var482 = string__NativeString__to_s_with_length(var480, var481); -var479 = var482; -varonce478 = var479; -} -var483 = NEW_array__Array(&type_array__Arraykernel__Object); -{ /* var483 = array_instance Array[Object] */ -var484 = 5; -var485 = NEW_array__NativeArray(var484, &type_array__NativeArraykernel__Object); -((struct instance_array__NativeArray*)var485)->values[0] = (val*) var469; -((struct instance_array__NativeArray*)var485)->values[1] = (val*) var_c_name; -((struct instance_array__NativeArray*)var485)->values[2] = (val*) var474; -((struct instance_array__NativeArray*)var485)->values[3] = (val*) var_c_name; -((struct instance_array__NativeArray*)var485)->values[4] = (val*) var479; -((void (*)(val*, val*, long))(var483->class->vft[COLOR_array__Array__with_native]))(var483, var485, var484) /* with_native on */; -CHECK_NEW_array__Array(var483); -} -var486 = ((val* (*)(val*))(var483->class->vft[COLOR_string__Object__to_s]))(var483) /* to_s on */; -((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(var_v, var486) /* add on */; -if (varonce487) { -var488 = varonce487; -} else { -var489 = "class_"; -var490 = 6; -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 = 2; -var494 = NEW_array__NativeArray(var493, &type_array__NativeArraykernel__Object); -((struct instance_array__NativeArray*)var494)->values[0] = (val*) var488; -((struct instance_array__NativeArray*)var494)->values[1] = (val*) var_c_name; -((void (*)(val*, val*, long))(var492->class->vft[COLOR_array__Array__with_native]))(var492, var494, var493) /* with_native on */; -CHECK_NEW_array__Array(var492); -} -var495 = ((val* (*)(val*))(var492->class->vft[COLOR_string__Object__to_s]))(var492) /* to_s on */; -((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__require_declaration]))(var_v, var495) /* require_declaration on */; if (varonce496) { var497 = varonce496; } else { -var498 = "res->class = &class_"; -var499 = 20; +var498 = "*res = nit_alloc(sizeof(struct instance_"; +var499 = 40; var500 = string__NativeString__to_s_with_length(var498, var499); var497 = var500; varonce496 = var497; @@ -3287,266 +3267,264 @@ varonce496 = var497; if (varonce501) { var502 = varonce501; } else { -var503 = ";"; -var504 = 1; +var503 = "));"; +var504 = 3; var505 = string__NativeString__to_s_with_length(var503, var504); var502 = var505; varonce501 = var502; } var506 = NEW_array__Array(&type_array__Arraykernel__Object); { /* var506 = array_instance Array[Object] */ -var507 = 3; +var507 = 5; var508 = NEW_array__NativeArray(var507, &type_array__NativeArraykernel__Object); -((struct instance_array__NativeArray*)var508)->values[0] = (val*) var497; -((struct instance_array__NativeArray*)var508)->values[1] = (val*) var_c_name; -((struct instance_array__NativeArray*)var508)->values[2] = (val*) var502; +((struct instance_array__NativeArray*)var508)->values[0] = (val*) var492; +((struct instance_array__NativeArray*)var508)->values[1] = (val*) var_c_instance_name; +((struct instance_array__NativeArray*)var508)->values[2] = (val*) var497; +((struct instance_array__NativeArray*)var508)->values[3] = (val*) var_c_instance_name; +((struct instance_array__NativeArray*)var508)->values[4] = (val*) var502; ((void (*)(val*, val*, long))(var506->class->vft[COLOR_array__Array__with_native]))(var506, var508, var507) /* with_native on */; -CHECK_NEW_array__Array(var506); } var509 = ((val* (*)(val*))(var506->class->vft[COLOR_string__Object__to_s]))(var506) /* to_s on */; ((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(var_v, var509) /* add on */; if (varonce510) { var511 = varonce510; } else { -var512 = "res->value = value;"; -var513 = 19; +var512 = "class_"; +var513 = 6; var514 = string__NativeString__to_s_with_length(var512, var513); var511 = var514; varonce510 = var511; } -((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(var_v, var511) /* add on */; -if (varonce515) { -var516 = varonce515; -} else { -var517 = "return (val*)res;"; -var518 = 17; -var519 = string__NativeString__to_s_with_length(var517, var518); -var516 = var519; -varonce515 = var516; -} -((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(var_v, var516) /* add on */; -if (varonce520) { -var521 = varonce520; -} else { -var522 = "}"; -var523 = 1; -var524 = string__NativeString__to_s_with_length(var522, var523); -var521 = var524; -varonce520 = var521; -} -((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(var_v, var521) /* add on */; -goto RET_LABEL; -} else { -var525 = ((val* (*)(val*))(var_mclass->class->vft[COLOR_model__MClass__name]))(var_mclass) /* name on */; -if (varonce526) { -var527 = varonce526; -} else { -var528 = "NativeArray"; -var529 = 11; -var530 = string__NativeString__to_s_with_length(var528, var529); -var527 = var530; -varonce526 = var527; -} -var531 = ((short int (*)(val*, val*))(var525->class->vft[COLOR_kernel__Object___61d_61d]))(var525, var527) /* == on */; -if (var531){ -var532 = ((val* (*)(val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompiler__header]))(self) /* header on */; +var515 = NEW_array__Array(&type_array__Arraykernel__Object); +{ /* var515 = array_instance Array[Object] */ +var516 = 2; +var517 = NEW_array__NativeArray(var516, &type_array__NativeArraykernel__Object); +((struct instance_array__NativeArray*)var517)->values[0] = (val*) var511; +((struct instance_array__NativeArray*)var517)->values[1] = (val*) var_c_name; +((void (*)(val*, val*, long))(var515->class->vft[COLOR_array__Array__with_native]))(var515, var517, var516) /* with_native on */; +} +var518 = ((val* (*)(val*))(var515->class->vft[COLOR_string__Object__to_s]))(var515) /* to_s on */; +((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__require_declaration]))(var_v, var518) /* require_declaration on */; +if (varonce519) { +var520 = varonce519; +} else { +var521 = "res->class = &class_"; +var522 = 20; +var523 = string__NativeString__to_s_with_length(var521, var522); +var520 = var523; +varonce519 = var520; +} +if (varonce524) { +var525 = varonce524; +} else { +var526 = ";"; +var527 = 1; +var528 = string__NativeString__to_s_with_length(var526, var527); +var525 = var528; +varonce524 = var525; +} +var529 = NEW_array__Array(&type_array__Arraykernel__Object); +{ /* var529 = array_instance Array[Object] */ +var530 = 3; +var531 = NEW_array__NativeArray(var530, &type_array__NativeArraykernel__Object); +((struct instance_array__NativeArray*)var531)->values[0] = (val*) var520; +((struct instance_array__NativeArray*)var531)->values[1] = (val*) var_c_name; +((struct instance_array__NativeArray*)var531)->values[2] = (val*) var525; +((void (*)(val*, val*, long))(var529->class->vft[COLOR_array__Array__with_native]))(var529, var531, var530) /* with_native on */; +} +var532 = ((val* (*)(val*))(var529->class->vft[COLOR_string__Object__to_s]))(var529) /* to_s on */; +((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(var_v, var532) /* add on */; if (varonce533) { var534 = varonce533; } else { -var535 = "struct instance_"; -var536 = 16; +var535 = "res->value = value;"; +var536 = 19; var537 = string__NativeString__to_s_with_length(var535, var536); var534 = var537; varonce533 = var534; } +((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(var_v, var534) /* add on */; if (varonce538) { var539 = varonce538; } else { -var540 = " {"; -var541 = 2; +var540 = "return (val*)res;"; +var541 = 17; var542 = string__NativeString__to_s_with_length(var540, var541); var539 = var542; varonce538 = var539; } -var543 = NEW_array__Array(&type_array__Arraykernel__Object); -{ /* var543 = array_instance Array[Object] */ -var544 = 3; -var545 = NEW_array__NativeArray(var544, &type_array__NativeArraykernel__Object); -((struct instance_array__NativeArray*)var545)->values[0] = (val*) var534; -((struct instance_array__NativeArray*)var545)->values[1] = (val*) var_c_name; -((struct instance_array__NativeArray*)var545)->values[2] = (val*) var539; -((void (*)(val*, val*, long))(var543->class->vft[COLOR_array__Array__with_native]))(var543, var545, var544) /* with_native on */; -CHECK_NEW_array__Array(var543); -} -var546 = ((val* (*)(val*))(var543->class->vft[COLOR_string__Object__to_s]))(var543) /* to_s on */; -((void (*)(val*, val*))(var532->class->vft[COLOR_abstract_compiler__CodeWriter__add_decl]))(var532, var546) /* add_decl on */; -var547 = ((val* (*)(val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompiler__header]))(self) /* header on */; -if (varonce548) { -var549 = varonce548; -} else { -var550 = "const struct class *class;"; -var551 = 26; -var552 = string__NativeString__to_s_with_length(var550, var551); -var549 = var552; -varonce548 = var549; -} -((void (*)(val*, val*))(var547->class->vft[COLOR_abstract_compiler__CodeWriter__add_decl]))(var547, var549) /* add_decl on */; -var553 = ((val* (*)(val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompiler__header]))(self) /* header on */; -if (varonce554) { -var555 = varonce554; -} else { -var556 = "val* values[];"; -var557 = 14; -var558 = string__NativeString__to_s_with_length(var556, var557); -var555 = var558; -varonce554 = var555; -} -((void (*)(val*, val*))(var553->class->vft[COLOR_abstract_compiler__CodeWriter__add_decl]))(var553, var555) /* add_decl on */; -var559 = ((val* (*)(val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompiler__header]))(self) /* header on */; -if (varonce560) { -var561 = varonce560; -} else { -var562 = "};"; -var563 = 2; -var564 = string__NativeString__to_s_with_length(var562, var563); -var561 = var564; -varonce560 = var561; -} -((void (*)(val*, val*))(var559->class->vft[COLOR_abstract_compiler__CodeWriter__add_decl]))(var559, var561) /* add_decl on */; -if (varonce565) { -var566 = varonce565; -} else { -var567 = "NEW_"; -var568 = 4; -var569 = string__NativeString__to_s_with_length(var567, var568); -var566 = var569; -varonce565 = var566; -} -var570 = NEW_array__Array(&type_array__Arraykernel__Object); -{ /* var570 = array_instance Array[Object] */ -var571 = 2; -var572 = NEW_array__NativeArray(var571, &type_array__NativeArraykernel__Object); -((struct instance_array__NativeArray*)var572)->values[0] = (val*) var566; -((struct instance_array__NativeArray*)var572)->values[1] = (val*) var_c_name; -((void (*)(val*, val*, long))(var570->class->vft[COLOR_array__Array__with_native]))(var570, var572, var571) /* with_native on */; -CHECK_NEW_array__Array(var570); -} -var573 = ((val* (*)(val*))(var570->class->vft[COLOR_string__Object__to_s]))(var570) /* to_s on */; -var574 = ((val* (*)(val*))(var_mtype->class->vft[COLOR_abstract_compiler__MType__ctype]))(var_mtype) /* ctype on */; -if (varonce575) { -var576 = varonce575; -} else { -var577 = " NEW_"; -var578 = 5; -var579 = string__NativeString__to_s_with_length(var577, var578); -var576 = var579; -varonce575 = var576; -} -if (varonce580) { -var581 = varonce580; -} else { -var582 = "(int length);"; -var583 = 13; -var584 = string__NativeString__to_s_with_length(var582, var583); -var581 = var584; -varonce580 = var581; -} -var585 = NEW_array__Array(&type_array__Arraykernel__Object); -{ /* var585 = array_instance Array[Object] */ -var586 = 4; -var587 = NEW_array__NativeArray(var586, &type_array__NativeArraykernel__Object); -((struct instance_array__NativeArray*)var587)->values[0] = (val*) var574; -((struct instance_array__NativeArray*)var587)->values[1] = (val*) var576; -((struct instance_array__NativeArray*)var587)->values[2] = (val*) var_c_name; -((struct instance_array__NativeArray*)var587)->values[3] = (val*) var581; -((void (*)(val*, val*, long))(var585->class->vft[COLOR_array__Array__with_native]))(var585, var587, var586) /* with_native on */; -CHECK_NEW_array__Array(var585); -} -var588 = ((val* (*)(val*))(var585->class->vft[COLOR_string__Object__to_s]))(var585) /* to_s on */; -((void (*)(val*, val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompiler__provide_declaration]))(self, var573, var588) /* provide_declaration on */; -if (varonce589) { -var590 = varonce589; -} else { -var591 = "/* allocate "; -var592 = 12; -var593 = string__NativeString__to_s_with_length(var591, var592); -var590 = var593; -varonce589 = var590; -} -if (varonce594) { -var595 = varonce594; -} else { -var596 = " */"; -var597 = 3; -var598 = string__NativeString__to_s_with_length(var596, var597); -var595 = var598; -varonce594 = var595; -} -var599 = NEW_array__Array(&type_array__Arraykernel__Object); -{ /* var599 = array_instance Array[Object] */ -var600 = 3; -var601 = NEW_array__NativeArray(var600, &type_array__NativeArraykernel__Object); -((struct instance_array__NativeArray*)var601)->values[0] = (val*) var590; -((struct instance_array__NativeArray*)var601)->values[1] = (val*) var_mtype; -((struct instance_array__NativeArray*)var601)->values[2] = (val*) var595; -((void (*)(val*, val*, long))(var599->class->vft[COLOR_array__Array__with_native]))(var599, var601, var600) /* with_native on */; -CHECK_NEW_array__Array(var599); -} -var602 = ((val* (*)(val*))(var599->class->vft[COLOR_string__Object__to_s]))(var599) /* to_s on */; -((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add_decl]))(var_v, var602) /* add_decl on */; -var603 = ((val* (*)(val*))(var_mtype->class->vft[COLOR_abstract_compiler__MType__ctype]))(var_mtype) /* ctype on */; -if (varonce604) { -var605 = varonce604; -} else { -var606 = " NEW_"; -var607 = 5; -var608 = string__NativeString__to_s_with_length(var606, var607); -var605 = var608; -varonce604 = var605; -} -if (varonce609) { -var610 = varonce609; -} else { -var611 = "(int length) {"; -var612 = 14; -var613 = string__NativeString__to_s_with_length(var611, var612); -var610 = var613; -varonce609 = var610; -} -var614 = NEW_array__Array(&type_array__Arraykernel__Object); -{ /* var614 = array_instance Array[Object] */ -var615 = 4; -var616 = NEW_array__NativeArray(var615, &type_array__NativeArraykernel__Object); -((struct instance_array__NativeArray*)var616)->values[0] = (val*) var603; -((struct instance_array__NativeArray*)var616)->values[1] = (val*) var605; -((struct instance_array__NativeArray*)var616)->values[2] = (val*) var_c_name; -((struct instance_array__NativeArray*)var616)->values[3] = (val*) var610; -((void (*)(val*, val*, long))(var614->class->vft[COLOR_array__Array__with_native]))(var614, var616, var615) /* with_native on */; -CHECK_NEW_array__Array(var614); -} -var617 = ((val* (*)(val*))(var614->class->vft[COLOR_string__Object__to_s]))(var614) /* to_s on */; -((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add_decl]))(var_v, var617) /* add_decl on */; -if (varonce618) { -var619 = varonce618; -} else { -var620 = "self"; -var621 = 4; -var622 = string__NativeString__to_s_with_length(var620, var621); -var619 = var622; -varonce618 = var619; -} -var623 = ((val* (*)(val*, val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__new_named_var]))(var_v, var_mtype, var619) /* new_named_var on */; -var_res = var623; -var624 = 1; -((void (*)(val*, short int))(var_res->class->vft[COLOR_abstract_compiler__RuntimeVariable__is_exact_61d]))(var_res, var624) /* is_exact= on */; -var625 = ((val* (*)(val*))(var_mtype->class->vft[COLOR_model__MClassType__arguments]))(var_mtype) /* arguments on */; -var626 = ((val* (*)(val*))(var625->class->vft[COLOR_abstract_collection__Collection__first]))(var625) /* first on */; -var_mtype_elt = var626; +((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(var_v, var539) /* add on */; +if (varonce543) { +var544 = varonce543; +} else { +var545 = "}"; +var546 = 1; +var547 = string__NativeString__to_s_with_length(var545, var546); +var544 = var547; +varonce543 = var544; +} +((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(var_v, var544) /* add on */; +goto RET_LABEL; +} else { +var548 = ((val* (*)(val*))(var_mclass->class->vft[COLOR_model__MClass__name]))(var_mclass) /* name on */; +if (varonce549) { +var550 = varonce549; +} else { +var551 = "NativeArray"; +var552 = 11; +var553 = string__NativeString__to_s_with_length(var551, var552); +var550 = var553; +varonce549 = var550; +} +var554 = ((short int (*)(val*, val*))(var548->class->vft[COLOR_kernel__Object___61d_61d]))(var548, var550) /* == on */; +if (var554){ +var555 = ((val* (*)(val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompiler__header]))(self) /* header on */; +if (varonce556) { +var557 = varonce556; +} else { +var558 = "struct instance_"; +var559 = 16; +var560 = string__NativeString__to_s_with_length(var558, var559); +var557 = var560; +varonce556 = var557; +} +if (varonce561) { +var562 = varonce561; +} else { +var563 = " {"; +var564 = 2; +var565 = string__NativeString__to_s_with_length(var563, var564); +var562 = var565; +varonce561 = var562; +} +var566 = NEW_array__Array(&type_array__Arraykernel__Object); +{ /* var566 = array_instance Array[Object] */ +var567 = 3; +var568 = NEW_array__NativeArray(var567, &type_array__NativeArraykernel__Object); +((struct instance_array__NativeArray*)var568)->values[0] = (val*) var557; +((struct instance_array__NativeArray*)var568)->values[1] = (val*) var_c_name; +((struct instance_array__NativeArray*)var568)->values[2] = (val*) var562; +((void (*)(val*, val*, long))(var566->class->vft[COLOR_array__Array__with_native]))(var566, var568, var567) /* with_native on */; +} +var569 = ((val* (*)(val*))(var566->class->vft[COLOR_string__Object__to_s]))(var566) /* to_s on */; +((void (*)(val*, val*))(var555->class->vft[COLOR_abstract_compiler__CodeWriter__add_decl]))(var555, var569) /* add_decl on */; +var570 = ((val* (*)(val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompiler__header]))(self) /* header on */; +if (varonce571) { +var572 = varonce571; +} else { +var573 = "const struct class *class;"; +var574 = 26; +var575 = string__NativeString__to_s_with_length(var573, var574); +var572 = var575; +varonce571 = var572; +} +((void (*)(val*, val*))(var570->class->vft[COLOR_abstract_compiler__CodeWriter__add_decl]))(var570, var572) /* add_decl on */; +var576 = ((val* (*)(val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompiler__header]))(self) /* header on */; +if (varonce577) { +var578 = varonce577; +} else { +var579 = "val* values[];"; +var580 = 14; +var581 = string__NativeString__to_s_with_length(var579, var580); +var578 = var581; +varonce577 = var578; +} +((void (*)(val*, val*))(var576->class->vft[COLOR_abstract_compiler__CodeWriter__add_decl]))(var576, var578) /* add_decl on */; +var582 = ((val* (*)(val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompiler__header]))(self) /* header on */; +if (varonce583) { +var584 = varonce583; +} else { +var585 = "};"; +var586 = 2; +var587 = string__NativeString__to_s_with_length(var585, var586); +var584 = var587; +varonce583 = var584; +} +((void (*)(val*, val*))(var582->class->vft[COLOR_abstract_compiler__CodeWriter__add_decl]))(var582, var584) /* add_decl on */; +if (varonce588) { +var589 = varonce588; +} else { +var590 = "NEW_"; +var591 = 4; +var592 = string__NativeString__to_s_with_length(var590, var591); +var589 = var592; +varonce588 = var589; +} +var593 = NEW_array__Array(&type_array__Arraykernel__Object); +{ /* var593 = array_instance Array[Object] */ +var594 = 2; +var595 = NEW_array__NativeArray(var594, &type_array__NativeArraykernel__Object); +((struct instance_array__NativeArray*)var595)->values[0] = (val*) var589; +((struct instance_array__NativeArray*)var595)->values[1] = (val*) var_c_name; +((void (*)(val*, val*, long))(var593->class->vft[COLOR_array__Array__with_native]))(var593, var595, var594) /* with_native on */; +} +var596 = ((val* (*)(val*))(var593->class->vft[COLOR_string__Object__to_s]))(var593) /* to_s on */; +var597 = ((val* (*)(val*))(var_mtype->class->vft[COLOR_abstract_compiler__MType__ctype]))(var_mtype) /* ctype on */; +if (varonce598) { +var599 = varonce598; +} else { +var600 = " NEW_"; +var601 = 5; +var602 = string__NativeString__to_s_with_length(var600, var601); +var599 = var602; +varonce598 = var599; +} +if (varonce603) { +var604 = varonce603; +} else { +var605 = "(int length);"; +var606 = 13; +var607 = string__NativeString__to_s_with_length(var605, var606); +var604 = var607; +varonce603 = var604; +} +var608 = NEW_array__Array(&type_array__Arraykernel__Object); +{ /* var608 = array_instance Array[Object] */ +var609 = 4; +var610 = NEW_array__NativeArray(var609, &type_array__NativeArraykernel__Object); +((struct instance_array__NativeArray*)var610)->values[0] = (val*) var597; +((struct instance_array__NativeArray*)var610)->values[1] = (val*) var599; +((struct instance_array__NativeArray*)var610)->values[2] = (val*) var_c_name; +((struct instance_array__NativeArray*)var610)->values[3] = (val*) var604; +((void (*)(val*, val*, long))(var608->class->vft[COLOR_array__Array__with_native]))(var608, var610, var609) /* with_native on */; +} +var611 = ((val* (*)(val*))(var608->class->vft[COLOR_string__Object__to_s]))(var608) /* to_s on */; +((void (*)(val*, val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompiler__provide_declaration]))(self, var596, var611) /* provide_declaration on */; +if (varonce612) { +var613 = varonce612; +} else { +var614 = "/* allocate "; +var615 = 12; +var616 = string__NativeString__to_s_with_length(var614, var615); +var613 = var616; +varonce612 = var613; +} +if (varonce617) { +var618 = varonce617; +} else { +var619 = " */"; +var620 = 3; +var621 = string__NativeString__to_s_with_length(var619, var620); +var618 = var621; +varonce617 = var618; +} +var622 = NEW_array__Array(&type_array__Arraykernel__Object); +{ /* var622 = array_instance Array[Object] */ +var623 = 3; +var624 = NEW_array__NativeArray(var623, &type_array__NativeArraykernel__Object); +((struct instance_array__NativeArray*)var624)->values[0] = (val*) var613; +((struct instance_array__NativeArray*)var624)->values[1] = (val*) var_mtype; +((struct instance_array__NativeArray*)var624)->values[2] = (val*) var618; +((void (*)(val*, val*, long))(var622->class->vft[COLOR_array__Array__with_native]))(var622, var624, var623) /* with_native on */; +} +var625 = ((val* (*)(val*))(var622->class->vft[COLOR_string__Object__to_s]))(var622) /* to_s on */; +((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add_decl]))(var_v, var625) /* add_decl on */; +var626 = ((val* (*)(val*))(var_mtype->class->vft[COLOR_abstract_compiler__MType__ctype]))(var_mtype) /* ctype on */; if (varonce627) { var628 = varonce627; } else { -var629 = " = nit_alloc(sizeof(struct instance_"; -var630 = 36; +var629 = " NEW_"; +var630 = 5; var631 = string__NativeString__to_s_with_length(var629, var630); var628 = var631; varonce627 = var628; @@ -3554,273 +3532,267 @@ varonce627 = var628; if (varonce632) { var633 = varonce632; } else { -var634 = ") + length*sizeof("; -var635 = 18; +var634 = "(int length) {"; +var635 = 14; var636 = string__NativeString__to_s_with_length(var634, var635); var633 = var636; varonce632 = var633; } -var637 = ((val* (*)(val*))(var_mtype_elt->class->vft[COLOR_abstract_compiler__MType__ctype]))(var_mtype_elt) /* ctype on */; -if (varonce638) { -var639 = varonce638; -} else { -var640 = "));"; -var641 = 3; -var642 = string__NativeString__to_s_with_length(var640, var641); -var639 = var642; -varonce638 = var639; -} -var643 = NEW_array__Array(&type_array__Arraykernel__Object); -{ /* var643 = array_instance Array[Object] */ -var644 = 6; -var645 = NEW_array__NativeArray(var644, &type_array__NativeArraykernel__Object); -((struct instance_array__NativeArray*)var645)->values[0] = (val*) var_res; -((struct instance_array__NativeArray*)var645)->values[1] = (val*) var628; -((struct instance_array__NativeArray*)var645)->values[2] = (val*) var_c_name; -((struct instance_array__NativeArray*)var645)->values[3] = (val*) var633; -((struct instance_array__NativeArray*)var645)->values[4] = (val*) var637; -((struct instance_array__NativeArray*)var645)->values[5] = (val*) var639; -((void (*)(val*, val*, long))(var643->class->vft[COLOR_array__Array__with_native]))(var643, var645, var644) /* with_native on */; -CHECK_NEW_array__Array(var643); -} -var646 = ((val* (*)(val*))(var643->class->vft[COLOR_string__Object__to_s]))(var643) /* to_s on */; -((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(var_v, var646) /* add on */; -if (varonce647) { -var648 = varonce647; -} else { -var649 = "class_"; -var650 = 6; -var651 = string__NativeString__to_s_with_length(var649, var650); -var648 = var651; -varonce647 = var648; -} -var652 = NEW_array__Array(&type_array__Arraykernel__Object); -{ /* var652 = array_instance Array[Object] */ -var653 = 2; -var654 = NEW_array__NativeArray(var653, &type_array__NativeArraykernel__Object); -((struct instance_array__NativeArray*)var654)->values[0] = (val*) var648; -((struct instance_array__NativeArray*)var654)->values[1] = (val*) var_c_name; -((void (*)(val*, val*, long))(var652->class->vft[COLOR_array__Array__with_native]))(var652, var654, var653) /* with_native on */; -CHECK_NEW_array__Array(var652); -} -var655 = ((val* (*)(val*))(var652->class->vft[COLOR_string__Object__to_s]))(var652) /* to_s on */; -((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__require_declaration]))(var_v, var655) /* require_declaration on */; -if (varonce656) { -var657 = varonce656; -} else { -var658 = "->class = &class_"; -var659 = 17; -var660 = string__NativeString__to_s_with_length(var658, var659); -var657 = var660; -varonce656 = var657; +var637 = NEW_array__Array(&type_array__Arraykernel__Object); +{ /* var637 = array_instance Array[Object] */ +var638 = 4; +var639 = NEW_array__NativeArray(var638, &type_array__NativeArraykernel__Object); +((struct instance_array__NativeArray*)var639)->values[0] = (val*) var626; +((struct instance_array__NativeArray*)var639)->values[1] = (val*) var628; +((struct instance_array__NativeArray*)var639)->values[2] = (val*) var_c_name; +((struct instance_array__NativeArray*)var639)->values[3] = (val*) var633; +((void (*)(val*, val*, long))(var637->class->vft[COLOR_array__Array__with_native]))(var637, var639, var638) /* with_native on */; +} +var640 = ((val* (*)(val*))(var637->class->vft[COLOR_string__Object__to_s]))(var637) /* to_s on */; +((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add_decl]))(var_v, var640) /* add_decl on */; +if (varonce641) { +var642 = varonce641; +} else { +var643 = "self"; +var644 = 4; +var645 = string__NativeString__to_s_with_length(var643, var644); +var642 = var645; +varonce641 = var642; } +var646 = ((val* (*)(val*, val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__new_named_var]))(var_v, var_mtype, var642) /* new_named_var on */; +var_res = var646; +var647 = 1; +((void (*)(val*, short int))(var_res->class->vft[COLOR_abstract_compiler__RuntimeVariable__is_exact_61d]))(var_res, var647) /* is_exact= on */; +var648 = ((val* (*)(val*))(var_mtype->class->vft[COLOR_model__MClassType__arguments]))(var_mtype) /* arguments on */; +var649 = ((val* (*)(val*))(var648->class->vft[COLOR_abstract_collection__Collection__first]))(var648) /* first on */; +var_mtype_elt = var649; +if (varonce650) { +var651 = varonce650; +} else { +var652 = " = nit_alloc(sizeof(struct instance_"; +var653 = 36; +var654 = string__NativeString__to_s_with_length(var652, var653); +var651 = var654; +varonce650 = var651; +} +if (varonce655) { +var656 = varonce655; +} else { +var657 = ") + length*sizeof("; +var658 = 18; +var659 = string__NativeString__to_s_with_length(var657, var658); +var656 = var659; +varonce655 = var656; +} +var660 = ((val* (*)(val*))(var_mtype_elt->class->vft[COLOR_abstract_compiler__MType__ctype]))(var_mtype_elt) /* ctype on */; if (varonce661) { var662 = varonce661; } else { -var663 = ";"; -var664 = 1; +var663 = "));"; +var664 = 3; var665 = string__NativeString__to_s_with_length(var663, var664); var662 = var665; varonce661 = var662; } var666 = NEW_array__Array(&type_array__Arraykernel__Object); { /* var666 = array_instance Array[Object] */ -var667 = 4; +var667 = 6; var668 = NEW_array__NativeArray(var667, &type_array__NativeArraykernel__Object); ((struct instance_array__NativeArray*)var668)->values[0] = (val*) var_res; -((struct instance_array__NativeArray*)var668)->values[1] = (val*) var657; +((struct instance_array__NativeArray*)var668)->values[1] = (val*) var651; ((struct instance_array__NativeArray*)var668)->values[2] = (val*) var_c_name; -((struct instance_array__NativeArray*)var668)->values[3] = (val*) var662; +((struct instance_array__NativeArray*)var668)->values[3] = (val*) var656; +((struct instance_array__NativeArray*)var668)->values[4] = (val*) var660; +((struct instance_array__NativeArray*)var668)->values[5] = (val*) var662; ((void (*)(val*, val*, long))(var666->class->vft[COLOR_array__Array__with_native]))(var666, var668, var667) /* with_native on */; -CHECK_NEW_array__Array(var666); } var669 = ((val* (*)(val*))(var666->class->vft[COLOR_string__Object__to_s]))(var666) /* to_s on */; ((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(var_v, var669) /* add on */; if (varonce670) { var671 = varonce670; } else { -var672 = "return "; -var673 = 7; +var672 = "class_"; +var673 = 6; var674 = string__NativeString__to_s_with_length(var672, var673); var671 = var674; varonce670 = var671; } -if (varonce675) { -var676 = varonce675; -} else { -var677 = ";"; -var678 = 1; -var679 = string__NativeString__to_s_with_length(var677, var678); -var676 = var679; -varonce675 = var676; -} -var680 = NEW_array__Array(&type_array__Arraykernel__Object); -{ /* var680 = array_instance Array[Object] */ -var681 = 3; -var682 = NEW_array__NativeArray(var681, &type_array__NativeArraykernel__Object); -((struct instance_array__NativeArray*)var682)->values[0] = (val*) var671; -((struct instance_array__NativeArray*)var682)->values[1] = (val*) var_res; -((struct instance_array__NativeArray*)var682)->values[2] = (val*) var676; -((void (*)(val*, val*, long))(var680->class->vft[COLOR_array__Array__with_native]))(var680, var682, var681) /* with_native on */; -CHECK_NEW_array__Array(var680); -} -var683 = ((val* (*)(val*))(var680->class->vft[COLOR_string__Object__to_s]))(var680) /* to_s on */; -((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(var_v, var683) /* add on */; +var675 = NEW_array__Array(&type_array__Arraykernel__Object); +{ /* var675 = array_instance Array[Object] */ +var676 = 2; +var677 = NEW_array__NativeArray(var676, &type_array__NativeArraykernel__Object); +((struct instance_array__NativeArray*)var677)->values[0] = (val*) var671; +((struct instance_array__NativeArray*)var677)->values[1] = (val*) var_c_name; +((void (*)(val*, val*, long))(var675->class->vft[COLOR_array__Array__with_native]))(var675, var677, var676) /* with_native on */; +} +var678 = ((val* (*)(val*))(var675->class->vft[COLOR_string__Object__to_s]))(var675) /* to_s on */; +((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__require_declaration]))(var_v, var678) /* require_declaration on */; +if (varonce679) { +var680 = varonce679; +} else { +var681 = "->class = &class_"; +var682 = 17; +var683 = string__NativeString__to_s_with_length(var681, var682); +var680 = var683; +varonce679 = var680; +} if (varonce684) { var685 = varonce684; } else { -var686 = "}"; +var686 = ";"; var687 = 1; var688 = string__NativeString__to_s_with_length(var686, var687); var685 = var688; varonce684 = var685; } -((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(var_v, var685) /* add on */; +var689 = NEW_array__Array(&type_array__Arraykernel__Object); +{ /* var689 = array_instance Array[Object] */ +var690 = 4; +var691 = NEW_array__NativeArray(var690, &type_array__NativeArraykernel__Object); +((struct instance_array__NativeArray*)var691)->values[0] = (val*) var_res; +((struct instance_array__NativeArray*)var691)->values[1] = (val*) var680; +((struct instance_array__NativeArray*)var691)->values[2] = (val*) var_c_name; +((struct instance_array__NativeArray*)var691)->values[3] = (val*) var685; +((void (*)(val*, val*, long))(var689->class->vft[COLOR_array__Array__with_native]))(var689, var691, var690) /* with_native on */; +} +var692 = ((val* (*)(val*))(var689->class->vft[COLOR_string__Object__to_s]))(var689) /* to_s on */; +((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(var_v, var692) /* add on */; +if (varonce693) { +var694 = varonce693; +} else { +var695 = "return "; +var696 = 7; +var697 = string__NativeString__to_s_with_length(var695, var696); +var694 = var697; +varonce693 = var694; +} +if (varonce698) { +var699 = varonce698; +} else { +var700 = ";"; +var701 = 1; +var702 = string__NativeString__to_s_with_length(var700, var701); +var699 = var702; +varonce698 = var699; +} +var703 = NEW_array__Array(&type_array__Arraykernel__Object); +{ /* var703 = array_instance Array[Object] */ +var704 = 3; +var705 = NEW_array__NativeArray(var704, &type_array__NativeArraykernel__Object); +((struct instance_array__NativeArray*)var705)->values[0] = (val*) var694; +((struct instance_array__NativeArray*)var705)->values[1] = (val*) var_res; +((struct instance_array__NativeArray*)var705)->values[2] = (val*) var699; +((void (*)(val*, val*, long))(var703->class->vft[COLOR_array__Array__with_native]))(var703, var705, var704) /* with_native on */; +} +var706 = ((val* (*)(val*))(var703->class->vft[COLOR_string__Object__to_s]))(var703) /* to_s on */; +((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(var_v, var706) /* add on */; +if (varonce707) { +var708 = varonce707; +} else { +var709 = "}"; +var710 = 1; +var711 = string__NativeString__to_s_with_length(var709, var710); +var708 = var711; +varonce707 = var708; +} +((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(var_v, var708) /* add on */; goto RET_LABEL; } else { } } -if (varonce689) { -var690 = varonce689; -} else { -var691 = "NEW_"; -var692 = 4; -var693 = string__NativeString__to_s_with_length(var691, var692); -var690 = var693; -varonce689 = var690; -} -var694 = NEW_array__Array(&type_array__Arraykernel__Object); -{ /* var694 = array_instance Array[Object] */ -var695 = 2; -var696 = NEW_array__NativeArray(var695, &type_array__NativeArraykernel__Object); -((struct instance_array__NativeArray*)var696)->values[0] = (val*) var690; -((struct instance_array__NativeArray*)var696)->values[1] = (val*) var_c_name; -((void (*)(val*, val*, long))(var694->class->vft[COLOR_array__Array__with_native]))(var694, var696, var695) /* with_native on */; -CHECK_NEW_array__Array(var694); -} -var697 = ((val* (*)(val*))(var694->class->vft[COLOR_string__Object__to_s]))(var694) /* to_s on */; -var698 = ((val* (*)(val*))(var_mtype->class->vft[COLOR_abstract_compiler__MType__ctype]))(var_mtype) /* ctype on */; -if (varonce699) { -var700 = varonce699; -} else { -var701 = " NEW_"; -var702 = 5; -var703 = string__NativeString__to_s_with_length(var701, var702); -var700 = var703; -varonce699 = var700; -} -if (varonce704) { -var705 = varonce704; -} else { -var706 = "(void);"; -var707 = 7; -var708 = string__NativeString__to_s_with_length(var706, var707); -var705 = var708; -varonce704 = var705; -} -var709 = NEW_array__Array(&type_array__Arraykernel__Object); -{ /* var709 = array_instance Array[Object] */ -var710 = 4; -var711 = NEW_array__NativeArray(var710, &type_array__NativeArraykernel__Object); -((struct instance_array__NativeArray*)var711)->values[0] = (val*) var698; -((struct instance_array__NativeArray*)var711)->values[1] = (val*) var700; -((struct instance_array__NativeArray*)var711)->values[2] = (val*) var_c_name; -((struct instance_array__NativeArray*)var711)->values[3] = (val*) var705; -((void (*)(val*, val*, long))(var709->class->vft[COLOR_array__Array__with_native]))(var709, var711, var710) /* with_native on */; -CHECK_NEW_array__Array(var709); -} -var712 = ((val* (*)(val*))(var709->class->vft[COLOR_string__Object__to_s]))(var709) /* to_s on */; -((void (*)(val*, val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompiler__provide_declaration]))(self, var697, var712) /* provide_declaration on */; -if (varonce713) { -var714 = varonce713; -} else { -var715 = "/* allocate "; -var716 = 12; -var717 = string__NativeString__to_s_with_length(var715, var716); -var714 = var717; -varonce713 = var714; -} -if (varonce718) { -var719 = varonce718; -} else { -var720 = " */"; -var721 = 3; -var722 = string__NativeString__to_s_with_length(var720, var721); -var719 = var722; -varonce718 = var719; -} -var723 = NEW_array__Array(&type_array__Arraykernel__Object); -{ /* var723 = array_instance Array[Object] */ -var724 = 3; -var725 = NEW_array__NativeArray(var724, &type_array__NativeArraykernel__Object); -((struct instance_array__NativeArray*)var725)->values[0] = (val*) var714; -((struct instance_array__NativeArray*)var725)->values[1] = (val*) var_mtype; -((struct instance_array__NativeArray*)var725)->values[2] = (val*) var719; -((void (*)(val*, val*, long))(var723->class->vft[COLOR_array__Array__with_native]))(var723, var725, var724) /* with_native on */; -CHECK_NEW_array__Array(var723); -} -var726 = ((val* (*)(val*))(var723->class->vft[COLOR_string__Object__to_s]))(var723) /* to_s on */; -((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add_decl]))(var_v, var726) /* add_decl on */; -var727 = ((val* (*)(val*))(var_mtype->class->vft[COLOR_abstract_compiler__MType__ctype]))(var_mtype) /* ctype on */; -if (varonce728) { -var729 = varonce728; -} else { -var730 = " NEW_"; -var731 = 5; -var732 = string__NativeString__to_s_with_length(var730, var731); -var729 = var732; -varonce728 = var729; -} -if (varonce733) { -var734 = varonce733; -} else { -var735 = "(void) {"; -var736 = 8; -var737 = string__NativeString__to_s_with_length(var735, var736); -var734 = var737; -varonce733 = var734; -} -var738 = NEW_array__Array(&type_array__Arraykernel__Object); -{ /* var738 = array_instance Array[Object] */ -var739 = 4; -var740 = NEW_array__NativeArray(var739, &type_array__NativeArraykernel__Object); -((struct instance_array__NativeArray*)var740)->values[0] = (val*) var727; -((struct instance_array__NativeArray*)var740)->values[1] = (val*) var729; -((struct instance_array__NativeArray*)var740)->values[2] = (val*) var_c_name; -((struct instance_array__NativeArray*)var740)->values[3] = (val*) var734; -((void (*)(val*, val*, long))(var738->class->vft[COLOR_array__Array__with_native]))(var738, var740, var739) /* with_native on */; -CHECK_NEW_array__Array(var738); -} -var741 = ((val* (*)(val*))(var738->class->vft[COLOR_string__Object__to_s]))(var738) /* to_s on */; -((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add_decl]))(var_v, var741) /* add_decl on */; -if (varonce742) { -var743 = varonce742; -} else { -var744 = "self"; -var745 = 4; -var746 = string__NativeString__to_s_with_length(var744, var745); -var743 = var746; -varonce742 = var743; -} -var747 = ((val* (*)(val*, val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__new_named_var]))(var_v, var_mtype, var743) /* new_named_var on */; -var_res748 = var747; -var749 = 1; -((void (*)(val*, short int))(var_res748->class->vft[COLOR_abstract_compiler__RuntimeVariable__is_exact_61d]))(var_res748, var749) /* is_exact= on */; -if (varonce750) { -var751 = varonce750; -} else { -var752 = " = nit_alloc(sizeof(struct instance) + "; -var753 = 39; -var754 = string__NativeString__to_s_with_length(var752, var753); -var751 = var754; -varonce750 = var751; -} -var755 = ((long (*)(val*))(var_attrs->class->vft[COLOR_abstract_collection__Collection__length]))(var_attrs) /* length on */; +if (varonce712) { +var713 = varonce712; +} else { +var714 = "NEW_"; +var715 = 4; +var716 = string__NativeString__to_s_with_length(var714, var715); +var713 = var716; +varonce712 = var713; +} +var717 = NEW_array__Array(&type_array__Arraykernel__Object); +{ /* var717 = array_instance Array[Object] */ +var718 = 2; +var719 = NEW_array__NativeArray(var718, &type_array__NativeArraykernel__Object); +((struct instance_array__NativeArray*)var719)->values[0] = (val*) var713; +((struct instance_array__NativeArray*)var719)->values[1] = (val*) var_c_name; +((void (*)(val*, val*, long))(var717->class->vft[COLOR_array__Array__with_native]))(var717, var719, var718) /* with_native on */; +} +var720 = ((val* (*)(val*))(var717->class->vft[COLOR_string__Object__to_s]))(var717) /* to_s on */; +var721 = ((val* (*)(val*))(var_mtype->class->vft[COLOR_abstract_compiler__MType__ctype]))(var_mtype) /* ctype on */; +if (varonce722) { +var723 = varonce722; +} else { +var724 = " NEW_"; +var725 = 5; +var726 = string__NativeString__to_s_with_length(var724, var725); +var723 = var726; +varonce722 = var723; +} +if (varonce727) { +var728 = varonce727; +} else { +var729 = "(void);"; +var730 = 7; +var731 = string__NativeString__to_s_with_length(var729, var730); +var728 = var731; +varonce727 = var728; +} +var732 = NEW_array__Array(&type_array__Arraykernel__Object); +{ /* var732 = array_instance Array[Object] */ +var733 = 4; +var734 = NEW_array__NativeArray(var733, &type_array__NativeArraykernel__Object); +((struct instance_array__NativeArray*)var734)->values[0] = (val*) var721; +((struct instance_array__NativeArray*)var734)->values[1] = (val*) var723; +((struct instance_array__NativeArray*)var734)->values[2] = (val*) var_c_name; +((struct instance_array__NativeArray*)var734)->values[3] = (val*) var728; +((void (*)(val*, val*, long))(var732->class->vft[COLOR_array__Array__with_native]))(var732, var734, var733) /* with_native on */; +} +var735 = ((val* (*)(val*))(var732->class->vft[COLOR_string__Object__to_s]))(var732) /* to_s on */; +((void (*)(val*, val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompiler__provide_declaration]))(self, var720, var735) /* provide_declaration on */; +if (varonce736) { +var737 = varonce736; +} else { +var738 = "/* allocate "; +var739 = 12; +var740 = string__NativeString__to_s_with_length(var738, var739); +var737 = var740; +varonce736 = var737; +} +if (varonce741) { +var742 = varonce741; +} else { +var743 = " */"; +var744 = 3; +var745 = string__NativeString__to_s_with_length(var743, var744); +var742 = var745; +varonce741 = var742; +} +var746 = NEW_array__Array(&type_array__Arraykernel__Object); +{ /* var746 = array_instance Array[Object] */ +var747 = 3; +var748 = NEW_array__NativeArray(var747, &type_array__NativeArraykernel__Object); +((struct instance_array__NativeArray*)var748)->values[0] = (val*) var737; +((struct instance_array__NativeArray*)var748)->values[1] = (val*) var_mtype; +((struct instance_array__NativeArray*)var748)->values[2] = (val*) var742; +((void (*)(val*, val*, long))(var746->class->vft[COLOR_array__Array__with_native]))(var746, var748, var747) /* with_native on */; +} +var749 = ((val* (*)(val*))(var746->class->vft[COLOR_string__Object__to_s]))(var746) /* to_s on */; +((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add_decl]))(var_v, var749) /* add_decl on */; +var750 = ((val* (*)(val*))(var_mtype->class->vft[COLOR_abstract_compiler__MType__ctype]))(var_mtype) /* ctype on */; +if (varonce751) { +var752 = varonce751; +} else { +var753 = " NEW_"; +var754 = 5; +var755 = string__NativeString__to_s_with_length(var753, var754); +var752 = var755; +varonce751 = var752; +} if (varonce756) { var757 = varonce756; } else { -var758 = "*sizeof(nitattribute_t));"; -var759 = 25; +var758 = "(void) {"; +var759 = 8; var760 = string__NativeString__to_s_with_length(var758, var759); var757 = var760; varonce756 = var757; @@ -3829,109 +3801,148 @@ var761 = NEW_array__Array(&type_array__Arraykernel__Object); { /* var761 = array_instance Array[Object] */ var762 = 4; var763 = NEW_array__NativeArray(var762, &type_array__NativeArraykernel__Object); -((struct instance_array__NativeArray*)var763)->values[0] = (val*) var_res748; -((struct instance_array__NativeArray*)var763)->values[1] = (val*) var751; -var764 = BOX_kernel__Int(var755); /* autobox from Int to Object */ -((struct instance_array__NativeArray*)var763)->values[2] = (val*) var764; +((struct instance_array__NativeArray*)var763)->values[0] = (val*) var750; +((struct instance_array__NativeArray*)var763)->values[1] = (val*) var752; +((struct instance_array__NativeArray*)var763)->values[2] = (val*) var_c_name; ((struct instance_array__NativeArray*)var763)->values[3] = (val*) var757; ((void (*)(val*, val*, long))(var761->class->vft[COLOR_array__Array__with_native]))(var761, var763, var762) /* with_native on */; -CHECK_NEW_array__Array(var761); -} -var765 = ((val* (*)(val*))(var761->class->vft[COLOR_string__Object__to_s]))(var761) /* to_s on */; -((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(var_v, var765) /* add on */; -if (varonce766) { -var767 = varonce766; -} else { -var768 = "class_"; -var769 = 6; -var770 = string__NativeString__to_s_with_length(var768, var769); -var767 = var770; -varonce766 = var767; -} -var771 = NEW_array__Array(&type_array__Arraykernel__Object); -{ /* var771 = array_instance Array[Object] */ -var772 = 2; -var773 = NEW_array__NativeArray(var772, &type_array__NativeArraykernel__Object); -((struct instance_array__NativeArray*)var773)->values[0] = (val*) var767; -((struct instance_array__NativeArray*)var773)->values[1] = (val*) var_c_name; -((void (*)(val*, val*, long))(var771->class->vft[COLOR_array__Array__with_native]))(var771, var773, var772) /* with_native on */; -CHECK_NEW_array__Array(var771); -} -var774 = ((val* (*)(val*))(var771->class->vft[COLOR_string__Object__to_s]))(var771) /* to_s on */; -((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__require_declaration]))(var_v, var774) /* require_declaration on */; -if (varonce775) { -var776 = varonce775; -} else { -var777 = "->class = &class_"; -var778 = 17; -var779 = string__NativeString__to_s_with_length(var777, var778); -var776 = var779; -varonce775 = var776; -} -if (varonce780) { -var781 = varonce780; -} else { -var782 = ";"; -var783 = 1; -var784 = string__NativeString__to_s_with_length(var782, var783); -var781 = var784; -varonce780 = var781; -} -var785 = NEW_array__Array(&type_array__Arraykernel__Object); -{ /* var785 = array_instance Array[Object] */ -var786 = 4; -var787 = NEW_array__NativeArray(var786, &type_array__NativeArraykernel__Object); -((struct instance_array__NativeArray*)var787)->values[0] = (val*) var_res748; -((struct instance_array__NativeArray*)var787)->values[1] = (val*) var776; -((struct instance_array__NativeArray*)var787)->values[2] = (val*) var_c_name; -((struct instance_array__NativeArray*)var787)->values[3] = (val*) var781; -((void (*)(val*, val*, long))(var785->class->vft[COLOR_array__Array__with_native]))(var785, var787, var786) /* with_native on */; -CHECK_NEW_array__Array(var785); -} -var788 = ((val* (*)(val*))(var785->class->vft[COLOR_string__Object__to_s]))(var785) /* to_s on */; +} +var764 = ((val* (*)(val*))(var761->class->vft[COLOR_string__Object__to_s]))(var761) /* to_s on */; +((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add_decl]))(var_v, var764) /* add_decl on */; +if (varonce765) { +var766 = varonce765; +} else { +var767 = "self"; +var768 = 4; +var769 = string__NativeString__to_s_with_length(var767, var768); +var766 = var769; +varonce765 = var766; +} +var770 = ((val* (*)(val*, val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__new_named_var]))(var_v, var_mtype, var766) /* new_named_var on */; +var_res771 = var770; +var772 = 1; +((void (*)(val*, short int))(var_res771->class->vft[COLOR_abstract_compiler__RuntimeVariable__is_exact_61d]))(var_res771, var772) /* is_exact= on */; +if (varonce773) { +var774 = varonce773; +} else { +var775 = " = nit_alloc(sizeof(struct instance) + "; +var776 = 39; +var777 = string__NativeString__to_s_with_length(var775, var776); +var774 = var777; +varonce773 = var774; +} +var778 = ((long (*)(val*))(var_attrs->class->vft[COLOR_abstract_collection__Collection__length]))(var_attrs) /* length on */; +if (varonce779) { +var780 = varonce779; +} else { +var781 = "*sizeof(nitattribute_t));"; +var782 = 25; +var783 = string__NativeString__to_s_with_length(var781, var782); +var780 = var783; +varonce779 = var780; +} +var784 = NEW_array__Array(&type_array__Arraykernel__Object); +{ /* var784 = array_instance Array[Object] */ +var785 = 4; +var786 = NEW_array__NativeArray(var785, &type_array__NativeArraykernel__Object); +((struct instance_array__NativeArray*)var786)->values[0] = (val*) var_res771; +((struct instance_array__NativeArray*)var786)->values[1] = (val*) var774; +var787 = BOX_kernel__Int(var778); /* autobox from Int to Object */ +((struct instance_array__NativeArray*)var786)->values[2] = (val*) var787; +((struct instance_array__NativeArray*)var786)->values[3] = (val*) var780; +((void (*)(val*, val*, long))(var784->class->vft[COLOR_array__Array__with_native]))(var784, var786, var785) /* with_native on */; +} +var788 = ((val* (*)(val*))(var784->class->vft[COLOR_string__Object__to_s]))(var784) /* to_s on */; ((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(var_v, var788) /* add on */; -((void (*)(val*, val*, val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompiler__generate_init_attr]))(self, var_v, var_res748, var_mtype) /* generate_init_attr on */; if (varonce789) { var790 = varonce789; } else { -var791 = "return "; -var792 = 7; +var791 = "class_"; +var792 = 6; var793 = string__NativeString__to_s_with_length(var791, var792); var790 = var793; varonce789 = var790; } -if (varonce794) { -var795 = varonce794; -} else { -var796 = ";"; -var797 = 1; -var798 = string__NativeString__to_s_with_length(var796, var797); -var795 = var798; -varonce794 = var795; -} -var799 = NEW_array__Array(&type_array__Arraykernel__Object); -{ /* var799 = array_instance Array[Object] */ -var800 = 3; -var801 = NEW_array__NativeArray(var800, &type_array__NativeArraykernel__Object); -((struct instance_array__NativeArray*)var801)->values[0] = (val*) var790; -((struct instance_array__NativeArray*)var801)->values[1] = (val*) var_res748; -((struct instance_array__NativeArray*)var801)->values[2] = (val*) var795; -((void (*)(val*, val*, long))(var799->class->vft[COLOR_array__Array__with_native]))(var799, var801, var800) /* with_native on */; -CHECK_NEW_array__Array(var799); -} -var802 = ((val* (*)(val*))(var799->class->vft[COLOR_string__Object__to_s]))(var799) /* to_s on */; -((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(var_v, var802) /* add on */; +var794 = NEW_array__Array(&type_array__Arraykernel__Object); +{ /* var794 = array_instance Array[Object] */ +var795 = 2; +var796 = NEW_array__NativeArray(var795, &type_array__NativeArraykernel__Object); +((struct instance_array__NativeArray*)var796)->values[0] = (val*) var790; +((struct instance_array__NativeArray*)var796)->values[1] = (val*) var_c_name; +((void (*)(val*, val*, long))(var794->class->vft[COLOR_array__Array__with_native]))(var794, var796, var795) /* with_native on */; +} +var797 = ((val* (*)(val*))(var794->class->vft[COLOR_string__Object__to_s]))(var794) /* to_s on */; +((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__require_declaration]))(var_v, var797) /* require_declaration on */; +if (varonce798) { +var799 = varonce798; +} else { +var800 = "->class = &class_"; +var801 = 17; +var802 = string__NativeString__to_s_with_length(var800, var801); +var799 = var802; +varonce798 = var799; +} if (varonce803) { var804 = varonce803; } else { -var805 = "}"; +var805 = ";"; var806 = 1; var807 = string__NativeString__to_s_with_length(var805, var806); var804 = var807; varonce803 = var804; } -((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(var_v, var804) /* add on */; -((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompiler__generate_check_init_instance]))(self, var_mtype) /* generate_check_init_instance on */; +var808 = NEW_array__Array(&type_array__Arraykernel__Object); +{ /* var808 = array_instance Array[Object] */ +var809 = 4; +var810 = NEW_array__NativeArray(var809, &type_array__NativeArraykernel__Object); +((struct instance_array__NativeArray*)var810)->values[0] = (val*) var_res771; +((struct instance_array__NativeArray*)var810)->values[1] = (val*) var799; +((struct instance_array__NativeArray*)var810)->values[2] = (val*) var_c_name; +((struct instance_array__NativeArray*)var810)->values[3] = (val*) var804; +((void (*)(val*, val*, long))(var808->class->vft[COLOR_array__Array__with_native]))(var808, var810, var809) /* with_native on */; +} +var811 = ((val* (*)(val*))(var808->class->vft[COLOR_string__Object__to_s]))(var808) /* to_s on */; +((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(var_v, var811) /* add on */; +((void (*)(val*, val*, val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompiler__generate_init_attr]))(self, var_v, var_res771, var_mtype) /* generate_init_attr on */; +if (varonce812) { +var813 = varonce812; +} else { +var814 = "return "; +var815 = 7; +var816 = string__NativeString__to_s_with_length(var814, var815); +var813 = var816; +varonce812 = var813; +} +if (varonce817) { +var818 = varonce817; +} else { +var819 = ";"; +var820 = 1; +var821 = string__NativeString__to_s_with_length(var819, var820); +var818 = var821; +varonce817 = var818; +} +var822 = NEW_array__Array(&type_array__Arraykernel__Object); +{ /* var822 = array_instance Array[Object] */ +var823 = 3; +var824 = NEW_array__NativeArray(var823, &type_array__NativeArraykernel__Object); +((struct instance_array__NativeArray*)var824)->values[0] = (val*) var813; +((struct instance_array__NativeArray*)var824)->values[1] = (val*) var_res771; +((struct instance_array__NativeArray*)var824)->values[2] = (val*) var818; +((void (*)(val*, val*, long))(var822->class->vft[COLOR_array__Array__with_native]))(var822, var824, var823) /* with_native on */; +} +var825 = ((val* (*)(val*))(var822->class->vft[COLOR_string__Object__to_s]))(var822) /* to_s on */; +((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(var_v, var825) /* add on */; +if (varonce826) { +var827 = varonce826; +} else { +var828 = "}"; +var829 = 1; +var830 = string__NativeString__to_s_with_length(var828, var829); +var827 = var830; +varonce826 = var827; +} +((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(var_v, var827) /* add on */; RET_LABEL:; } /* method separate_erasure_compiler#SeparateErasureCompiler#compile_class_to_c for (self: Object, MClass) */ @@ -4023,6 +4034,7 @@ val* var71 /* : MClassType */; short int var72 /* : Bool */; int cltype73; int idtype74; +const char* var_class_name; val* var75 /* : nullable MType */; val* var76 /* : MType */; val* var_bound /* var bound: MType */; @@ -4037,55 +4049,56 @@ long var84 /* : Int */; short int var85 /* : Bool */; int cltype86; int idtype87; -val* var88 /* : MClass */; +const char* var_class_name88; +val* var89 /* : MClass */; val* var_vtclass /* var vtclass: MClass */; -static val* varonce89; -val* var90 /* : String */; -char* var91 /* : NativeString */; -long var92 /* : Int */; -val* var93 /* : String */; +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* var95 /* : String */; +val* var96 /* : Array[Object] */; +long var97 /* : Int */; +val* var98 /* : NativeArray[Object] */; +val* var99 /* : String */; +static val* varonce100; +val* var101 /* : String */; +char* var102 /* : NativeString */; +long var103 /* : Int */; +val* var104 /* : String */; +static val* varonce105; +val* var106 /* : String */; +char* var107 /* : NativeString */; +long var108 /* : Int */; val* var109 /* : String */; -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 /* : Array[Object] */; -long var121 /* : Int */; -val* var122 /* : NativeArray[Object] */; -val* var123 /* : Object */; -val* var124 /* : String */; -static val* varonce126; -val* var127 /* : String */; -char* var128 /* : NativeString */; -long var129 /* : Int */; -val* var130 /* : String */; -static val* varonce131; -val* var132 /* : String */; -char* var133 /* : NativeString */; -long var134 /* : Int */; -val* var135 /* : String */; -short int var136 /* : Bool */; +val* var110 /* : String */; +static val* varonce111; +val* var112 /* : String */; +char* var113 /* : NativeString */; +long var114 /* : Int */; +val* var115 /* : String */; +static val* varonce116; +val* var117 /* : String */; +char* var118 /* : NativeString */; +long var119 /* : Int */; +val* var120 /* : String */; +val* var121 /* : Array[Object] */; +long var122 /* : Int */; +val* var123 /* : NativeArray[Object] */; +val* var124 /* : Object */; +val* var125 /* : String */; +static val* varonce127; +val* var128 /* : String */; +char* var129 /* : NativeString */; +long var130 /* : Int */; +val* var131 /* : String */; +static val* varonce132; +val* var133 /* : String */; +char* var134 /* : NativeString */; +long var135 /* : Int */; +val* var136 /* : String */; +short int var137 /* : Bool */; var_mclass = p0; var1 = ((val* (*)(val*))(self->class->vft[COLOR_separate_erasure_compiler__SeparateErasureCompiler__vt_tables]))(self) /* vt_tables on */; var2 = ((val* (*)(val*, val*))(var1->class->vft[COLOR_abstract_collection__MapRead___91d_93d]))(var1, var_mclass) /* [] on */; @@ -4113,7 +4126,6 @@ var12 = NEW_array__NativeArray(var11, &type_array__NativeArraykernel__Object); ((struct instance_array__NativeArray*)var12)->values[0] = (val*) var5; ((struct instance_array__NativeArray*)var12)->values[1] = (val*) var9; ((void (*)(val*, val*, long))(var10->class->vft[COLOR_array__Array__with_native]))(var10, var12, var11) /* with_native on */; -CHECK_NEW_array__Array(var10); } var13 = ((val* (*)(val*))(var10->class->vft[COLOR_string__Object__to_s]))(var10) /* to_s on */; if (varonce14) { @@ -4143,7 +4155,6 @@ var27 = NEW_array__NativeArray(var26, &type_array__NativeArraykernel__Object); ((struct instance_array__NativeArray*)var27)->values[1] = (val*) var19; ((struct instance_array__NativeArray*)var27)->values[2] = (val*) var21; ((void (*)(val*, val*, long))(var25->class->vft[COLOR_array__Array__with_native]))(var25, var27, var26) /* with_native on */; -CHECK_NEW_array__Array(var25); } var28 = ((val* (*)(val*))(var25->class->vft[COLOR_string__Object__to_s]))(var25) /* to_s on */; ((void (*)(val*, val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompiler__provide_declaration]))(self, var13, var28) /* provide_declaration on */; @@ -4176,7 +4187,6 @@ var43 = NEW_array__NativeArray(var42, &type_array__NativeArraykernel__Object); ((struct instance_array__NativeArray*)var43)->values[1] = (val*) var35; ((struct instance_array__NativeArray*)var43)->values[2] = (val*) var37; ((void (*)(val*, val*, long))(var41->class->vft[COLOR_array__Array__with_native]))(var41, var43, var42) /* with_native on */; -CHECK_NEW_array__Array(var41); } var44 = ((val* (*)(val*))(var41->class->vft[COLOR_string__Object__to_s]))(var41) /* to_s on */; ((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add_decl]))(var_v, var44) /* add_decl on */; @@ -4255,8 +4265,10 @@ var72 = 0; var72 = var_vt->type->type_table[cltype73] == idtype74; } if (!var72) { -fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "src/separate_erasure_compiler.nit", 360); -exit(1); +var_class_name = var_vt == NULL ? "null" : var_vt->type->name; +fprintf(stderr, "Runtime error: Cast failed. Expected `%s`, got `%s`", "MVirtualTypeDef", var_class_name); +fprintf(stderr, " (%s:%d)\n", "src/separate_erasure_compiler.nit", 361); +show_backtrace(1); } var75 = ((val* (*)(val*))(var_vt->class->vft[COLOR_model__MVirtualTypeDef__bound]))(var_vt) /* bound on */; var76 = ((val* (*)(val*, val*, val*))(self->class->vft[COLOR_separate_erasure_compiler__SeparateErasureCompiler__retrieve_vt_bound]))(self, var71, var75) /* retrieve_vt_bound on */; @@ -4290,113 +4302,113 @@ var85 = 0; var85 = var_bound->type->type_table[cltype86] == idtype87; } if (!var85) { -fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "src/separate_erasure_compiler.nit", 365); -exit(1); -} -var88 = ((val* (*)(val*))(var_bound->class->vft[COLOR_model__MClassType__mclass]))(var_bound) /* mclass on */; -var_vtclass = var88; -if (varonce89) { -var90 = varonce89; -} else { -var91 = "class_"; -var92 = 6; -var93 = string__NativeString__to_s_with_length(var91, var92); -var90 = var93; -varonce89 = var90; -} -var94 = ((val* (*)(val*))(var_vtclass->class->vft[COLOR_abstract_compiler__MClass__c_name]))(var_vtclass) /* c_name on */; -var95 = NEW_array__Array(&type_array__Arraykernel__Object); -{ /* var95 = array_instance Array[Object] */ -var96 = 2; -var97 = NEW_array__NativeArray(var96, &type_array__NativeArraykernel__Object); -((struct instance_array__NativeArray*)var97)->values[0] = (val*) var90; -((struct instance_array__NativeArray*)var97)->values[1] = (val*) var94; -((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*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__require_declaration]))(var_v, var98) /* require_declaration on */; -if (varonce99) { -var100 = varonce99; +var_class_name88 = var_bound == NULL ? "null" : var_bound->type->name; +fprintf(stderr, "Runtime error: Cast failed. Expected `%s`, got `%s`", "MClassType", var_class_name88); +fprintf(stderr, " (%s:%d)\n", "src/separate_erasure_compiler.nit", 366); +show_backtrace(1); +} +var89 = ((val* (*)(val*))(var_bound->class->vft[COLOR_model__MClassType__mclass]))(var_bound) /* mclass on */; +var_vtclass = var89; +if (varonce90) { +var91 = varonce90; +} else { +var92 = "class_"; +var93 = 6; +var94 = string__NativeString__to_s_with_length(var92, var93); +var91 = var94; +varonce90 = var91; +} +var95 = ((val* (*)(val*))(var_vtclass->class->vft[COLOR_abstract_compiler__MClass__c_name]))(var_vtclass) /* c_name on */; +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*) var91; +((struct instance_array__NativeArray*)var98)->values[1] = (val*) var95; +((void (*)(val*, val*, long))(var96->class->vft[COLOR_array__Array__with_native]))(var96, var98, var97) /* with_native on */; +} +var99 = ((val* (*)(val*))(var96->class->vft[COLOR_string__Object__to_s]))(var96) /* to_s on */; +((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__require_declaration]))(var_v, var99) /* require_declaration on */; +if (varonce100) { +var101 = varonce100; +} else { +var102 = "{"; +var103 = 1; +var104 = string__NativeString__to_s_with_length(var102, var103); +var101 = var104; +varonce100 = var101; +} +if (varonce105) { +var106 = varonce105; +} else { +var107 = ", &class_"; +var108 = 9; +var109 = string__NativeString__to_s_with_length(var107, var108); +var106 = var109; +varonce105 = var106; +} +var110 = ((val* (*)(val*))(var_vtclass->class->vft[COLOR_abstract_compiler__MClass__c_name]))(var_vtclass) /* c_name on */; +if (varonce111) { +var112 = varonce111; } else { -var101 = "{"; -var102 = 1; -var103 = string__NativeString__to_s_with_length(var101, var102); -var100 = var103; -varonce99 = var100; +var113 = "}, /* "; +var114 = 6; +var115 = string__NativeString__to_s_with_length(var113, var114); +var112 = var115; +varonce111 = var112; } -if (varonce104) { -var105 = varonce104; +if (varonce116) { +var117 = varonce116; } else { -var106 = ", &class_"; -var107 = 9; -var108 = string__NativeString__to_s_with_length(var106, var107); -var105 = var108; -varonce104 = var105; +var118 = " */"; +var119 = 3; +var120 = string__NativeString__to_s_with_length(var118, var119); +var117 = var120; +varonce116 = var117; } -var109 = ((val* (*)(val*))(var_vtclass->class->vft[COLOR_abstract_compiler__MClass__c_name]))(var_vtclass) /* c_name on */; -if (varonce110) { -var111 = varonce110; -} else { -var112 = "}, /* "; -var113 = 6; -var114 = string__NativeString__to_s_with_length(var112, var113); -var111 = var114; -varonce110 = var111; -} -if (varonce115) { -var116 = varonce115; -} else { -var117 = " */"; -var118 = 3; -var119 = string__NativeString__to_s_with_length(var117, var118); -var116 = var119; -varonce115 = var116; -} -var120 = NEW_array__Array(&type_array__Arraykernel__Object); -{ /* var120 = array_instance Array[Object] */ -var121 = 7; -var122 = NEW_array__NativeArray(var121, &type_array__NativeArraykernel__Object); -((struct instance_array__NativeArray*)var122)->values[0] = (val*) var100; -var123 = BOX_kernel__Int(var_is_null); /* autobox from Int to Object */ -((struct instance_array__NativeArray*)var122)->values[1] = (val*) var123; -((struct instance_array__NativeArray*)var122)->values[2] = (val*) var105; -((struct instance_array__NativeArray*)var122)->values[3] = (val*) var109; -((struct instance_array__NativeArray*)var122)->values[4] = (val*) var111; -((struct instance_array__NativeArray*)var122)->values[5] = (val*) var_vt; -((struct instance_array__NativeArray*)var122)->values[6] = (val*) var116; -((void (*)(val*, val*, long))(var120->class->vft[COLOR_array__Array__with_native]))(var120, var122, var121) /* with_native on */; -CHECK_NEW_array__Array(var120); -} -var124 = ((val* (*)(val*))(var120->class->vft[COLOR_string__Object__to_s]))(var120) /* to_s on */; -((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add_decl]))(var_v, var124) /* add_decl on */; -} -CONTINUE_label125: (void)0; +var121 = NEW_array__Array(&type_array__Arraykernel__Object); +{ /* var121 = array_instance Array[Object] */ +var122 = 7; +var123 = NEW_array__NativeArray(var122, &type_array__NativeArraykernel__Object); +((struct instance_array__NativeArray*)var123)->values[0] = (val*) var101; +var124 = BOX_kernel__Int(var_is_null); /* autobox from Int to Object */ +((struct instance_array__NativeArray*)var123)->values[1] = (val*) var124; +((struct instance_array__NativeArray*)var123)->values[2] = (val*) var106; +((struct instance_array__NativeArray*)var123)->values[3] = (val*) var110; +((struct instance_array__NativeArray*)var123)->values[4] = (val*) var112; +((struct instance_array__NativeArray*)var123)->values[5] = (val*) var_vt; +((struct instance_array__NativeArray*)var123)->values[6] = (val*) var117; +((void (*)(val*, val*, long))(var121->class->vft[COLOR_array__Array__with_native]))(var121, var123, var122) /* with_native on */; +} +var125 = ((val* (*)(val*))(var121->class->vft[COLOR_string__Object__to_s]))(var121) /* to_s on */; +((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add_decl]))(var_v, var125) /* add_decl on */; +} +CONTINUE_label126: (void)0; ((void (*)(val*))(var59->class->vft[COLOR_abstract_collection__Iterator__next]))(var59) /* next on */; } -BREAK_label125: (void)0; -if (varonce126) { -var127 = varonce126; +BREAK_label126: (void)0; +if (varonce127) { +var128 = varonce127; } else { -var128 = "},"; -var129 = 2; -var130 = string__NativeString__to_s_with_length(var128, var129); -var127 = var130; -varonce126 = var127; +var129 = "},"; +var130 = 2; +var131 = string__NativeString__to_s_with_length(var129, var130); +var128 = var131; +varonce127 = var128; } -((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add_decl]))(var_v, var127) /* add_decl on */; -if (varonce131) { -var132 = varonce131; +((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add_decl]))(var_v, var128) /* add_decl on */; +if (varonce132) { +var133 = varonce132; } else { -var133 = "};"; -var134 = 2; -var135 = string__NativeString__to_s_with_length(var133, var134); -var132 = var135; -varonce131 = var132; +var134 = "};"; +var135 = 2; +var136 = string__NativeString__to_s_with_length(var134, var135); +var133 = var136; +varonce132 = var133; } -((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add_decl]))(var_v, var132) /* add_decl on */; -var136 = 1; -var = var136; +((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add_decl]))(var_v, var133) /* add_decl on */; +var137 = 1; +var = var137; goto RET_LABEL; RET_LABEL:; return var; @@ -4451,8 +4463,9 @@ var3 = var6; varonce = var3; } ((void (*)(val*, val*))(self->class->vft[COLOR_file__Object__print]))(self, var3) /* print on */; -fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Aborted", "src/separate_erasure_compiler.nit", 378); -exit(1); +fprintf(stderr, "Runtime error: %s", "Aborted"); +fprintf(stderr, " (%s:%d)\n", "src/separate_erasure_compiler.nit", 379); +show_backtrace(1); } else { } /* isa MVirtualType */ @@ -4507,9 +4520,9 @@ short int var2 /* : Bool */; int cltype; int idtype; const struct type* type_struct; +const char* var_class_name; var1 = NEW_separate_erasure_compiler__SeparateErasureCompilerVisitor(&type_separate_erasure_compiler__SeparateErasureCompilerVisitor); ((void (*)(val*, val*))(var1->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__init]))(var1, self) /* init on */; -CHECK_NEW_separate_erasure_compiler__SeparateErasureCompilerVisitor(var1); /* isa VISITOR */ type_struct = self->type->resolution_table->types[COLOR_abstract_compiler__AbstractCompiler_VTVISITOR]; cltype = type_struct->color; @@ -4520,8 +4533,10 @@ var2 = 0; var2 = var1->type->type_table[cltype] == idtype; } if (!var2) { -fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "src/separate_erasure_compiler.nit", 389); -exit(1); +var_class_name = var1 == NULL ? "null" : var1->type->name; +fprintf(stderr, "Runtime error: Cast failed. Expected `%s`, got `%s`", "VISITOR", var_class_name); +fprintf(stderr, " (%s:%d)\n", "src/separate_erasure_compiler.nit", 390); +show_backtrace(1); } var = var1; goto RET_LABEL; @@ -4543,8 +4558,9 @@ val* var /* : Map[MClass, Array[nullable MClass]] */; val* var1 /* : Map[MClass, Array[nullable MClass]] */; var1 = self->attrs[COLOR_separate_erasure_compiler__SeparateErasureCompiler___64dclass_tables].val; /* @class_tables on */ if (var1 == NULL) { -fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Uninitialized attribute @class_tables", "src/separate_erasure_compiler.nit", 393); -exit(1); +fprintf(stderr, "Runtime error: %s", "Uninitialized attribute @class_tables"); +fprintf(stderr, " (%s:%d)\n", "src/separate_erasure_compiler.nit", 394); +show_backtrace(1); } var = var1; RET_LABEL:; @@ -4575,8 +4591,9 @@ val* var /* : Map[MClass, Array[nullable MPropDef]] */; val* var1 /* : Map[MClass, Array[nullable MPropDef]] */; var1 = self->attrs[COLOR_separate_erasure_compiler__SeparateErasureCompiler___64dvt_tables].val; /* @vt_tables on */ if (var1 == NULL) { -fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Uninitialized attribute @vt_tables", "src/separate_erasure_compiler.nit", 394); -exit(1); +fprintf(stderr, "Runtime error: %s", "Uninitialized attribute @vt_tables"); +fprintf(stderr, " (%s:%d)\n", "src/separate_erasure_compiler.nit", 395); +show_backtrace(1); } var = var1; RET_LABEL:; @@ -4894,7 +4911,6 @@ var43 = BOX_kernel__Int(var_total); /* autobox from Int to Object */ var44 = BOX_kernel__Int(var_holes); /* autobox from Int to Object */ ((struct instance_array__NativeArray*)var42)->values[3] = (val*) var44; ((void (*)(val*, val*, long))(var40->class->vft[COLOR_array__Array__with_native]))(var40, var42, var41) /* with_native on */; -CHECK_NEW_array__Array(var40); } var45 = ((val* (*)(val*))(var40->class->vft[COLOR_string__Object__to_s]))(var40) /* to_s on */; ((void (*)(val*, val*))(self->class->vft[COLOR_file__Object__print]))(self, var45) /* print on */; @@ -4999,7 +5015,6 @@ var94 = BOX_kernel__Int(var_total); /* autobox from Int to Object */ var95 = BOX_kernel__Int(var_holes); /* autobox from Int to Object */ ((struct instance_array__NativeArray*)var93)->values[3] = (val*) var95; ((void (*)(val*, val*, long))(var91->class->vft[COLOR_array__Array__with_native]))(var91, var93, var92) /* with_native on */; -CHECK_NEW_array__Array(var91); } var96 = ((val* (*)(val*))(var91->class->vft[COLOR_string__Object__to_s]))(var91) /* to_s on */; ((void (*)(val*, val*))(self->class->vft[COLOR_file__Object__print]))(self, var96) /* print on */; @@ -5104,7 +5119,6 @@ var145 = BOX_kernel__Int(var_total); /* autobox from Int to Object */ var146 = BOX_kernel__Int(var_holes); /* autobox from Int to Object */ ((struct instance_array__NativeArray*)var144)->values[3] = (val*) var146; ((void (*)(val*, val*, long))(var142->class->vft[COLOR_array__Array__with_native]))(var142, var144, var143) /* with_native on */; -CHECK_NEW_array__Array(var142); } var147 = ((val* (*)(val*))(var142->class->vft[COLOR_string__Object__to_s]))(var142) /* to_s on */; ((void (*)(val*, val*))(self->class->vft[COLOR_file__Object__print]))(self, var147) /* print on */; @@ -5209,7 +5223,6 @@ var196 = BOX_kernel__Int(var_total); /* autobox from Int to Object */ var197 = BOX_kernel__Int(var_holes); /* autobox from Int to Object */ ((struct instance_array__NativeArray*)var195)->values[3] = (val*) var197; ((void (*)(val*, val*, long))(var193->class->vft[COLOR_array__Array__with_native]))(var193, var195, var194) /* with_native on */; -CHECK_NEW_array__Array(var193); } var198 = ((val* (*)(val*))(var193->class->vft[COLOR_string__Object__to_s]))(var193) /* to_s on */; ((void (*)(val*, val*))(self->class->vft[COLOR_file__Object__print]))(self, var198) /* print on */; @@ -5234,6 +5247,7 @@ val* var4 /* : AbstractCompiler */; short int var5 /* : Bool */; int cltype; int idtype; +const char* var_class_name; val* var6 /* : ModelBuilder */; val* var7 /* : ToolContext */; val* var8 /* : OptionBool */; @@ -5314,8 +5328,10 @@ var5 = 0; var5 = var4->type->type_table[cltype] == idtype; } if (!var5) { -fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "src/separate_erasure_compiler.nit", 446); -exit(1); +var_class_name = var4 == NULL ? "null" : var4->type->name; +fprintf(stderr, "Runtime error: Cast failed. Expected `%s`, got `%s`", "SeparateErasureCompiler", var_class_name); +fprintf(stderr, " (%s:%d)\n", "src/separate_erasure_compiler.nit", 447); +show_backtrace(1); } var6 = ((val* (*)(val*))(var4->class->vft[COLOR_abstract_compiler__AbstractCompiler__modelbuilder]))(var4) /* modelbuilder on */; var7 = ((val* (*)(val*))(var6->class->vft[COLOR_modelbuilder__ModelBuilder__toolcontext]))(var6) /* toolcontext on */; @@ -5335,8 +5351,9 @@ var13 = 0; /* is null */ var13 = 1; /* arg is null and recv is not */ } if (!var13) { -fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Assert failed", "src/separate_erasure_compiler.nit", 447); -exit(1); +fprintf(stderr, "Runtime error: %s", "Assert failed"); +fprintf(stderr, " (%s:%d)\n", "src/separate_erasure_compiler.nit", 448); +show_backtrace(1); } var14 = ((val* (*)(val*))(var_callsite->class->vft[COLOR_typing__CallSite__msignature]))(var_callsite) /* msignature on */; var15 = ((val* (*)(val*))(var14->class->vft[COLOR_model__MSignature__return_mtype]))(var14) /* return_mtype on */; @@ -5348,8 +5365,9 @@ var17 = 0; /* is null */ var17 = 1; /* arg is null and recv is not */ } if (!var17) { -fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Assert failed", "src/separate_erasure_compiler.nit", 449); -exit(1); +fprintf(stderr, "Runtime error: %s", "Assert failed"); +fprintf(stderr, " (%s:%d)\n", "src/separate_erasure_compiler.nit", 450); +show_backtrace(1); } if (varonce) { var18 = varonce; @@ -5388,7 +5406,6 @@ var34 = NEW_array__NativeArray(var33, &type_array__NativeArraykernel__Object); ((struct instance_array__NativeArray*)var34)->values[3] = (val*) var_mtype; ((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 */; @@ -5429,7 +5446,6 @@ var54 = NEW_array__NativeArray(var53, &type_array__NativeArraykernel__Object); ((struct instance_array__NativeArray*)var54)->values[1] = (val*) var_cond; ((struct instance_array__NativeArray*)var54)->values[2] = (val*) var48; ((void (*)(val*, val*, long))(var52->class->vft[COLOR_array__Array__with_native]))(var52, var54, var53) /* with_native on */; -CHECK_NEW_array__Array(var52); } var55 = ((val* (*)(val*))(var52->class->vft[COLOR_string__Object__to_s]))(var52) /* to_s on */; ((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var55) /* add on */; @@ -5520,7 +5536,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 */; @@ -5552,7 +5567,6 @@ var25 = NEW_array__NativeArray(var24, &type_array__NativeArraykernel__Object); ((struct instance_array__NativeArray*)var25)->values[1] = (val*) var17; ((struct instance_array__NativeArray*)var25)->values[2] = (val*) var19; ((void (*)(val*, val*, long))(var23->class->vft[COLOR_array__Array__with_native]))(var23, var25, var24) /* with_native on */; -CHECK_NEW_array__Array(var23); } var26 = ((val* (*)(val*))(var23->class->vft[COLOR_string__Object__to_s]))(var23) /* to_s on */; var27 = ((val* (*)(val*, val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__new_expr]))(self, var26, var_mtype) /* new_expr on */; @@ -5771,6 +5785,7 @@ val* var183 /* : MType */; short int var184 /* : Bool */; int cltype185; int idtype186; +const char* var_class_name; val* var187 /* : MClass */; val* var_mclass /* var mclass: MClass */; static val* varonce188; @@ -5903,360 +5918,363 @@ val* var313 /* : MType */; short int var314 /* : Bool */; int cltype315; int idtype316; -val* var317 /* : MClass */; -val* var_mclass318 /* var mclass: MClass */; -static val* varonce319; -val* var320 /* : String */; -char* var321 /* : NativeString */; -long var322 /* : Int */; -val* var323 /* : String */; +const char* var_class_name317; +val* var318 /* : MClass */; +val* var_mclass319 /* var mclass: MClass */; +static val* varonce320; +val* var321 /* : String */; +char* var322 /* : NativeString */; +long var323 /* : Int */; val* var324 /* : String */; -val* var325 /* : Array[Object] */; -long var326 /* : Int */; -val* var327 /* : NativeArray[Object] */; -val* var328 /* : String */; -static val* varonce329; -val* var330 /* : String */; -char* var331 /* : NativeString */; -long var332 /* : Int */; -val* var333 /* : String */; +val* var325 /* : String */; +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 */; -static val* varonce335; -val* var336 /* : String */; -char* var337 /* : NativeString */; -long var338 /* : Int */; -val* var339 /* : String */; -val* var340 /* : Array[Object] */; -long var341 /* : Int */; -val* var342 /* : NativeArray[Object] */; -val* var343 /* : String */; -static val* varonce344; -val* var345 /* : String */; -char* var346 /* : NativeString */; -long var347 /* : Int */; -val* var348 /* : String */; +val* var335 /* : String */; +static val* varonce336; +val* var337 /* : String */; +char* var338 /* : NativeString */; +long var339 /* : Int */; +val* var340 /* : String */; +val* var341 /* : Array[Object] */; +long var342 /* : Int */; +val* var343 /* : NativeArray[Object] */; +val* var344 /* : String */; +static val* varonce345; +val* var346 /* : String */; +char* var347 /* : NativeString */; +long var348 /* : Int */; val* var349 /* : String */; +val* var350 /* : String */; val* var_entry /* var entry: String */; -static val* varonce350; -val* var351 /* : String */; -char* var352 /* : NativeString */; -long var353 /* : Int */; -val* var354 /* : String */; -static val* varonce355; -val* var356 /* : String */; -char* var357 /* : NativeString */; -long var358 /* : Int */; -val* var359 /* : String */; -val* var360 /* : Array[Object] */; -long var361 /* : Int */; -val* var362 /* : NativeArray[Object] */; -val* var363 /* : String */; -val* var364 /* : MProperty */; -val* var365 /* : String */; -val* var366 /* : AbstractCompiler */; -short int var367 /* : Bool */; -int cltype368; -int idtype369; -val* var370 /* : nullable Layout[MVirtualTypeProp] */; -short int var371 /* : Bool */; -int cltype372; -int idtype373; -static val* varonce374; -val* var375 /* : String */; -char* var376 /* : NativeString */; -long var377 /* : Int */; -val* var378 /* : String */; -static val* varonce379; +static val* varonce351; +val* var352 /* : String */; +char* var353 /* : NativeString */; +long var354 /* : Int */; +val* var355 /* : String */; +static val* varonce356; +val* var357 /* : String */; +char* var358 /* : NativeString */; +long var359 /* : Int */; +val* var360 /* : String */; +val* var361 /* : Array[Object] */; +long var362 /* : Int */; +val* var363 /* : NativeArray[Object] */; +val* var364 /* : String */; +val* var365 /* : MProperty */; +val* var366 /* : String */; +val* var367 /* : AbstractCompiler */; +short int var368 /* : Bool */; +int cltype369; +int idtype370; +const char* var_class_name371; +val* var372 /* : nullable Layout[MVirtualTypeProp] */; +short int var373 /* : Bool */; +int cltype374; +int idtype375; +static val* varonce376; +val* var377 /* : String */; +char* var378 /* : NativeString */; +long var379 /* : Int */; val* var380 /* : String */; -char* var381 /* : NativeString */; -long var382 /* : Int */; -val* var383 /* : String */; -static val* varonce384; +static val* varonce381; +val* var382 /* : String */; +char* var383 /* : NativeString */; +long var384 /* : Int */; val* var385 /* : String */; -char* var386 /* : NativeString */; -long var387 /* : Int */; -val* var388 /* : String */; -val* var389 /* : MProperty */; +static val* varonce386; +val* var387 /* : String */; +char* var388 /* : NativeString */; +long var389 /* : Int */; val* var390 /* : String */; -static val* varonce391; +val* var391 /* : MProperty */; val* var392 /* : String */; -char* var393 /* : NativeString */; -long var394 /* : Int */; -val* var395 /* : String */; -val* var396 /* : Array[Object] */; -long var397 /* : Int */; -val* var398 /* : NativeArray[Object] */; -val* var399 /* : String */; -static val* varonce400; +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 */; -char* var402 /* : NativeString */; -long var403 /* : Int */; -val* var404 /* : String */; -static val* varonce405; +static val* varonce402; +val* var403 /* : String */; +char* var404 /* : NativeString */; +long var405 /* : Int */; val* var406 /* : String */; -char* var407 /* : NativeString */; -long var408 /* : Int */; -val* var409 /* : String */; -val* var410 /* : MProperty */; +static val* varonce407; +val* var408 /* : String */; +char* var409 /* : NativeString */; +long var410 /* : Int */; val* var411 /* : String */; -static val* varonce412; +val* var412 /* : MProperty */; val* var413 /* : String */; -char* var414 /* : NativeString */; -long var415 /* : Int */; -val* var416 /* : String */; -val* var417 /* : Array[Object] */; -long var418 /* : Int */; -val* var419 /* : NativeArray[Object] */; -val* var420 /* : String */; -static val* varonce421; +static val* varonce414; +val* var415 /* : String */; +char* var416 /* : NativeString */; +long var417 /* : Int */; +val* var418 /* : String */; +val* var419 /* : Array[Object] */; +long var420 /* : Int */; +val* var421 /* : NativeArray[Object] */; val* var422 /* : String */; -char* var423 /* : NativeString */; -long var424 /* : Int */; -val* var425 /* : String */; -static val* varonce426; +static val* varonce423; +val* var424 /* : String */; +char* var425 /* : NativeString */; +long var426 /* : Int */; val* var427 /* : String */; -char* var428 /* : NativeString */; -long var429 /* : Int */; -val* var430 /* : String */; -val* var431 /* : Array[Object] */; -long var432 /* : Int */; -val* var433 /* : NativeArray[Object] */; -val* var434 /* : String */; -static val* varonce435; +static val* varonce428; +val* var429 /* : String */; +char* var430 /* : NativeString */; +long var431 /* : Int */; +val* var432 /* : String */; +val* var433 /* : Array[Object] */; +long var434 /* : Int */; +val* var435 /* : NativeArray[Object] */; val* var436 /* : String */; -char* var437 /* : NativeString */; -long var438 /* : Int */; -val* var439 /* : String */; -static val* varonce440; +static val* varonce437; +val* var438 /* : String */; +char* var439 /* : NativeString */; +long var440 /* : Int */; val* var441 /* : String */; -char* var442 /* : NativeString */; -long var443 /* : Int */; -val* var444 /* : String */; -val* var445 /* : Array[Object] */; -long var446 /* : Int */; -val* var447 /* : NativeArray[Object] */; -val* var448 /* : String */; -short int var449 /* : Bool */; -short int var_450 /* var : Bool */; -static val* varonce451; -val* var452 /* : String */; -char* var453 /* : NativeString */; -long var454 /* : Int */; -val* var455 /* : String */; -short int var456 /* : Bool */; -static val* varonce457; -val* var458 /* : String */; -char* var459 /* : NativeString */; -long var460 /* : Int */; -val* var461 /* : String */; -val* var462 /* : String */; -val* var_is_nullable /* var is_nullable: String */; -static val* varonce463; +static val* varonce442; +val* var443 /* : String */; +char* var444 /* : NativeString */; +long var445 /* : Int */; +val* var446 /* : String */; +val* var447 /* : Array[Object] */; +long var448 /* : Int */; +val* var449 /* : NativeArray[Object] */; +val* var450 /* : String */; +short int var451 /* : Bool */; +short int var_452 /* var : Bool */; +static val* varonce453; +val* var454 /* : String */; +char* var455 /* : NativeString */; +long var456 /* : Int */; +val* var457 /* : String */; +short int var458 /* : Bool */; +static val* varonce459; +val* var460 /* : String */; +char* var461 /* : NativeString */; +long var462 /* : Int */; +val* var463 /* : String */; val* var464 /* : String */; -char* var465 /* : NativeString */; -long var466 /* : Int */; -val* var467 /* : String */; -static val* varonce468; +val* var_is_nullable /* var is_nullable: String */; +static val* varonce465; +val* var466 /* : String */; +char* var467 /* : NativeString */; +long var468 /* : Int */; val* var469 /* : String */; -char* var470 /* : NativeString */; -long var471 /* : Int */; -val* var472 /* : String */; -val* var473 /* : Array[Object] */; -long var474 /* : Int */; -val* var475 /* : NativeArray[Object] */; -val* var476 /* : String */; -static val* varonce477; +static val* varonce470; +val* var471 /* : String */; +char* var472 /* : NativeString */; +long var473 /* : Int */; +val* var474 /* : String */; +val* var475 /* : Array[Object] */; +long var476 /* : Int */; +val* var477 /* : NativeArray[Object] */; val* var478 /* : String */; -char* var479 /* : NativeString */; -long var480 /* : Int */; -val* var481 /* : String */; -static val* varonce482; +static val* varonce479; +val* var480 /* : String */; +char* var481 /* : NativeString */; +long var482 /* : Int */; val* var483 /* : String */; -char* var484 /* : NativeString */; -long var485 /* : Int */; -val* var486 /* : String */; -val* var487 /* : Array[Object] */; -long var488 /* : Int */; -val* var489 /* : NativeArray[Object] */; -val* var490 /* : String */; -val* var491 /* : String */; -val* var492 /* : AbstractCompiler */; -val* var493 /* : ModelBuilder */; -val* var494 /* : ToolContext */; -val* var495 /* : OptionBool */; -val* var496 /* : nullable Object */; -short int var497 /* : Bool */; -val* var498 /* : AbstractCompiler */; -val* var499 /* : HashMap[String, Int] */; -val* var_500 /* var : HashMap[String, Int] */; -val* var_501 /* var : String */; -val* var502 /* : nullable Object */; -long var503 /* : Int */; -long var504 /* : Int */; +static val* varonce484; +val* var485 /* : String */; +char* var486 /* : NativeString */; +long var487 /* : Int */; +val* var488 /* : String */; +val* var489 /* : Array[Object] */; +long var490 /* : Int */; +val* var491 /* : NativeArray[Object] */; +val* var492 /* : String */; +val* var493 /* : String */; +val* var494 /* : AbstractCompiler */; +val* var495 /* : ModelBuilder */; +val* var496 /* : ToolContext */; +val* var497 /* : OptionBool */; +val* var498 /* : nullable Object */; +short int var499 /* : Bool */; +val* var500 /* : AbstractCompiler */; +val* var501 /* : HashMap[String, Int] */; +val* var_502 /* var : HashMap[String, Int] */; +val* var_503 /* var : String */; +val* var504 /* : nullable Object */; +long var505 /* : Int */; long var506 /* : Int */; -long var507 /* : Int */; -val* var508 /* : nullable Object */; -static val* varonce509; -val* var510 /* : String */; -char* var511 /* : NativeString */; -long var512 /* : Int */; -val* var513 /* : String */; -static val* varonce514; +long var508 /* : Int */; +long var509 /* : Int */; +val* var510 /* : nullable Object */; +static val* varonce511; +val* var512 /* : String */; +char* var513 /* : NativeString */; +long var514 /* : Int */; val* var515 /* : String */; -char* var516 /* : NativeString */; -long var517 /* : Int */; -val* var518 /* : String */; -val* var519 /* : Array[Object] */; -long var520 /* : Int */; -val* var521 /* : NativeArray[Object] */; -val* var522 /* : String */; -static val* varonce523; +static val* varonce516; +val* var517 /* : String */; +char* var518 /* : NativeString */; +long var519 /* : Int */; +val* var520 /* : String */; +val* var521 /* : Array[Object] */; +long var522 /* : Int */; +val* var523 /* : NativeArray[Object] */; val* var524 /* : String */; -char* var525 /* : NativeString */; -long var526 /* : Int */; -val* var527 /* : String */; -val* var528 /* : String */; -static val* varonce529; +static val* varonce525; +val* var526 /* : String */; +char* var527 /* : NativeString */; +long var528 /* : Int */; +val* var529 /* : String */; val* var530 /* : String */; -char* var531 /* : NativeString */; -long var532 /* : Int */; -val* var533 /* : String */; -static val* varonce534; +static val* varonce531; +val* var532 /* : String */; +char* var533 /* : NativeString */; +long var534 /* : Int */; val* var535 /* : String */; -char* var536 /* : NativeString */; -long var537 /* : Int */; -val* var538 /* : String */; -val* var539 /* : Array[Object] */; -long var540 /* : Int */; -val* var541 /* : NativeArray[Object] */; -val* var542 /* : String */; -static val* varonce543; +static val* varonce536; +val* var537 /* : String */; +char* var538 /* : NativeString */; +long var539 /* : Int */; +val* var540 /* : String */; +val* var541 /* : Array[Object] */; +long var542 /* : Int */; +val* var543 /* : NativeArray[Object] */; val* var544 /* : String */; -char* var545 /* : NativeString */; -long var546 /* : Int */; -val* var547 /* : String */; -static val* varonce548; +static val* varonce545; +val* var546 /* : String */; +char* var547 /* : NativeString */; +long var548 /* : Int */; val* var549 /* : String */; -char* var550 /* : NativeString */; -long var551 /* : Int */; -val* var552 /* : String */; -val* var553 /* : Array[Object] */; -long var554 /* : Int */; -val* var555 /* : NativeArray[Object] */; -val* var556 /* : String */; -static val* varonce557; +static val* varonce550; +val* var551 /* : String */; +char* var552 /* : NativeString */; +long var553 /* : Int */; +val* var554 /* : String */; +val* var555 /* : Array[Object] */; +long var556 /* : Int */; +val* var557 /* : NativeArray[Object] */; val* var558 /* : String */; -char* var559 /* : NativeString */; -long var560 /* : Int */; -val* var561 /* : String */; -static val* varonce562; +static val* varonce559; +val* var560 /* : String */; +char* var561 /* : NativeString */; +long var562 /* : Int */; val* var563 /* : String */; -char* var564 /* : NativeString */; -long var565 /* : Int */; -val* var566 /* : String */; -val* var567 /* : Array[Object] */; -long var568 /* : Int */; -val* var569 /* : NativeArray[Object] */; -val* var570 /* : String */; -static val* varonce571; +static val* varonce564; +val* var565 /* : String */; +char* var566 /* : NativeString */; +long var567 /* : Int */; +val* var568 /* : String */; +val* var569 /* : Array[Object] */; +long var570 /* : Int */; +val* var571 /* : NativeArray[Object] */; val* var572 /* : String */; -char* var573 /* : NativeString */; -long var574 /* : Int */; -val* var575 /* : String */; -val* var576 /* : AbstractCompiler */; -short int var577 /* : Bool */; -int cltype578; -int idtype579; -val* var580 /* : nullable Layout[MClass] */; -short int var581 /* : Bool */; -int cltype582; -int idtype583; -static val* varonce584; -val* var585 /* : String */; -char* var586 /* : NativeString */; -long var587 /* : Int */; +static val* varonce573; +val* var574 /* : String */; +char* var575 /* : NativeString */; +long var576 /* : Int */; +val* var577 /* : String */; +val* var578 /* : AbstractCompiler */; +short int var579 /* : Bool */; +int cltype580; +int idtype581; +const char* var_class_name582; +val* var583 /* : nullable Layout[MClass] */; +short int var584 /* : Bool */; +int cltype585; +int idtype586; +static val* varonce587; val* var588 /* : String */; -static val* varonce589; -val* var590 /* : String */; -char* var591 /* : NativeString */; -long var592 /* : Int */; +char* var589 /* : NativeString */; +long var590 /* : Int */; +val* var591 /* : String */; +static val* varonce592; val* var593 /* : String */; -static val* varonce594; -val* var595 /* : String */; -char* var596 /* : NativeString */; -long var597 /* : Int */; +char* var594 /* : NativeString */; +long var595 /* : Int */; +val* var596 /* : String */; +static val* varonce597; val* var598 /* : String */; -val* var599 /* : Array[Object] */; +char* var599 /* : NativeString */; long var600 /* : Int */; -val* var601 /* : NativeArray[Object] */; -val* var602 /* : String */; -static val* varonce603; -val* var604 /* : String */; -char* var605 /* : NativeString */; -long var606 /* : Int */; +val* var601 /* : String */; +val* var602 /* : Array[Object] */; +long var603 /* : Int */; +val* var604 /* : NativeArray[Object] */; +val* var605 /* : String */; +static val* varonce606; val* var607 /* : String */; -static val* varonce608; -val* var609 /* : String */; -char* var610 /* : NativeString */; -long var611 /* : Int */; +char* var608 /* : NativeString */; +long var609 /* : Int */; +val* var610 /* : String */; +static val* varonce611; val* var612 /* : String */; -static val* varonce613; -val* var614 /* : String */; -char* var615 /* : NativeString */; -long var616 /* : Int */; +char* var613 /* : NativeString */; +long var614 /* : Int */; +val* var615 /* : String */; +static val* varonce616; val* var617 /* : String */; -val* var618 /* : Array[Object] */; +char* var618 /* : NativeString */; long var619 /* : Int */; -val* var620 /* : NativeArray[Object] */; -val* var621 /* : String */; -static val* varonce622; -val* var623 /* : String */; -char* var624 /* : NativeString */; -long var625 /* : Int */; +val* var620 /* : String */; +val* var621 /* : Array[Object] */; +long var622 /* : Int */; +val* var623 /* : NativeArray[Object] */; +val* var624 /* : String */; +static val* varonce625; val* var626 /* : String */; -val* var627 /* : Array[Object] */; +char* var627 /* : NativeString */; long var628 /* : Int */; -val* var629 /* : NativeArray[Object] */; -val* var630 /* : String */; -static val* varonce631; -val* var632 /* : String */; -char* var633 /* : NativeString */; -long var634 /* : Int */; +val* var629 /* : String */; +val* var630 /* : Array[Object] */; +long var631 /* : Int */; +val* var632 /* : NativeArray[Object] */; +val* var633 /* : String */; +static val* varonce634; val* var635 /* : String */; -static val* varonce636; -val* var637 /* : String */; -char* var638 /* : NativeString */; -long var639 /* : Int */; +char* var636 /* : NativeString */; +long var637 /* : Int */; +val* var638 /* : String */; +static val* varonce639; val* var640 /* : String */; -static val* varonce641; -val* var642 /* : String */; -char* var643 /* : NativeString */; -long var644 /* : Int */; +char* var641 /* : NativeString */; +long var642 /* : Int */; +val* var643 /* : String */; +static val* varonce644; val* var645 /* : String */; -static val* varonce646; -val* var647 /* : String */; -char* var648 /* : NativeString */; -long var649 /* : Int */; +char* var646 /* : NativeString */; +long var647 /* : Int */; +val* var648 /* : String */; +static val* varonce649; val* var650 /* : String */; -static val* varonce651; -val* var652 /* : String */; -char* var653 /* : NativeString */; -long var654 /* : Int */; +char* var651 /* : NativeString */; +long var652 /* : Int */; +val* var653 /* : String */; +static val* varonce654; val* var655 /* : String */; -val* var656 /* : Array[Object] */; +char* var656 /* : NativeString */; long var657 /* : Int */; -val* var658 /* : NativeArray[Object] */; -val* var659 /* : String */; -static val* varonce660; -val* var661 /* : String */; -char* var662 /* : NativeString */; -long var663 /* : Int */; +val* var658 /* : String */; +val* var659 /* : Array[Object] */; +long var660 /* : Int */; +val* var661 /* : NativeArray[Object] */; +val* var662 /* : String */; +static val* varonce663; val* var664 /* : String */; -static val* varonce665; -val* var666 /* : String */; -char* var667 /* : NativeString */; -long var668 /* : Int */; +char* var665 /* : NativeString */; +long var666 /* : Int */; +val* var667 /* : String */; +static val* varonce668; val* var669 /* : String */; +char* var670 /* : NativeString */; +long var671 /* : Int */; +val* var672 /* : String */; var_value = p0; var_mtype = p1; var_tag = p2; @@ -6298,7 +6316,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 */; @@ -6342,7 +6359,6 @@ var40 = NEW_array__NativeArray(var39, &type_array__NativeArraykernel__Object); ((struct instance_array__NativeArray*)var40)->values[1] = (val*) var_cltype; ((struct instance_array__NativeArray*)var40)->values[2] = (val*) var34; ((void (*)(val*, val*, long))(var38->class->vft[COLOR_array__Array__with_native]))(var38, var40, var39) /* with_native on */; -CHECK_NEW_array__Array(var38); } var41 = ((val* (*)(val*))(var38->class->vft[COLOR_string__Object__to_s]))(var38) /* to_s on */; ((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add_decl]))(self, var41) /* add_decl on */; @@ -6383,7 +6399,6 @@ var60 = NEW_array__NativeArray(var59, &type_array__NativeArraykernel__Object); ((struct instance_array__NativeArray*)var60)->values[1] = (val*) var_idtype; ((struct instance_array__NativeArray*)var60)->values[2] = (val*) var54; ((void (*)(val*, val*, long))(var58->class->vft[COLOR_array__Array__with_native]))(var58, var60, var59) /* with_native on */; -CHECK_NEW_array__Array(var58); } var61 = ((val* (*)(val*))(var58->class->vft[COLOR_string__Object__to_s]))(var58) /* to_s on */; ((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add_decl]))(self, var61) /* add_decl on */; @@ -6433,8 +6448,9 @@ var75 = var_mtype->type->type_table[cltype76] == idtype77; if (var75){ var78 = ((val* (*)(val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__frame]))(self) /* frame on */; if (var78 == NULL) { -fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Reciever is null", "src/separate_erasure_compiler.nit", 487); -exit(1); +fprintf(stderr, "Runtime error: %s", "Receiver is null"); +fprintf(stderr, " (%s:%d)\n", "src/separate_erasure_compiler.nit", 488); +show_backtrace(1); } else { var79 = ((val* (*)(val*))(var78->class->vft[COLOR_abstract_compiler__Frame__mpropdef]))(var78) /* mpropdef on */; } @@ -6442,8 +6458,9 @@ var80 = ((val* (*)(val*))(var79->class->vft[COLOR_model__MPropDef__mclassdef]))( var81 = ((val* (*)(val*))(var80->class->vft[COLOR_model__MClassDef__bound_mtype]))(var80) /* bound_mtype on */; var82 = ((val* (*)(val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__frame]))(self) /* frame on */; if (var82 == NULL) { -fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Reciever is null", "src/separate_erasure_compiler.nit", 487); -exit(1); +fprintf(stderr, "Runtime error: %s", "Receiver is null"); +fprintf(stderr, " (%s:%d)\n", "src/separate_erasure_compiler.nit", 488); +show_backtrace(1); } else { var83 = ((val* (*)(val*))(var82->class->vft[COLOR_abstract_compiler__Frame__mpropdef]))(var82) /* mpropdef on */; } @@ -6451,8 +6468,9 @@ var84 = ((val* (*)(val*))(var83->class->vft[COLOR_model__MPropDef__mclassdef]))( var85 = ((val* (*)(val*))(var84->class->vft[COLOR_model__MClassDef__bound_mtype]))(var84) /* bound_mtype on */; var86 = ((val* (*)(val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__frame]))(self) /* frame on */; if (var86 == NULL) { -fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Reciever is null", "src/separate_erasure_compiler.nit", 487); -exit(1); +fprintf(stderr, "Runtime error: %s", "Receiver is null"); +fprintf(stderr, " (%s:%d)\n", "src/separate_erasure_compiler.nit", 488); +show_backtrace(1); } else { var87 = ((val* (*)(val*))(var86->class->vft[COLOR_abstract_compiler__Frame__mpropdef]))(var86) /* mpropdef on */; } @@ -6489,8 +6507,9 @@ var_accept_null = var97; var101 = ((val* (*)(val*))(var_value->class->vft[COLOR_abstract_compiler__RuntimeVariable__mcasttype]))(var_value) /* mcasttype on */; var102 = ((val* (*)(val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__frame]))(self) /* frame on */; if (var102 == NULL) { -fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Reciever is null", "src/separate_erasure_compiler.nit", 494); -exit(1); +fprintf(stderr, "Runtime error: %s", "Receiver is null"); +fprintf(stderr, " (%s:%d)\n", "src/separate_erasure_compiler.nit", 495); +show_backtrace(1); } else { var103 = ((val* (*)(val*))(var102->class->vft[COLOR_abstract_compiler__Frame__mpropdef]))(var102) /* mpropdef on */; } @@ -6498,8 +6517,9 @@ var104 = ((val* (*)(val*))(var103->class->vft[COLOR_model__MPropDef__mclassdef]) var105 = ((val* (*)(val*))(var104->class->vft[COLOR_model__MClassDef__mmodule]))(var104) /* mmodule on */; var106 = ((val* (*)(val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__frame]))(self) /* frame on */; if (var106 == NULL) { -fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Reciever is null", "src/separate_erasure_compiler.nit", 494); -exit(1); +fprintf(stderr, "Runtime error: %s", "Receiver is null"); +fprintf(stderr, " (%s:%d)\n", "src/separate_erasure_compiler.nit", 495); +show_backtrace(1); } else { var107 = ((val* (*)(val*))(var106->class->vft[COLOR_abstract_compiler__Frame__mpropdef]))(var106) /* mpropdef on */; } @@ -6546,7 +6566,6 @@ var129 = NEW_array__NativeArray(var128, &type_array__NativeArraykernel__Object); ((struct instance_array__NativeArray*)var129)->values[4] = (val*) var_mtype; ((struct instance_array__NativeArray*)var129)->values[5] = (val*) var123; ((void (*)(val*, val*, long))(var127->class->vft[COLOR_array__Array__with_native]))(var127, var129, var128) /* with_native on */; -CHECK_NEW_array__Array(var127); } var130 = ((val* (*)(val*))(var127->class->vft[COLOR_string__Object__to_s]))(var127) /* to_s on */; ((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var130) /* add on */; @@ -6598,7 +6617,6 @@ var159 = NEW_array__NativeArray(var158, &type_array__NativeArraykernel__Object); ((struct instance_array__NativeArray*)var159)->values[1] = (val*) var_tag; ((struct instance_array__NativeArray*)var159)->values[2] = (val*) var153; ((void (*)(val*, val*, long))(var157->class->vft[COLOR_array__Array__with_native]))(var157, var159, var158) /* with_native on */; -CHECK_NEW_array__Array(var157); } var160 = ((val* (*)(val*))(var157->class->vft[COLOR_string__Object__to_s]))(var157) /* to_s on */; ((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var160) /* add on */; @@ -6624,7 +6642,6 @@ if (var168){ var169 = NEW_array__Array(&type_array__Arraykernel__Object); var170 = 3; ((void (*)(val*, long))(var169->class->vft[COLOR_array__Array__with_capacity]))(var169, var170) /* with_capacity on */; -CHECK_NEW_array__Array(var169); var_171 = var169; if (varonce172) { var173 = varonce172; @@ -6660,8 +6677,10 @@ var184 = 0; var184 = var183->type->type_table[cltype185] == idtype186; } if (!var184) { -fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "src/separate_erasure_compiler.nit", 508); -exit(1); +var_class_name = var183 == NULL ? "null" : var183->type->name; +fprintf(stderr, "Runtime error: Cast failed. Expected `%s`, got `%s`", "MClassType", var_class_name); +fprintf(stderr, " (%s:%d)\n", "src/separate_erasure_compiler.nit", 509); +show_backtrace(1); } var187 = ((val* (*)(val*))(var183->class->vft[COLOR_model__MClassType__mclass]))(var183) /* mclass on */; var_mclass = var187; @@ -6682,14 +6701,12 @@ var196 = NEW_array__NativeArray(var195, &type_array__NativeArraykernel__Object); ((struct instance_array__NativeArray*)var196)->values[0] = (val*) var189; ((struct instance_array__NativeArray*)var196)->values[1] = (val*) var193; ((void (*)(val*, val*, long))(var194->class->vft[COLOR_array__Array__with_native]))(var194, var196, var195) /* with_native on */; -CHECK_NEW_array__Array(var194); } var197 = ((val* (*)(val*))(var194->class->vft[COLOR_string__Object__to_s]))(var194) /* to_s on */; ((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__require_declaration]))(self, var197) /* require_declaration on */; var198 = NEW_array__Array(&type_array__Arraykernel__Object); var199 = 3; ((void (*)(val*, long))(var198->class->vft[COLOR_array__Array__with_capacity]))(var198, var199) /* with_capacity on */; -CHECK_NEW_array__Array(var198); var_200 = var198; if (varonce201) { var202 = varonce201; @@ -6743,7 +6760,6 @@ var225 = NEW_array__NativeArray(var224, &type_array__NativeArraykernel__Object); ((struct instance_array__NativeArray*)var225)->values[0] = (val*) var217; ((struct instance_array__NativeArray*)var225)->values[1] = (val*) var222; ((void (*)(val*, val*, long))(var223->class->vft[COLOR_array__Array__with_native]))(var223, var225, var224) /* with_native on */; -CHECK_NEW_array__Array(var223); } var226 = ((val* (*)(val*))(var223->class->vft[COLOR_string__Object__to_s]))(var223) /* to_s on */; ((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__require_declaration]))(self, var226) /* require_declaration on */; @@ -6776,7 +6792,6 @@ var241 = NEW_array__NativeArray(var240, &type_array__NativeArraykernel__Object); ((struct instance_array__NativeArray*)var241)->values[2] = (val*) var233; ((struct instance_array__NativeArray*)var241)->values[3] = (val*) var235; ((void (*)(val*, val*, long))(var239->class->vft[COLOR_array__Array__with_native]))(var239, var241, var240) /* with_native on */; -CHECK_NEW_array__Array(var239); } var242 = ((val* (*)(val*))(var239->class->vft[COLOR_string__Object__to_s]))(var239) /* to_s on */; ((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var242) /* add on */; @@ -6809,7 +6824,6 @@ var257 = NEW_array__NativeArray(var256, &type_array__NativeArraykernel__Object); ((struct instance_array__NativeArray*)var257)->values[2] = (val*) var249; ((struct instance_array__NativeArray*)var257)->values[3] = (val*) var251; ((void (*)(val*, val*, long))(var255->class->vft[COLOR_array__Array__with_native]))(var255, var257, var256) /* with_native on */; -CHECK_NEW_array__Array(var255); } var258 = ((val* (*)(val*))(var255->class->vft[COLOR_string__Object__to_s]))(var255) /* to_s on */; ((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var258) /* add on */; @@ -6861,7 +6875,6 @@ var288 = NEW_array__NativeArray(var287, &type_array__NativeArraykernel__Object); ((struct instance_array__NativeArray*)var288)->values[1] = (val*) var_tag; ((struct instance_array__NativeArray*)var288)->values[2] = (val*) var282; ((void (*)(val*, val*, long))(var286->class->vft[COLOR_array__Array__with_native]))(var286, var288, var287) /* with_native on */; -CHECK_NEW_array__Array(var286); } var289 = ((val* (*)(val*))(var286->class->vft[COLOR_string__Object__to_s]))(var286) /* to_s on */; ((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var289) /* add on */; @@ -6879,8 +6892,9 @@ var290 = var_mtype->type->type_table[cltype291] == idtype292; if (var290){ var293 = ((val* (*)(val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__frame]))(self) /* frame on */; if (var293 == NULL) { -fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Reciever is null", "src/separate_erasure_compiler.nit", 522); -exit(1); +fprintf(stderr, "Runtime error: %s", "Receiver is null"); +fprintf(stderr, " (%s:%d)\n", "src/separate_erasure_compiler.nit", 523); +show_backtrace(1); } else { var294 = ((val* (*)(val*))(var293->class->vft[COLOR_abstract_compiler__Frame__arguments]))(var293) /* arguments on */; } @@ -6915,7 +6929,6 @@ var311 = NEW_array__NativeArray(var310, &type_array__NativeArraykernel__Object); ((struct instance_array__NativeArray*)var311)->values[0] = (val*) var_recv; ((struct instance_array__NativeArray*)var311)->values[1] = (val*) var305; ((void (*)(val*, val*, long))(var309->class->vft[COLOR_array__Array__with_native]))(var309, var311, var310) /* with_native on */; -CHECK_NEW_array__Array(var309); } var312 = ((val* (*)(val*))(var309->class->vft[COLOR_string__Object__to_s]))(var309) /* to_s on */; var_recv_ptr = var312; @@ -6930,782 +6943,772 @@ var314 = 0; var314 = var313->type->type_table[cltype315] == idtype316; } if (!var314) { -fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "src/separate_erasure_compiler.nit", 527); -exit(1); -} -var317 = ((val* (*)(val*))(var313->class->vft[COLOR_model__MClassType__mclass]))(var313) /* mclass on */; -var_mclass318 = var317; -if (varonce319) { -var320 = varonce319; -} else { -var321 = "class_"; -var322 = 6; -var323 = string__NativeString__to_s_with_length(var321, var322); -var320 = var323; -varonce319 = var320; -} -var324 = ((val* (*)(val*))(var_mclass318->class->vft[COLOR_abstract_compiler__MClass__c_name]))(var_mclass318) /* c_name on */; -var325 = NEW_array__Array(&type_array__Arraykernel__Object); -{ /* var325 = array_instance Array[Object] */ -var326 = 2; -var327 = NEW_array__NativeArray(var326, &type_array__NativeArraykernel__Object); -((struct instance_array__NativeArray*)var327)->values[0] = (val*) var320; -((struct instance_array__NativeArray*)var327)->values[1] = (val*) var324; -((void (*)(val*, val*, long))(var325->class->vft[COLOR_array__Array__with_native]))(var325, var327, var326) /* with_native on */; -CHECK_NEW_array__Array(var325); -} -var328 = ((val* (*)(val*))(var325->class->vft[COLOR_string__Object__to_s]))(var325) /* to_s on */; -((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__require_declaration]))(self, var328) /* require_declaration on */; -if (varonce329) { -var330 = varonce329; -} else { -var331 = "class_"; -var332 = 6; -var333 = string__NativeString__to_s_with_length(var331, var332); -var330 = var333; -varonce329 = var330; -} -var334 = ((val* (*)(val*))(var_mclass318->class->vft[COLOR_abstract_compiler__MClass__c_name]))(var_mclass318) /* c_name on */; -if (varonce335) { -var336 = varonce335; -} else { -var337 = "."; -var338 = 1; -var339 = string__NativeString__to_s_with_length(var337, var338); -var336 = var339; -varonce335 = var336; -} -var340 = NEW_array__Array(&type_array__Arraykernel__Object); -{ /* var340 = array_instance Array[Object] */ -var341 = 3; -var342 = NEW_array__NativeArray(var341, &type_array__NativeArraykernel__Object); -((struct instance_array__NativeArray*)var342)->values[0] = (val*) var330; -((struct instance_array__NativeArray*)var342)->values[1] = (val*) var334; -((struct instance_array__NativeArray*)var342)->values[2] = (val*) var336; -((void (*)(val*, val*, long))(var340->class->vft[COLOR_array__Array__with_native]))(var340, var342, var341) /* with_native on */; -CHECK_NEW_array__Array(var340); -} -var343 = ((val* (*)(val*))(var340->class->vft[COLOR_string__Object__to_s]))(var340) /* to_s on */; -var_recv_ptr = var343; -} -if (varonce344) { -var345 = varonce344; -} else { -var346 = "entry"; -var347 = 5; -var348 = string__NativeString__to_s_with_length(var346, var347); -var345 = var348; -varonce344 = var345; -} -var349 = ((val* (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__get_name]))(self, var345) /* get_name on */; -var_entry = var349; -if (varonce350) { -var351 = varonce350; -} else { -var352 = "struct vts_entry "; -var353 = 17; -var354 = string__NativeString__to_s_with_length(var352, var353); -var351 = var354; -varonce350 = var351; -} -if (varonce355) { -var356 = varonce355; -} else { -var357 = ";"; -var358 = 1; -var359 = string__NativeString__to_s_with_length(var357, var358); -var356 = var359; -varonce355 = var356; -} -var360 = NEW_array__Array(&type_array__Arraykernel__Object); -{ /* var360 = array_instance Array[Object] */ -var361 = 3; -var362 = NEW_array__NativeArray(var361, &type_array__NativeArraykernel__Object); -((struct instance_array__NativeArray*)var362)->values[0] = (val*) var351; -((struct instance_array__NativeArray*)var362)->values[1] = (val*) var_entry; -((struct instance_array__NativeArray*)var362)->values[2] = (val*) var356; -((void (*)(val*, val*, long))(var360->class->vft[COLOR_array__Array__with_native]))(var360, var362, var361) /* with_native on */; -CHECK_NEW_array__Array(var360); -} -var363 = ((val* (*)(val*))(var360->class->vft[COLOR_string__Object__to_s]))(var360) /* to_s on */; -((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var363) /* add on */; -var364 = ((val* (*)(val*))(var_mtype->class->vft[COLOR_model__MVirtualType__mproperty]))(var_mtype) /* mproperty on */; -var365 = ((val* (*)(val*))(var364->class->vft[COLOR_separate_compiler__MProperty__const_color]))(var364) /* const_color on */; -((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__require_declaration]))(self, var365) /* require_declaration on */; -var366 = ((val* (*)(val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__compiler]))(self) /* compiler on */; -/* isa SeparateErasureCompiler */ -cltype368 = type_separate_erasure_compiler__SeparateErasureCompiler.color; -idtype369 = type_separate_erasure_compiler__SeparateErasureCompiler.id; -if(cltype368 >= var366->type->table_size) { -var367 = 0; -} else { -var367 = var366->type->type_table[cltype368] == idtype369; -} -if (!var367) { -fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "src/separate_erasure_compiler.nit", 534); -exit(1); -} -var370 = ((val* (*)(val*))(var366->class->vft[COLOR_separate_erasure_compiler__SeparateErasureCompiler__vt_layout]))(var366) /* vt_layout on */; -/* isa PHLayout[MClass, MVirtualTypeProp] */ -cltype372 = type_layout_builders__PHLayoutmodel__MClassmodel__MVirtualTypeProp.color; -idtype373 = type_layout_builders__PHLayoutmodel__MClassmodel__MVirtualTypeProp.id; -if(var370 == NULL) { -var371 = 0; -} else { -if(cltype372 >= var370->type->table_size) { -var371 = 0; -} else { -var371 = var370->type->type_table[cltype372] == idtype373; -} -} -if (var371){ -if (varonce374) { -var375 = varonce374; -} else { -var376 = " = "; -var377 = 3; -var378 = string__NativeString__to_s_with_length(var376, var377); -var375 = var378; -varonce374 = var375; -} -if (varonce379) { -var380 = varonce379; -} else { -var381 = "vts_table->vts[HASH("; -var382 = 20; -var383 = string__NativeString__to_s_with_length(var381, var382); -var380 = var383; -varonce379 = var380; -} -if (varonce384) { -var385 = varonce384; -} else { -var386 = "vts_table->mask, "; -var387 = 17; -var388 = string__NativeString__to_s_with_length(var386, var387); -var385 = var388; -varonce384 = var385; -} -var389 = ((val* (*)(val*))(var_mtype->class->vft[COLOR_model__MVirtualType__mproperty]))(var_mtype) /* mproperty on */; -var390 = ((val* (*)(val*))(var389->class->vft[COLOR_separate_compiler__MProperty__const_color]))(var389) /* const_color on */; -if (varonce391) { -var392 = varonce391; -} else { -var393 = ")];"; -var394 = 3; -var395 = string__NativeString__to_s_with_length(var393, var394); -var392 = var395; -varonce391 = var392; -} -var396 = NEW_array__Array(&type_array__Arraykernel__Object); -{ /* var396 = array_instance Array[Object] */ -var397 = 8; -var398 = NEW_array__NativeArray(var397, &type_array__NativeArraykernel__Object); -((struct instance_array__NativeArray*)var398)->values[0] = (val*) var_entry; -((struct instance_array__NativeArray*)var398)->values[1] = (val*) var375; -((struct instance_array__NativeArray*)var398)->values[2] = (val*) var_recv_ptr; -((struct instance_array__NativeArray*)var398)->values[3] = (val*) var380; -((struct instance_array__NativeArray*)var398)->values[4] = (val*) var_recv_ptr; -((struct instance_array__NativeArray*)var398)->values[5] = (val*) var385; -((struct instance_array__NativeArray*)var398)->values[6] = (val*) var390; -((struct instance_array__NativeArray*)var398)->values[7] = (val*) var392; -((void (*)(val*, val*, long))(var396->class->vft[COLOR_array__Array__with_native]))(var396, var398, var397) /* with_native on */; -CHECK_NEW_array__Array(var396); -} -var399 = ((val* (*)(val*))(var396->class->vft[COLOR_string__Object__to_s]))(var396) /* to_s on */; -((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var399) /* add on */; -} else { -if (varonce400) { -var401 = varonce400; -} else { -var402 = " = "; -var403 = 3; -var404 = string__NativeString__to_s_with_length(var402, var403); -var401 = var404; -varonce400 = var401; -} -if (varonce405) { -var406 = varonce405; -} else { -var407 = "vts_table->vts["; -var408 = 15; -var409 = string__NativeString__to_s_with_length(var407, var408); -var406 = var409; -varonce405 = var406; -} -var410 = ((val* (*)(val*))(var_mtype->class->vft[COLOR_model__MVirtualType__mproperty]))(var_mtype) /* mproperty on */; -var411 = ((val* (*)(val*))(var410->class->vft[COLOR_separate_compiler__MProperty__const_color]))(var410) /* const_color on */; -if (varonce412) { -var413 = varonce412; -} else { -var414 = "];"; -var415 = 2; -var416 = string__NativeString__to_s_with_length(var414, var415); -var413 = var416; -varonce412 = var413; +var_class_name317 = var313 == NULL ? "null" : var313->type->name; +fprintf(stderr, "Runtime error: Cast failed. Expected `%s`, got `%s`", "MClassType", var_class_name317); +fprintf(stderr, " (%s:%d)\n", "src/separate_erasure_compiler.nit", 528); +show_backtrace(1); +} +var318 = ((val* (*)(val*))(var313->class->vft[COLOR_model__MClassType__mclass]))(var313) /* mclass on */; +var_mclass319 = var318; +if (varonce320) { +var321 = varonce320; +} else { +var322 = "class_"; +var323 = 6; +var324 = string__NativeString__to_s_with_length(var322, var323); +var321 = var324; +varonce320 = var321; +} +var325 = ((val* (*)(val*))(var_mclass319->class->vft[COLOR_abstract_compiler__MClass__c_name]))(var_mclass319) /* c_name on */; +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*) var321; +((struct instance_array__NativeArray*)var328)->values[1] = (val*) var325; +((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__require_declaration]))(self, var329) /* require_declaration on */; +if (varonce330) { +var331 = varonce330; +} else { +var332 = "class_"; +var333 = 6; +var334 = string__NativeString__to_s_with_length(var332, var333); +var331 = var334; +varonce330 = var331; +} +var335 = ((val* (*)(val*))(var_mclass319->class->vft[COLOR_abstract_compiler__MClass__c_name]))(var_mclass319) /* c_name on */; +if (varonce336) { +var337 = varonce336; +} else { +var338 = "."; +var339 = 1; +var340 = string__NativeString__to_s_with_length(var338, var339); +var337 = var340; +varonce336 = var337; +} +var341 = NEW_array__Array(&type_array__Arraykernel__Object); +{ /* var341 = array_instance Array[Object] */ +var342 = 3; +var343 = NEW_array__NativeArray(var342, &type_array__NativeArraykernel__Object); +((struct instance_array__NativeArray*)var343)->values[0] = (val*) var331; +((struct instance_array__NativeArray*)var343)->values[1] = (val*) var335; +((struct instance_array__NativeArray*)var343)->values[2] = (val*) var337; +((void (*)(val*, val*, long))(var341->class->vft[COLOR_array__Array__with_native]))(var341, var343, var342) /* with_native on */; +} +var344 = ((val* (*)(val*))(var341->class->vft[COLOR_string__Object__to_s]))(var341) /* to_s on */; +var_recv_ptr = var344; +} +if (varonce345) { +var346 = varonce345; +} else { +var347 = "entry"; +var348 = 5; +var349 = string__NativeString__to_s_with_length(var347, var348); +var346 = var349; +varonce345 = var346; +} +var350 = ((val* (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__get_name]))(self, var346) /* get_name on */; +var_entry = var350; +if (varonce351) { +var352 = varonce351; +} else { +var353 = "struct vts_entry "; +var354 = 17; +var355 = string__NativeString__to_s_with_length(var353, var354); +var352 = var355; +varonce351 = var352; +} +if (varonce356) { +var357 = varonce356; +} else { +var358 = ";"; +var359 = 1; +var360 = string__NativeString__to_s_with_length(var358, var359); +var357 = var360; +varonce356 = var357; +} +var361 = NEW_array__Array(&type_array__Arraykernel__Object); +{ /* var361 = array_instance Array[Object] */ +var362 = 3; +var363 = NEW_array__NativeArray(var362, &type_array__NativeArraykernel__Object); +((struct instance_array__NativeArray*)var363)->values[0] = (val*) var352; +((struct instance_array__NativeArray*)var363)->values[1] = (val*) var_entry; +((struct instance_array__NativeArray*)var363)->values[2] = (val*) var357; +((void (*)(val*, val*, long))(var361->class->vft[COLOR_array__Array__with_native]))(var361, var363, var362) /* with_native on */; +} +var364 = ((val* (*)(val*))(var361->class->vft[COLOR_string__Object__to_s]))(var361) /* to_s on */; +((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var364) /* add on */; +var365 = ((val* (*)(val*))(var_mtype->class->vft[COLOR_model__MVirtualType__mproperty]))(var_mtype) /* mproperty on */; +var366 = ((val* (*)(val*))(var365->class->vft[COLOR_separate_compiler__MProperty__const_color]))(var365) /* const_color on */; +((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__require_declaration]))(self, var366) /* require_declaration on */; +var367 = ((val* (*)(val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__compiler]))(self) /* compiler on */; +/* isa SeparateErasureCompiler */ +cltype369 = type_separate_erasure_compiler__SeparateErasureCompiler.color; +idtype370 = type_separate_erasure_compiler__SeparateErasureCompiler.id; +if(cltype369 >= var367->type->table_size) { +var368 = 0; +} else { +var368 = var367->type->type_table[cltype369] == idtype370; +} +if (!var368) { +var_class_name371 = var367 == NULL ? "null" : var367->type->name; +fprintf(stderr, "Runtime error: Cast failed. Expected `%s`, got `%s`", "SeparateErasureCompiler", var_class_name371); +fprintf(stderr, " (%s:%d)\n", "src/separate_erasure_compiler.nit", 535); +show_backtrace(1); +} +var372 = ((val* (*)(val*))(var367->class->vft[COLOR_separate_erasure_compiler__SeparateErasureCompiler__vt_layout]))(var367) /* vt_layout on */; +/* isa PHLayout[MClass, MVirtualTypeProp] */ +cltype374 = type_layout_builders__PHLayoutmodel__MClassmodel__MVirtualTypeProp.color; +idtype375 = type_layout_builders__PHLayoutmodel__MClassmodel__MVirtualTypeProp.id; +if(var372 == NULL) { +var373 = 0; +} else { +if(cltype374 >= var372->type->table_size) { +var373 = 0; +} else { +var373 = var372->type->type_table[cltype374] == idtype375; } -var417 = NEW_array__Array(&type_array__Arraykernel__Object); -{ /* var417 = array_instance Array[Object] */ -var418 = 6; -var419 = NEW_array__NativeArray(var418, &type_array__NativeArraykernel__Object); -((struct instance_array__NativeArray*)var419)->values[0] = (val*) var_entry; -((struct instance_array__NativeArray*)var419)->values[1] = (val*) var401; -((struct instance_array__NativeArray*)var419)->values[2] = (val*) var_recv_ptr; -((struct instance_array__NativeArray*)var419)->values[3] = (val*) var406; -((struct instance_array__NativeArray*)var419)->values[4] = (val*) var411; -((struct instance_array__NativeArray*)var419)->values[5] = (val*) var413; -((void (*)(val*, val*, long))(var417->class->vft[COLOR_array__Array__with_native]))(var417, var419, var418) /* with_native on */; -CHECK_NEW_array__Array(var417); } -var420 = ((val* (*)(val*))(var417->class->vft[COLOR_string__Object__to_s]))(var417) /* to_s on */; -((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var420) /* add on */; -} -if (varonce421) { -var422 = varonce421; -} else { -var423 = " = "; -var424 = 3; -var425 = string__NativeString__to_s_with_length(var423, var424); -var422 = var425; -varonce421 = var422; -} -if (varonce426) { -var427 = varonce426; -} else { -var428 = ".class->color;"; -var429 = 14; -var430 = string__NativeString__to_s_with_length(var428, var429); -var427 = var430; -varonce426 = var427; -} -var431 = NEW_array__Array(&type_array__Arraykernel__Object); -{ /* var431 = array_instance Array[Object] */ -var432 = 4; -var433 = NEW_array__NativeArray(var432, &type_array__NativeArraykernel__Object); -((struct instance_array__NativeArray*)var433)->values[0] = (val*) var_cltype; -((struct instance_array__NativeArray*)var433)->values[1] = (val*) var422; -((struct instance_array__NativeArray*)var433)->values[2] = (val*) var_entry; -((struct instance_array__NativeArray*)var433)->values[3] = (val*) var427; -((void (*)(val*, val*, long))(var431->class->vft[COLOR_array__Array__with_native]))(var431, var433, var432) /* with_native on */; -CHECK_NEW_array__Array(var431); -} -var434 = ((val* (*)(val*))(var431->class->vft[COLOR_string__Object__to_s]))(var431) /* to_s on */; -((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var434) /* add on */; -if (varonce435) { -var436 = varonce435; -} else { -var437 = " = "; -var438 = 3; -var439 = string__NativeString__to_s_with_length(var437, var438); -var436 = var439; -varonce435 = var436; -} -if (varonce440) { -var441 = varonce440; -} else { -var442 = ".class->id;"; -var443 = 11; -var444 = string__NativeString__to_s_with_length(var442, var443); -var441 = var444; -varonce440 = var441; -} -var445 = NEW_array__Array(&type_array__Arraykernel__Object); -{ /* var445 = array_instance Array[Object] */ -var446 = 4; -var447 = NEW_array__NativeArray(var446, &type_array__NativeArraykernel__Object); -((struct instance_array__NativeArray*)var447)->values[0] = (val*) var_idtype; -((struct instance_array__NativeArray*)var447)->values[1] = (val*) var436; -((struct instance_array__NativeArray*)var447)->values[2] = (val*) var_entry; -((struct instance_array__NativeArray*)var447)->values[3] = (val*) var441; -((void (*)(val*, val*, long))(var445->class->vft[COLOR_array__Array__with_native]))(var445, var447, var446) /* with_native on */; -CHECK_NEW_array__Array(var445); -} -var448 = ((val* (*)(val*))(var445->class->vft[COLOR_string__Object__to_s]))(var445) /* to_s on */; -((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var448) /* add on */; -var_450 = var_maybe_null; -if (var_maybe_null){ -if (varonce451) { -var452 = varonce451; -} else { -var453 = "0"; -var454 = 1; -var455 = string__NativeString__to_s_with_length(var453, var454); -var452 = var455; -varonce451 = var452; -} -var456 = ((short int (*)(val*, val*))(var_accept_null->class->vft[COLOR_kernel__Object___61d_61d]))(var_accept_null, var452) /* == on */; -var449 = var456; -} else { -var449 = var_450; -} -if (var449){ -if (varonce457) { -var458 = varonce457; -} else { -var459 = "is_nullable"; -var460 = 11; -var461 = string__NativeString__to_s_with_length(var459, var460); -var458 = var461; -varonce457 = var458; -} -var462 = ((val* (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__get_name]))(self, var458) /* get_name on */; -var_is_nullable = var462; -if (varonce463) { -var464 = varonce463; -} else { -var465 = "short int "; -var466 = 10; -var467 = string__NativeString__to_s_with_length(var465, var466); -var464 = var467; -varonce463 = var464; -} -if (varonce468) { -var469 = varonce468; -} else { -var470 = ";"; -var471 = 1; -var472 = string__NativeString__to_s_with_length(var470, var471); -var469 = var472; -varonce468 = var469; -} -var473 = NEW_array__Array(&type_array__Arraykernel__Object); -{ /* var473 = array_instance Array[Object] */ -var474 = 3; -var475 = NEW_array__NativeArray(var474, &type_array__NativeArraykernel__Object); -((struct instance_array__NativeArray*)var475)->values[0] = (val*) var464; -((struct instance_array__NativeArray*)var475)->values[1] = (val*) var_is_nullable; -((struct instance_array__NativeArray*)var475)->values[2] = (val*) var469; -((void (*)(val*, val*, long))(var473->class->vft[COLOR_array__Array__with_native]))(var473, var475, var474) /* with_native on */; -CHECK_NEW_array__Array(var473); -} -var476 = ((val* (*)(val*))(var473->class->vft[COLOR_string__Object__to_s]))(var473) /* to_s on */; -((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add_decl]))(self, var476) /* add_decl on */; -if (varonce477) { -var478 = varonce477; -} else { -var479 = " = "; -var480 = 3; -var481 = string__NativeString__to_s_with_length(var479, var480); -var478 = var481; -varonce477 = var478; +if (var373){ +if (varonce376) { +var377 = varonce376; +} else { +var378 = " = "; +var379 = 3; +var380 = string__NativeString__to_s_with_length(var378, var379); +var377 = var380; +varonce376 = var377; +} +if (varonce381) { +var382 = varonce381; +} else { +var383 = "vts_table->vts[HASH("; +var384 = 20; +var385 = string__NativeString__to_s_with_length(var383, var384); +var382 = var385; +varonce381 = var382; +} +if (varonce386) { +var387 = varonce386; +} else { +var388 = "vts_table->mask, "; +var389 = 17; +var390 = string__NativeString__to_s_with_length(var388, var389); +var387 = var390; +varonce386 = var387; +} +var391 = ((val* (*)(val*))(var_mtype->class->vft[COLOR_model__MVirtualType__mproperty]))(var_mtype) /* mproperty on */; +var392 = ((val* (*)(val*))(var391->class->vft[COLOR_separate_compiler__MProperty__const_color]))(var391) /* const_color on */; +if (varonce393) { +var394 = varonce393; +} else { +var395 = ")];"; +var396 = 3; +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 = 8; +var400 = NEW_array__NativeArray(var399, &type_array__NativeArraykernel__Object); +((struct instance_array__NativeArray*)var400)->values[0] = (val*) var_entry; +((struct instance_array__NativeArray*)var400)->values[1] = (val*) var377; +((struct instance_array__NativeArray*)var400)->values[2] = (val*) var_recv_ptr; +((struct instance_array__NativeArray*)var400)->values[3] = (val*) var382; +((struct instance_array__NativeArray*)var400)->values[4] = (val*) var_recv_ptr; +((struct instance_array__NativeArray*)var400)->values[5] = (val*) var387; +((struct instance_array__NativeArray*)var400)->values[6] = (val*) var392; +((struct instance_array__NativeArray*)var400)->values[7] = (val*) var394; +((void (*)(val*, val*, long))(var398->class->vft[COLOR_array__Array__with_native]))(var398, var400, var399) /* with_native on */; +} +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; +} else { +var404 = " = "; +var405 = 3; +var406 = string__NativeString__to_s_with_length(var404, var405); +var403 = var406; +varonce402 = var403; } -if (varonce482) { -var483 = varonce482; +if (varonce407) { +var408 = varonce407; } else { -var484 = ".is_nullable;"; -var485 = 13; -var486 = string__NativeString__to_s_with_length(var484, var485); -var483 = var486; -varonce482 = var483; -} -var487 = NEW_array__Array(&type_array__Arraykernel__Object); -{ /* var487 = array_instance Array[Object] */ -var488 = 4; -var489 = NEW_array__NativeArray(var488, &type_array__NativeArraykernel__Object); -((struct instance_array__NativeArray*)var489)->values[0] = (val*) var_is_nullable; -((struct instance_array__NativeArray*)var489)->values[1] = (val*) var478; -((struct instance_array__NativeArray*)var489)->values[2] = (val*) var_entry; -((struct instance_array__NativeArray*)var489)->values[3] = (val*) var483; -((void (*)(val*, val*, long))(var487->class->vft[COLOR_array__Array__with_native]))(var487, var489, var488) /* with_native on */; -CHECK_NEW_array__Array(var487); -} -var490 = ((val* (*)(val*))(var487->class->vft[COLOR_string__Object__to_s]))(var487) /* to_s on */; -((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var490) /* add on */; -var491 = ((val* (*)(val*))(var_is_nullable->class->vft[COLOR_string__Object__to_s]))(var_is_nullable) /* to_s on */; -var_accept_null = var491; -} else { -} -var492 = ((val* (*)(val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__compiler]))(self) /* compiler on */; -var493 = ((val* (*)(val*))(var492->class->vft[COLOR_abstract_compiler__AbstractCompiler__modelbuilder]))(var492) /* modelbuilder on */; -var494 = ((val* (*)(val*))(var493->class->vft[COLOR_modelbuilder__ModelBuilder__toolcontext]))(var493) /* toolcontext on */; -var495 = ((val* (*)(val*))(var494->class->vft[COLOR_abstract_compiler__ToolContext__opt_typing_test_metrics]))(var494) /* opt_typing_test_metrics on */; -var496 = ((val* (*)(val*))(var495->class->vft[COLOR_opts__Option__value]))(var495) /* value on */; -var497 = ((struct instance_kernel__Bool*)var496)->value; /* autounbox from nullable Object to Bool */; -if (var497){ -var498 = ((val* (*)(val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__compiler]))(self) /* compiler on */; -var499 = ((val* (*)(val*))(var498->class->vft[COLOR_abstract_compiler__AbstractCompiler__count_type_test_unresolved]))(var498) /* count_type_test_unresolved on */; -var_500 = var499; -var_501 = var_tag; -var502 = ((val* (*)(val*, val*))(var_500->class->vft[COLOR_abstract_collection__MapRead___91d_93d]))(var_500, var_501) /* [] on */; -var503 = 1; -{ /* Inline kernel#Int#+ (var502,var503) */ -var506 = ((struct instance_kernel__Int*)var502)->value; /* autounbox from nullable Object to Int */; -var507 = var506 + var503; -var504 = var507; -goto RET_LABEL505; -RET_LABEL505:(void)0; -} -var508 = BOX_kernel__Int(var504); /* autobox from Int to nullable Object */ -((void (*)(val*, val*, val*))(var_500->class->vft[COLOR_abstract_collection__Map___91d_93d_61d]))(var_500, var_501, var508) /* []= on */; -if (varonce509) { -var510 = varonce509; -} else { -var511 = "count_type_test_unresolved_"; -var512 = 27; -var513 = string__NativeString__to_s_with_length(var511, var512); -var510 = var513; -varonce509 = var510; -} -if (varonce514) { -var515 = varonce514; -} else { -var516 = "++;"; -var517 = 3; -var518 = string__NativeString__to_s_with_length(var516, var517); -var515 = var518; -varonce514 = var515; -} -var519 = NEW_array__Array(&type_array__Arraykernel__Object); -{ /* var519 = array_instance Array[Object] */ -var520 = 3; -var521 = NEW_array__NativeArray(var520, &type_array__NativeArraykernel__Object); -((struct instance_array__NativeArray*)var521)->values[0] = (val*) var510; -((struct instance_array__NativeArray*)var521)->values[1] = (val*) var_tag; -((struct instance_array__NativeArray*)var521)->values[2] = (val*) var515; -((void (*)(val*, val*, long))(var519->class->vft[COLOR_array__Array__with_native]))(var519, var521, var520) /* with_native on */; -CHECK_NEW_array__Array(var519); -} -var522 = ((val* (*)(val*))(var519->class->vft[COLOR_string__Object__to_s]))(var519) /* to_s on */; -((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var522) /* add on */; -} else { -} -} else { -if (varonce523) { -var524 = varonce523; -} else { -var525 = "type_test("; -var526 = 10; -var527 = string__NativeString__to_s_with_length(var525, var526); -var524 = var527; -varonce523 = var524; -} -var528 = ((val* (*)(val*))(var_value->class->vft[COLOR_string__Object__inspect]))(var_value) /* inspect on */; -if (varonce529) { -var530 = varonce529; -} else { -var531 = ", "; -var532 = 2; -var533 = string__NativeString__to_s_with_length(var531, var532); -var530 = var533; -varonce529 = var530; -} -if (varonce534) { -var535 = varonce534; -} else { -var536 = ")"; -var537 = 1; -var538 = string__NativeString__to_s_with_length(var536, var537); -var535 = var538; -varonce534 = var535; -} -var539 = NEW_array__Array(&type_array__Arraykernel__Object); -{ /* var539 = array_instance Array[Object] */ -var540 = 5; -var541 = NEW_array__NativeArray(var540, &type_array__NativeArraykernel__Object); -((struct instance_array__NativeArray*)var541)->values[0] = (val*) var524; -((struct instance_array__NativeArray*)var541)->values[1] = (val*) var528; -((struct instance_array__NativeArray*)var541)->values[2] = (val*) var530; -((struct instance_array__NativeArray*)var541)->values[3] = (val*) var_mtype; -((struct instance_array__NativeArray*)var541)->values[4] = (val*) var535; -((void (*)(val*, val*, long))(var539->class->vft[COLOR_array__Array__with_native]))(var539, var541, var540) /* with_native on */; -CHECK_NEW_array__Array(var539); -} -var542 = ((val* (*)(val*))(var539->class->vft[COLOR_string__Object__to_s]))(var539) /* to_s on */; -((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__debug]))(self, var542) /* debug on */; -fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Aborted", "src/separate_erasure_compiler.nit", 553); -exit(1); -} +var409 = "vts_table->vts["; +var410 = 15; +var411 = string__NativeString__to_s_with_length(var409, var410); +var408 = var411; +varonce407 = var408; } +var412 = ((val* (*)(val*))(var_mtype->class->vft[COLOR_model__MVirtualType__mproperty]))(var_mtype) /* mproperty on */; +var413 = ((val* (*)(val*))(var412->class->vft[COLOR_separate_compiler__MProperty__const_color]))(var412) /* const_color on */; +if (varonce414) { +var415 = varonce414; +} else { +var416 = "];"; +var417 = 2; +var418 = string__NativeString__to_s_with_length(var416, var417); +var415 = var418; +varonce414 = var415; +} +var419 = NEW_array__Array(&type_array__Arraykernel__Object); +{ /* var419 = array_instance Array[Object] */ +var420 = 6; +var421 = NEW_array__NativeArray(var420, &type_array__NativeArraykernel__Object); +((struct instance_array__NativeArray*)var421)->values[0] = (val*) var_entry; +((struct instance_array__NativeArray*)var421)->values[1] = (val*) var403; +((struct instance_array__NativeArray*)var421)->values[2] = (val*) var_recv_ptr; +((struct instance_array__NativeArray*)var421)->values[3] = (val*) var408; +((struct instance_array__NativeArray*)var421)->values[4] = (val*) var413; +((struct instance_array__NativeArray*)var421)->values[5] = (val*) var415; +((void (*)(val*, val*, long))(var419->class->vft[COLOR_array__Array__with_native]))(var419, var421, var420) /* with_native on */; +} +var422 = ((val* (*)(val*))(var419->class->vft[COLOR_string__Object__to_s]))(var419) /* to_s on */; +((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var422) /* add on */; +} +if (varonce423) { +var424 = varonce423; +} else { +var425 = " = "; +var426 = 3; +var427 = string__NativeString__to_s_with_length(var425, var426); +var424 = var427; +varonce423 = var424; +} +if (varonce428) { +var429 = varonce428; +} else { +var430 = ".class->color;"; +var431 = 14; +var432 = string__NativeString__to_s_with_length(var430, var431); +var429 = var432; +varonce428 = var429; +} +var433 = NEW_array__Array(&type_array__Arraykernel__Object); +{ /* var433 = array_instance Array[Object] */ +var434 = 4; +var435 = NEW_array__NativeArray(var434, &type_array__NativeArraykernel__Object); +((struct instance_array__NativeArray*)var435)->values[0] = (val*) var_cltype; +((struct instance_array__NativeArray*)var435)->values[1] = (val*) var424; +((struct instance_array__NativeArray*)var435)->values[2] = (val*) var_entry; +((struct instance_array__NativeArray*)var435)->values[3] = (val*) var429; +((void (*)(val*, val*, long))(var433->class->vft[COLOR_array__Array__with_native]))(var433, var435, var434) /* with_native on */; +} +var436 = ((val* (*)(val*))(var433->class->vft[COLOR_string__Object__to_s]))(var433) /* to_s on */; +((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var436) /* add on */; +if (varonce437) { +var438 = varonce437; +} else { +var439 = " = "; +var440 = 3; +var441 = string__NativeString__to_s_with_length(var439, var440); +var438 = var441; +varonce437 = var438; +} +if (varonce442) { +var443 = varonce442; +} else { +var444 = ".class->id;"; +var445 = 11; +var446 = string__NativeString__to_s_with_length(var444, var445); +var443 = var446; +varonce442 = var443; +} +var447 = NEW_array__Array(&type_array__Arraykernel__Object); +{ /* var447 = array_instance Array[Object] */ +var448 = 4; +var449 = NEW_array__NativeArray(var448, &type_array__NativeArraykernel__Object); +((struct instance_array__NativeArray*)var449)->values[0] = (val*) var_idtype; +((struct instance_array__NativeArray*)var449)->values[1] = (val*) var438; +((struct instance_array__NativeArray*)var449)->values[2] = (val*) var_entry; +((struct instance_array__NativeArray*)var449)->values[3] = (val*) var443; +((void (*)(val*, val*, long))(var447->class->vft[COLOR_array__Array__with_native]))(var447, var449, var448) /* with_native on */; +} +var450 = ((val* (*)(val*))(var447->class->vft[COLOR_string__Object__to_s]))(var447) /* to_s on */; +((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var450) /* add on */; +var_452 = var_maybe_null; if (var_maybe_null){ -if (varonce543) { -var544 = varonce543; -} else { -var545 = "if("; -var546 = 3; -var547 = string__NativeString__to_s_with_length(var545, var546); -var544 = var547; -varonce543 = var544; -} -if (varonce548) { -var549 = varonce548; -} else { -var550 = " == NULL) {"; -var551 = 11; -var552 = string__NativeString__to_s_with_length(var550, var551); -var549 = var552; -varonce548 = var549; -} -var553 = NEW_array__Array(&type_array__Arraykernel__Object); -{ /* var553 = array_instance Array[Object] */ -var554 = 3; -var555 = NEW_array__NativeArray(var554, &type_array__NativeArraykernel__Object); -((struct instance_array__NativeArray*)var555)->values[0] = (val*) var544; -((struct instance_array__NativeArray*)var555)->values[1] = (val*) var_value; -((struct instance_array__NativeArray*)var555)->values[2] = (val*) var549; -((void (*)(val*, val*, long))(var553->class->vft[COLOR_array__Array__with_native]))(var553, var555, var554) /* with_native on */; -CHECK_NEW_array__Array(var553); -} -var556 = ((val* (*)(val*))(var553->class->vft[COLOR_string__Object__to_s]))(var553) /* to_s on */; -((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var556) /* add on */; -if (varonce557) { -var558 = varonce557; -} else { -var559 = " = "; -var560 = 3; -var561 = string__NativeString__to_s_with_length(var559, var560); -var558 = var561; -varonce557 = var558; -} -if (varonce562) { -var563 = varonce562; -} else { -var564 = ";"; -var565 = 1; -var566 = string__NativeString__to_s_with_length(var564, var565); -var563 = var566; -varonce562 = var563; -} -var567 = NEW_array__Array(&type_array__Arraykernel__Object); -{ /* var567 = array_instance Array[Object] */ -var568 = 4; -var569 = NEW_array__NativeArray(var568, &type_array__NativeArraykernel__Object); -((struct instance_array__NativeArray*)var569)->values[0] = (val*) var_res; -((struct instance_array__NativeArray*)var569)->values[1] = (val*) var558; -((struct instance_array__NativeArray*)var569)->values[2] = (val*) var_accept_null; -((struct instance_array__NativeArray*)var569)->values[3] = (val*) var563; -((void (*)(val*, val*, long))(var567->class->vft[COLOR_array__Array__with_native]))(var567, var569, var568) /* with_native on */; -CHECK_NEW_array__Array(var567); -} -var570 = ((val* (*)(val*))(var567->class->vft[COLOR_string__Object__to_s]))(var567) /* to_s on */; -((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var570) /* add on */; -if (varonce571) { -var572 = varonce571; -} else { -var573 = "} else {"; -var574 = 8; -var575 = string__NativeString__to_s_with_length(var573, var574); -var572 = var575; -varonce571 = var572; -} -((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var572) /* add on */; -} else { -} -var576 = ((val* (*)(val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__compiler]))(self) /* compiler on */; -/* isa SeparateErasureCompiler */ -cltype578 = type_separate_erasure_compiler__SeparateErasureCompiler.color; -idtype579 = type_separate_erasure_compiler__SeparateErasureCompiler.id; -if(cltype578 >= var576->type->table_size) { -var577 = 0; -} else { -var577 = var576->type->type_table[cltype578] == idtype579; -} -if (!var577) { -fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "src/separate_erasure_compiler.nit", 562); -exit(1); -} -var580 = ((val* (*)(val*))(var576->class->vft[COLOR_separate_erasure_compiler__SeparateErasureCompiler__class_layout]))(var576) /* class_layout on */; -/* isa PHLayout[MClass, MClass] */ -cltype582 = type_layout_builders__PHLayoutmodel__MClassmodel__MClass.color; -idtype583 = type_layout_builders__PHLayoutmodel__MClassmodel__MClass.id; -if(var580 == NULL) { -var581 = 0; -} else { -if(cltype582 >= var580->type->table_size) { -var581 = 0; -} else { -var581 = var580->type->type_table[cltype582] == idtype583; -} -} -if (var581){ -if (varonce584) { -var585 = varonce584; -} else { -var586 = " = HASH("; -var587 = 8; -var588 = string__NativeString__to_s_with_length(var586, var587); -var585 = var588; -varonce584 = var585; -} -if (varonce589) { -var590 = varonce589; -} else { -var591 = "color, "; -var592 = 7; -var593 = string__NativeString__to_s_with_length(var591, var592); -var590 = var593; -varonce589 = var590; -} -if (varonce594) { -var595 = varonce594; +if (varonce453) { +var454 = varonce453; } else { -var596 = ");"; -var597 = 2; -var598 = string__NativeString__to_s_with_length(var596, var597); -var595 = var598; -varonce594 = var595; -} -var599 = NEW_array__Array(&type_array__Arraykernel__Object); -{ /* var599 = array_instance Array[Object] */ -var600 = 6; -var601 = NEW_array__NativeArray(var600, &type_array__NativeArraykernel__Object); -((struct instance_array__NativeArray*)var601)->values[0] = (val*) var_cltype; -((struct instance_array__NativeArray*)var601)->values[1] = (val*) var585; -((struct instance_array__NativeArray*)var601)->values[2] = (val*) var_class_ptr; -((struct instance_array__NativeArray*)var601)->values[3] = (val*) var590; -((struct instance_array__NativeArray*)var601)->values[4] = (val*) var_idtype; -((struct instance_array__NativeArray*)var601)->values[5] = (val*) var595; -((void (*)(val*, val*, long))(var599->class->vft[COLOR_array__Array__with_native]))(var599, var601, var600) /* with_native on */; -CHECK_NEW_array__Array(var599); +var455 = "0"; +var456 = 1; +var457 = string__NativeString__to_s_with_length(var455, var456); +var454 = var457; +varonce453 = var454; } -var602 = ((val* (*)(val*))(var599->class->vft[COLOR_string__Object__to_s]))(var599) /* to_s on */; -((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var602) /* add on */; +var458 = ((short int (*)(val*, val*))(var_accept_null->class->vft[COLOR_kernel__Object___61d_61d]))(var_accept_null, var454) /* == on */; +var451 = var458; } else { +var451 = var_452; } -if (varonce603) { -var604 = varonce603; +if (var451){ +if (varonce459) { +var460 = varonce459; } else { -var605 = "if("; -var606 = 3; -var607 = string__NativeString__to_s_with_length(var605, var606); -var604 = var607; -varonce603 = var604; +var461 = "is_nullable"; +var462 = 11; +var463 = string__NativeString__to_s_with_length(var461, var462); +var460 = var463; +varonce459 = var460; } -if (varonce608) { -var609 = varonce608; -} else { -var610 = " >= "; -var611 = 4; -var612 = string__NativeString__to_s_with_length(var610, var611); -var609 = var612; -varonce608 = var609; -} -if (varonce613) { -var614 = varonce613; -} else { -var615 = "type_table->size) {"; -var616 = 19; -var617 = string__NativeString__to_s_with_length(var615, var616); -var614 = var617; -varonce613 = var614; -} -var618 = NEW_array__Array(&type_array__Arraykernel__Object); -{ /* var618 = array_instance Array[Object] */ -var619 = 5; -var620 = NEW_array__NativeArray(var619, &type_array__NativeArraykernel__Object); -((struct instance_array__NativeArray*)var620)->values[0] = (val*) var604; -((struct instance_array__NativeArray*)var620)->values[1] = (val*) var_cltype; -((struct instance_array__NativeArray*)var620)->values[2] = (val*) var609; -((struct instance_array__NativeArray*)var620)->values[3] = (val*) var_class_ptr; -((struct instance_array__NativeArray*)var620)->values[4] = (val*) var614; -((void (*)(val*, val*, long))(var618->class->vft[COLOR_array__Array__with_native]))(var618, var620, var619) /* with_native on */; -CHECK_NEW_array__Array(var618); -} -var621 = ((val* (*)(val*))(var618->class->vft[COLOR_string__Object__to_s]))(var618) /* to_s on */; -((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var621) /* add on */; -if (varonce622) { -var623 = varonce622; -} else { -var624 = " = 0;"; -var625 = 5; -var626 = string__NativeString__to_s_with_length(var624, var625); -var623 = var626; -varonce622 = var623; -} -var627 = NEW_array__Array(&type_array__Arraykernel__Object); -{ /* var627 = array_instance Array[Object] */ -var628 = 2; -var629 = NEW_array__NativeArray(var628, &type_array__NativeArraykernel__Object); -((struct instance_array__NativeArray*)var629)->values[0] = (val*) var_res; -((struct instance_array__NativeArray*)var629)->values[1] = (val*) var623; -((void (*)(val*, val*, long))(var627->class->vft[COLOR_array__Array__with_native]))(var627, var629, var628) /* with_native on */; -CHECK_NEW_array__Array(var627); -} -var630 = ((val* (*)(val*))(var627->class->vft[COLOR_string__Object__to_s]))(var627) /* to_s on */; -((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var630) /* add on */; -if (varonce631) { -var632 = varonce631; -} else { -var633 = "} else {"; -var634 = 8; -var635 = string__NativeString__to_s_with_length(var633, var634); -var632 = var635; -varonce631 = var632; -} -((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var632) /* add on */; -if (varonce636) { -var637 = varonce636; -} else { -var638 = " = "; -var639 = 3; -var640 = string__NativeString__to_s_with_length(var638, var639); -var637 = var640; -varonce636 = var637; +var464 = ((val* (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__get_name]))(self, var460) /* get_name on */; +var_is_nullable = var464; +if (varonce465) { +var466 = varonce465; +} else { +var467 = "short int "; +var468 = 10; +var469 = string__NativeString__to_s_with_length(var467, var468); +var466 = var469; +varonce465 = var466; +} +if (varonce470) { +var471 = varonce470; +} else { +var472 = ";"; +var473 = 1; +var474 = string__NativeString__to_s_with_length(var472, var473); +var471 = var474; +varonce470 = var471; +} +var475 = NEW_array__Array(&type_array__Arraykernel__Object); +{ /* var475 = array_instance Array[Object] */ +var476 = 3; +var477 = NEW_array__NativeArray(var476, &type_array__NativeArraykernel__Object); +((struct instance_array__NativeArray*)var477)->values[0] = (val*) var466; +((struct instance_array__NativeArray*)var477)->values[1] = (val*) var_is_nullable; +((struct instance_array__NativeArray*)var477)->values[2] = (val*) var471; +((void (*)(val*, val*, long))(var475->class->vft[COLOR_array__Array__with_native]))(var475, var477, var476) /* with_native on */; +} +var478 = ((val* (*)(val*))(var475->class->vft[COLOR_string__Object__to_s]))(var475) /* to_s on */; +((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add_decl]))(self, var478) /* add_decl on */; +if (varonce479) { +var480 = varonce479; +} else { +var481 = " = "; +var482 = 3; +var483 = string__NativeString__to_s_with_length(var481, var482); +var480 = var483; +varonce479 = var480; +} +if (varonce484) { +var485 = varonce484; +} else { +var486 = ".is_nullable;"; +var487 = 13; +var488 = string__NativeString__to_s_with_length(var486, var487); +var485 = var488; +varonce484 = var485; +} +var489 = NEW_array__Array(&type_array__Arraykernel__Object); +{ /* var489 = array_instance Array[Object] */ +var490 = 4; +var491 = NEW_array__NativeArray(var490, &type_array__NativeArraykernel__Object); +((struct instance_array__NativeArray*)var491)->values[0] = (val*) var_is_nullable; +((struct instance_array__NativeArray*)var491)->values[1] = (val*) var480; +((struct instance_array__NativeArray*)var491)->values[2] = (val*) var_entry; +((struct instance_array__NativeArray*)var491)->values[3] = (val*) var485; +((void (*)(val*, val*, long))(var489->class->vft[COLOR_array__Array__with_native]))(var489, var491, var490) /* with_native on */; +} +var492 = ((val* (*)(val*))(var489->class->vft[COLOR_string__Object__to_s]))(var489) /* to_s on */; +((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var492) /* add on */; +var493 = ((val* (*)(val*))(var_is_nullable->class->vft[COLOR_string__Object__to_s]))(var_is_nullable) /* to_s on */; +var_accept_null = var493; +} else { +} +var494 = ((val* (*)(val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__compiler]))(self) /* compiler on */; +var495 = ((val* (*)(val*))(var494->class->vft[COLOR_abstract_compiler__AbstractCompiler__modelbuilder]))(var494) /* modelbuilder on */; +var496 = ((val* (*)(val*))(var495->class->vft[COLOR_modelbuilder__ModelBuilder__toolcontext]))(var495) /* toolcontext on */; +var497 = ((val* (*)(val*))(var496->class->vft[COLOR_abstract_compiler__ToolContext__opt_typing_test_metrics]))(var496) /* opt_typing_test_metrics on */; +var498 = ((val* (*)(val*))(var497->class->vft[COLOR_opts__Option__value]))(var497) /* value on */; +var499 = ((struct instance_kernel__Bool*)var498)->value; /* autounbox from nullable Object to Bool */; +if (var499){ +var500 = ((val* (*)(val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__compiler]))(self) /* compiler on */; +var501 = ((val* (*)(val*))(var500->class->vft[COLOR_abstract_compiler__AbstractCompiler__count_type_test_unresolved]))(var500) /* count_type_test_unresolved on */; +var_502 = var501; +var_503 = var_tag; +var504 = ((val* (*)(val*, val*))(var_502->class->vft[COLOR_abstract_collection__MapRead___91d_93d]))(var_502, var_503) /* [] on */; +var505 = 1; +{ /* Inline kernel#Int#+ (var504,var505) */ +var508 = ((struct instance_kernel__Int*)var504)->value; /* autounbox from nullable Object to Int */; +var509 = var508 + var505; +var506 = var509; +goto RET_LABEL507; +RET_LABEL507:(void)0; +} +var510 = BOX_kernel__Int(var506); /* autobox from Int to nullable Object */ +((void (*)(val*, val*, val*))(var_502->class->vft[COLOR_abstract_collection__Map___91d_93d_61d]))(var_502, var_503, var510) /* []= on */; +if (varonce511) { +var512 = varonce511; +} else { +var513 = "count_type_test_unresolved_"; +var514 = 27; +var515 = string__NativeString__to_s_with_length(var513, var514); +var512 = var515; +varonce511 = var512; +} +if (varonce516) { +var517 = varonce516; +} else { +var518 = "++;"; +var519 = 3; +var520 = string__NativeString__to_s_with_length(var518, var519); +var517 = var520; +varonce516 = var517; +} +var521 = NEW_array__Array(&type_array__Arraykernel__Object); +{ /* var521 = array_instance Array[Object] */ +var522 = 3; +var523 = NEW_array__NativeArray(var522, &type_array__NativeArraykernel__Object); +((struct instance_array__NativeArray*)var523)->values[0] = (val*) var512; +((struct instance_array__NativeArray*)var523)->values[1] = (val*) var_tag; +((struct instance_array__NativeArray*)var523)->values[2] = (val*) var517; +((void (*)(val*, val*, long))(var521->class->vft[COLOR_array__Array__with_native]))(var521, var523, var522) /* with_native on */; +} +var524 = ((val* (*)(val*))(var521->class->vft[COLOR_string__Object__to_s]))(var521) /* to_s on */; +((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var524) /* add on */; +} else { +} +} else { +if (varonce525) { +var526 = varonce525; +} else { +var527 = "type_test("; +var528 = 10; +var529 = string__NativeString__to_s_with_length(var527, var528); +var526 = var529; +varonce525 = var526; +} +var530 = ((val* (*)(val*))(var_value->class->vft[COLOR_string__Object__inspect]))(var_value) /* inspect on */; +if (varonce531) { +var532 = varonce531; +} else { +var533 = ", "; +var534 = 2; +var535 = string__NativeString__to_s_with_length(var533, var534); +var532 = var535; +varonce531 = var532; +} +if (varonce536) { +var537 = varonce536; +} else { +var538 = ")"; +var539 = 1; +var540 = string__NativeString__to_s_with_length(var538, var539); +var537 = var540; +varonce536 = var537; +} +var541 = NEW_array__Array(&type_array__Arraykernel__Object); +{ /* var541 = array_instance Array[Object] */ +var542 = 5; +var543 = NEW_array__NativeArray(var542, &type_array__NativeArraykernel__Object); +((struct instance_array__NativeArray*)var543)->values[0] = (val*) var526; +((struct instance_array__NativeArray*)var543)->values[1] = (val*) var530; +((struct instance_array__NativeArray*)var543)->values[2] = (val*) var532; +((struct instance_array__NativeArray*)var543)->values[3] = (val*) var_mtype; +((struct instance_array__NativeArray*)var543)->values[4] = (val*) var537; +((void (*)(val*, val*, long))(var541->class->vft[COLOR_array__Array__with_native]))(var541, var543, var542) /* with_native on */; +} +var544 = ((val* (*)(val*))(var541->class->vft[COLOR_string__Object__to_s]))(var541) /* to_s on */; +((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__debug]))(self, var544) /* debug on */; +fprintf(stderr, "Runtime error: %s", "Aborted"); +fprintf(stderr, " (%s:%d)\n", "src/separate_erasure_compiler.nit", 554); +show_backtrace(1); } -if (varonce641) { -var642 = varonce641; -} else { -var643 = "type_table->table["; -var644 = 18; -var645 = string__NativeString__to_s_with_length(var643, var644); -var642 = var645; -varonce641 = var642; } -if (varonce646) { -var647 = varonce646; -} else { -var648 = "] == "; -var649 = 5; -var650 = string__NativeString__to_s_with_length(var648, var649); -var647 = var650; -varonce646 = var647; -} -if (varonce651) { -var652 = varonce651; -} else { -var653 = ";"; -var654 = 1; -var655 = string__NativeString__to_s_with_length(var653, var654); -var652 = var655; -varonce651 = var652; -} -var656 = NEW_array__Array(&type_array__Arraykernel__Object); -{ /* var656 = array_instance Array[Object] */ -var657 = 8; -var658 = NEW_array__NativeArray(var657, &type_array__NativeArraykernel__Object); -((struct instance_array__NativeArray*)var658)->values[0] = (val*) var_res; -((struct instance_array__NativeArray*)var658)->values[1] = (val*) var637; -((struct instance_array__NativeArray*)var658)->values[2] = (val*) var_class_ptr; -((struct instance_array__NativeArray*)var658)->values[3] = (val*) var642; -((struct instance_array__NativeArray*)var658)->values[4] = (val*) var_cltype; -((struct instance_array__NativeArray*)var658)->values[5] = (val*) var647; -((struct instance_array__NativeArray*)var658)->values[6] = (val*) var_idtype; -((struct instance_array__NativeArray*)var658)->values[7] = (val*) var652; -((void (*)(val*, val*, long))(var656->class->vft[COLOR_array__Array__with_native]))(var656, var658, var657) /* with_native on */; -CHECK_NEW_array__Array(var656); -} -var659 = ((val* (*)(val*))(var656->class->vft[COLOR_string__Object__to_s]))(var656) /* to_s on */; -((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var659) /* add on */; -if (varonce660) { -var661 = varonce660; -} else { -var662 = "}"; -var663 = 1; -var664 = string__NativeString__to_s_with_length(var662, var663); -var661 = var664; -varonce660 = var661; -} -((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var661) /* add on */; if (var_maybe_null){ -if (varonce665) { -var666 = varonce665; +if (varonce545) { +var546 = varonce545; +} else { +var547 = "if("; +var548 = 3; +var549 = string__NativeString__to_s_with_length(var547, var548); +var546 = var549; +varonce545 = var546; +} +if (varonce550) { +var551 = varonce550; +} else { +var552 = " == NULL) {"; +var553 = 11; +var554 = string__NativeString__to_s_with_length(var552, var553); +var551 = var554; +varonce550 = var551; +} +var555 = NEW_array__Array(&type_array__Arraykernel__Object); +{ /* var555 = array_instance Array[Object] */ +var556 = 3; +var557 = NEW_array__NativeArray(var556, &type_array__NativeArraykernel__Object); +((struct instance_array__NativeArray*)var557)->values[0] = (val*) var546; +((struct instance_array__NativeArray*)var557)->values[1] = (val*) var_value; +((struct instance_array__NativeArray*)var557)->values[2] = (val*) var551; +((void (*)(val*, val*, long))(var555->class->vft[COLOR_array__Array__with_native]))(var555, var557, var556) /* with_native on */; +} +var558 = ((val* (*)(val*))(var555->class->vft[COLOR_string__Object__to_s]))(var555) /* to_s on */; +((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var558) /* add on */; +if (varonce559) { +var560 = varonce559; +} else { +var561 = " = "; +var562 = 3; +var563 = string__NativeString__to_s_with_length(var561, var562); +var560 = var563; +varonce559 = var560; +} +if (varonce564) { +var565 = varonce564; +} else { +var566 = ";"; +var567 = 1; +var568 = string__NativeString__to_s_with_length(var566, var567); +var565 = var568; +varonce564 = var565; +} +var569 = NEW_array__Array(&type_array__Arraykernel__Object); +{ /* var569 = array_instance Array[Object] */ +var570 = 4; +var571 = NEW_array__NativeArray(var570, &type_array__NativeArraykernel__Object); +((struct instance_array__NativeArray*)var571)->values[0] = (val*) var_res; +((struct instance_array__NativeArray*)var571)->values[1] = (val*) var560; +((struct instance_array__NativeArray*)var571)->values[2] = (val*) var_accept_null; +((struct instance_array__NativeArray*)var571)->values[3] = (val*) var565; +((void (*)(val*, val*, long))(var569->class->vft[COLOR_array__Array__with_native]))(var569, var571, var570) /* with_native on */; +} +var572 = ((val* (*)(val*))(var569->class->vft[COLOR_string__Object__to_s]))(var569) /* to_s on */; +((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var572) /* add on */; +if (varonce573) { +var574 = varonce573; +} else { +var575 = "} else {"; +var576 = 8; +var577 = string__NativeString__to_s_with_length(var575, var576); +var574 = var577; +varonce573 = var574; +} +((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var574) /* add on */; +} else { +} +var578 = ((val* (*)(val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__compiler]))(self) /* compiler on */; +/* isa SeparateErasureCompiler */ +cltype580 = type_separate_erasure_compiler__SeparateErasureCompiler.color; +idtype581 = type_separate_erasure_compiler__SeparateErasureCompiler.id; +if(cltype580 >= var578->type->table_size) { +var579 = 0; +} else { +var579 = var578->type->type_table[cltype580] == idtype581; +} +if (!var579) { +var_class_name582 = var578 == NULL ? "null" : var578->type->name; +fprintf(stderr, "Runtime error: Cast failed. Expected `%s`, got `%s`", "SeparateErasureCompiler", var_class_name582); +fprintf(stderr, " (%s:%d)\n", "src/separate_erasure_compiler.nit", 563); +show_backtrace(1); +} +var583 = ((val* (*)(val*))(var578->class->vft[COLOR_separate_erasure_compiler__SeparateErasureCompiler__class_layout]))(var578) /* class_layout on */; +/* isa PHLayout[MClass, MClass] */ +cltype585 = type_layout_builders__PHLayoutmodel__MClassmodel__MClass.color; +idtype586 = type_layout_builders__PHLayoutmodel__MClassmodel__MClass.id; +if(var583 == NULL) { +var584 = 0; +} else { +if(cltype585 >= var583->type->table_size) { +var584 = 0; +} else { +var584 = var583->type->type_table[cltype585] == idtype586; +} +} +if (var584){ +if (varonce587) { +var588 = varonce587; +} else { +var589 = " = HASH("; +var590 = 8; +var591 = string__NativeString__to_s_with_length(var589, var590); +var588 = var591; +varonce587 = var588; +} +if (varonce592) { +var593 = varonce592; +} else { +var594 = "color, "; +var595 = 7; +var596 = string__NativeString__to_s_with_length(var594, var595); +var593 = var596; +varonce592 = var593; +} +if (varonce597) { +var598 = varonce597; +} else { +var599 = ");"; +var600 = 2; +var601 = string__NativeString__to_s_with_length(var599, var600); +var598 = var601; +varonce597 = var598; +} +var602 = NEW_array__Array(&type_array__Arraykernel__Object); +{ /* var602 = array_instance Array[Object] */ +var603 = 6; +var604 = NEW_array__NativeArray(var603, &type_array__NativeArraykernel__Object); +((struct instance_array__NativeArray*)var604)->values[0] = (val*) var_cltype; +((struct instance_array__NativeArray*)var604)->values[1] = (val*) var588; +((struct instance_array__NativeArray*)var604)->values[2] = (val*) var_class_ptr; +((struct instance_array__NativeArray*)var604)->values[3] = (val*) var593; +((struct instance_array__NativeArray*)var604)->values[4] = (val*) var_idtype; +((struct instance_array__NativeArray*)var604)->values[5] = (val*) var598; +((void (*)(val*, val*, long))(var602->class->vft[COLOR_array__Array__with_native]))(var602, var604, var603) /* with_native on */; +} +var605 = ((val* (*)(val*))(var602->class->vft[COLOR_string__Object__to_s]))(var602) /* to_s on */; +((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var605) /* add on */; +} else { +} +if (varonce606) { +var607 = varonce606; +} else { +var608 = "if("; +var609 = 3; +var610 = string__NativeString__to_s_with_length(var608, var609); +var607 = var610; +varonce606 = var607; +} +if (varonce611) { +var612 = varonce611; +} else { +var613 = " >= "; +var614 = 4; +var615 = string__NativeString__to_s_with_length(var613, var614); +var612 = var615; +varonce611 = var612; +} +if (varonce616) { +var617 = varonce616; +} else { +var618 = "type_table->size) {"; +var619 = 19; +var620 = string__NativeString__to_s_with_length(var618, var619); +var617 = var620; +varonce616 = var617; +} +var621 = NEW_array__Array(&type_array__Arraykernel__Object); +{ /* var621 = array_instance Array[Object] */ +var622 = 5; +var623 = NEW_array__NativeArray(var622, &type_array__NativeArraykernel__Object); +((struct instance_array__NativeArray*)var623)->values[0] = (val*) var607; +((struct instance_array__NativeArray*)var623)->values[1] = (val*) var_cltype; +((struct instance_array__NativeArray*)var623)->values[2] = (val*) var612; +((struct instance_array__NativeArray*)var623)->values[3] = (val*) var_class_ptr; +((struct instance_array__NativeArray*)var623)->values[4] = (val*) var617; +((void (*)(val*, val*, long))(var621->class->vft[COLOR_array__Array__with_native]))(var621, var623, var622) /* with_native on */; +} +var624 = ((val* (*)(val*))(var621->class->vft[COLOR_string__Object__to_s]))(var621) /* to_s on */; +((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var624) /* add on */; +if (varonce625) { +var626 = varonce625; +} else { +var627 = " = 0;"; +var628 = 5; +var629 = string__NativeString__to_s_with_length(var627, var628); +var626 = var629; +varonce625 = var626; +} +var630 = NEW_array__Array(&type_array__Arraykernel__Object); +{ /* var630 = array_instance Array[Object] */ +var631 = 2; +var632 = NEW_array__NativeArray(var631, &type_array__NativeArraykernel__Object); +((struct instance_array__NativeArray*)var632)->values[0] = (val*) var_res; +((struct instance_array__NativeArray*)var632)->values[1] = (val*) var626; +((void (*)(val*, val*, long))(var630->class->vft[COLOR_array__Array__with_native]))(var630, var632, var631) /* with_native on */; +} +var633 = ((val* (*)(val*))(var630->class->vft[COLOR_string__Object__to_s]))(var630) /* to_s on */; +((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var633) /* add on */; +if (varonce634) { +var635 = varonce634; +} else { +var636 = "} else {"; +var637 = 8; +var638 = string__NativeString__to_s_with_length(var636, var637); +var635 = var638; +varonce634 = var635; +} +((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var635) /* add on */; +if (varonce639) { +var640 = varonce639; +} else { +var641 = " = "; +var642 = 3; +var643 = string__NativeString__to_s_with_length(var641, var642); +var640 = var643; +varonce639 = var640; +} +if (varonce644) { +var645 = varonce644; +} else { +var646 = "type_table->table["; +var647 = 18; +var648 = string__NativeString__to_s_with_length(var646, var647); +var645 = var648; +varonce644 = var645; +} +if (varonce649) { +var650 = varonce649; +} else { +var651 = "] == "; +var652 = 5; +var653 = string__NativeString__to_s_with_length(var651, var652); +var650 = var653; +varonce649 = var650; +} +if (varonce654) { +var655 = varonce654; +} else { +var656 = ";"; +var657 = 1; +var658 = string__NativeString__to_s_with_length(var656, var657); +var655 = var658; +varonce654 = var655; +} +var659 = NEW_array__Array(&type_array__Arraykernel__Object); +{ /* var659 = array_instance Array[Object] */ +var660 = 8; +var661 = NEW_array__NativeArray(var660, &type_array__NativeArraykernel__Object); +((struct instance_array__NativeArray*)var661)->values[0] = (val*) var_res; +((struct instance_array__NativeArray*)var661)->values[1] = (val*) var640; +((struct instance_array__NativeArray*)var661)->values[2] = (val*) var_class_ptr; +((struct instance_array__NativeArray*)var661)->values[3] = (val*) var645; +((struct instance_array__NativeArray*)var661)->values[4] = (val*) var_cltype; +((struct instance_array__NativeArray*)var661)->values[5] = (val*) var650; +((struct instance_array__NativeArray*)var661)->values[6] = (val*) var_idtype; +((struct instance_array__NativeArray*)var661)->values[7] = (val*) var655; +((void (*)(val*, val*, long))(var659->class->vft[COLOR_array__Array__with_native]))(var659, var661, var660) /* with_native on */; +} +var662 = ((val* (*)(val*))(var659->class->vft[COLOR_string__Object__to_s]))(var659) /* to_s on */; +((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var662) /* add on */; +if (varonce663) { +var664 = varonce663; +} else { +var665 = "}"; +var666 = 1; +var667 = string__NativeString__to_s_with_length(var665, var666); +var664 = var667; +varonce663 = var664; +} +((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var664) /* add on */; +if (var_maybe_null){ +if (varonce668) { +var669 = varonce668; } else { -var667 = "}"; -var668 = 1; -var669 = string__NativeString__to_s_with_length(var667, var668); -var666 = var669; -varonce665 = var666; +var670 = "}"; +var671 = 1; +var672 = string__NativeString__to_s_with_length(var670, var671); +var669 = var672; +varonce668 = var669; } -((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var666) /* add on */; +((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var669) /* add on */; } else { } var = var_res; @@ -7839,7 +7842,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 */; @@ -7894,7 +7896,6 @@ 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 */; @@ -7917,7 +7918,6 @@ 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 */; @@ -7950,7 +7950,6 @@ var72 = NEW_array__NativeArray(var71, &type_array__NativeArraykernel__Object); ((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); } 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 */; @@ -8153,7 +8152,6 @@ var14 = 1; var15 = NEW_array__NativeArray(var14, &type_array__NativeArraymodel__MType); ((struct instance_array__NativeArray*)var15)->values[0] = (val*) var_elttype; ((void (*)(val*, val*, long))(var13->class->vft[COLOR_array__Array__with_native]))(var13, var15, var14) /* with_native on */; -CHECK_NEW_array__Array(var13); } var16 = ((val* (*)(val*, val*))(var12->class->vft[COLOR_model__MClass__get_mtype]))(var12, var13) /* get_mtype on */; var_arraytype = var16; @@ -8196,7 +8194,6 @@ var35 = NEW_array__NativeArray(var34, &type_array__NativeArraykernel__Object); ((struct instance_array__NativeArray*)var35)->values[3] = (val*) var_elttype; ((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 */; @@ -8216,7 +8213,6 @@ var44 = 1; var45 = NEW_array__NativeArray(var44, &type_array__NativeArraymodel__MType); ((struct instance_array__NativeArray*)var45)->values[0] = (val*) var_elttype; ((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*, val*))(var42->class->vft[COLOR_model__MClass__get_mtype]))(var42, var43) /* get_mtype on */; var47 = ((val* (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__new_var]))(self, var46) /* new_var on */; @@ -8240,7 +8236,6 @@ var57 = NEW_array__NativeArray(var56, &type_array__NativeArraykernel__Object); ((struct instance_array__NativeArray*)var57)->values[0] = (val*) var50; ((struct instance_array__NativeArray*)var57)->values[1] = (val*) var54; ((void (*)(val*, val*, long))(var55->class->vft[COLOR_array__Array__with_native]))(var55, var57, var56) /* with_native on */; -CHECK_NEW_array__Array(var55); } var58 = ((val* (*)(val*))(var55->class->vft[COLOR_string__Object__to_s]))(var55) /* to_s on */; ((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__require_declaration]))(self, var58) /* require_declaration on */; @@ -8285,7 +8280,6 @@ var79 = BOX_kernel__Int(var70); /* autobox from Int to Object */ ((struct instance_array__NativeArray*)var78)->values[4] = (val*) var79; ((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); } var80 = ((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, var80) /* add on */; @@ -8295,7 +8289,6 @@ var83 = ((long (*)(val*))(var_array->class->vft[COLOR_abstract_collection__Colle var84 = BOX_kernel__Int(var82); /* autobox from Int to Discrete */ var85 = BOX_kernel__Int(var83); /* autobox from Int to Discrete */ ((void (*)(val*, val*, val*))(var81->class->vft[COLOR_range__Range__without_last]))(var81, var84, var85) /* without_last on */; -CHECK_NEW_range__Range(var81); var86 = ((val* (*)(val*))(var81->class->vft[COLOR_abstract_collection__Collection__iterator]))(var81) /* iterator on */; for(;;) { var87 = ((short int (*)(val*))(var86->class->vft[COLOR_abstract_collection__Iterator__is_ok]))(var86) /* is_ok on */; @@ -8316,7 +8309,7 @@ var97 = string__NativeString__to_s_with_length(var95, var96); var94 = var97; varonce93 = var94; } -var98 = ((val* (*)(val*))(var_nclass->class->vft[COLOR_abstract_compiler__MClass__c_name]))(var_nclass) /* c_name on */; +var98 = ((val* (*)(val*))(var_nclass->class->vft[COLOR_separate_compiler__MClass__c_instance_name]))(var_nclass) /* c_instance_name on */; if (varonce99) { var100 = varonce99; } else { @@ -8368,7 +8361,6 @@ var122 = BOX_kernel__Int(var_i); /* autobox from Int to Object */ ((struct instance_array__NativeArray*)var121)->values[7] = (val*) var_r; ((struct instance_array__NativeArray*)var121)->values[8] = (val*) var115; ((void (*)(val*, val*, long))(var119->class->vft[COLOR_array__Array__with_native]))(var119, var121, var120) /* with_native on */; -CHECK_NEW_array__Array(var119); } var123 = ((val* (*)(val*))(var119->class->vft[COLOR_string__Object__to_s]))(var119) /* to_s on */; ((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var123) /* add on */; @@ -8397,11 +8389,9 @@ var134 = NEW_array__NativeArray(var133, &type_array__NativeArrayabstract_compile ((struct instance_array__NativeArray*)var134)->values[1] = (val*) var_nat; ((struct instance_array__NativeArray*)var134)->values[2] = (val*) var_length; ((void (*)(val*, val*, long))(var132->class->vft[COLOR_array__Array__with_native]))(var132, var134, var133) /* with_native on */; -CHECK_NEW_array__Array(var132); } var135 = ((val* (*)(val*, val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__send]))(self, var131, var132) /* send on */; var135; -((void (*)(val*, val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__check_init_instance]))(self, var_res, var_arraytype) /* check_init_instance on */; if (varonce136) { var137 = varonce136; } else { @@ -8433,6 +8423,7 @@ val* var_arguments /* var arguments: Array[RuntimeVariable] */; short int var /* : Bool */; int cltype; int idtype; +const char* var_class_name; val* var_ret /* var ret: MClassType */; static val* varonce; val* var1 /* : String */; @@ -8480,8 +8471,10 @@ var = 0; var = var_ret_type->type->type_table[cltype] == idtype; } if (!var) { -fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "src/separate_erasure_compiler.nit", 614); -exit(1); +var_class_name = var_ret_type == NULL ? "null" : var_ret_type->type->name; +fprintf(stderr, "Runtime error: Cast failed. Expected `%s`, got `%s`", "MClassType", var_class_name); +fprintf(stderr, " (%s:%d)\n", "src/separate_erasure_compiler.nit", 614); +show_backtrace(1); } var_ret = var_ret_type; if (varonce) { @@ -8502,7 +8495,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 */; @@ -8547,7 +8539,6 @@ var32 = NEW_array__NativeArray(var31, &type_array__NativeArraykernel__Object); ((struct instance_array__NativeArray*)var32)->values[3] = (val*) var24; ((struct instance_array__NativeArray*)var32)->values[4] = (val*) var26; ((void (*)(val*, val*, long))(var30->class->vft[COLOR_array__Array__with_native]))(var30, var32, var31) /* with_native on */; -CHECK_NEW_array__Array(var30); } var33 = ((val* (*)(val*))(var30->class->vft[COLOR_string__Object__to_s]))(var30) /* to_s on */; var34 = ((val* (*)(val*, val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__new_expr]))(self, var33, var_ret_type) /* new_expr on */;