+var7 = "*** GENERATING C ***";
+var8 = 20;
+var9 = string__NativeString__to_s_with_length(var7, var8);
+var6 = var9;
+varonce = var6;
+}
+var10 = 1;
+{
+toolcontext__ToolContext__info(var3, var6, var10); /* Direct call toolcontext#ToolContext#info on <var3:ToolContext>*/
+}
+var11 = NEW_separate_compiler__SeparateCompiler(&type_separate_compiler__SeparateCompiler);
+{
+separate_compiler__SeparateCompiler__init(var11, var_mainmodule, self, var_runtime_type_analysis); /* Direct call separate_compiler#SeparateCompiler#init on <var11:SeparateCompiler>*/
+}
+var_compiler = var11;
+{
+abstract_compiler__AbstractCompiler__compile_header(var_compiler); /* Direct call abstract_compiler#AbstractCompiler#compile_header on <var_compiler:SeparateCompiler>*/
+}
+{
+{ /* Inline modelbuilder#ModelBuilder#toolcontext (self) on <self:ModelBuilder> */
+var14 = self->attrs[COLOR_modelbuilder__ModelBuilder___toolcontext].val; /* _toolcontext on <self:ModelBuilder> */
+if (unlikely(var14 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _toolcontext");
+PRINT_ERROR(" (%s:%d)\n", "modelbuilder.nit", 106);
+show_backtrace(1);
+}
+var12 = var14;
+RET_LABEL13:(void)0;
+}
+}
+if (varonce15) {
+var16 = varonce15;
+} else {
+var17 = "Property coloring";
+var18 = 17;
+var19 = string__NativeString__to_s_with_length(var17, var18);
+var16 = var19;
+varonce15 = var16;
+}
+var20 = 2;
+{
+toolcontext__ToolContext__info(var12, var16, var20); /* Direct call toolcontext#ToolContext#info on <var12:ToolContext>*/
+}
+{
+{ /* Inline mmodule#MModule#name (var_mainmodule) on <var_mainmodule:MModule> */
+var23 = var_mainmodule->attrs[COLOR_mmodule__MModule___name].val; /* _name on <var_mainmodule:MModule> */
+if (unlikely(var23 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _name");
+PRINT_ERROR(" (%s:%d)\n", "model/mmodule.nit", 78);
+show_backtrace(1);
+}
+var21 = var23;
+RET_LABEL22:(void)0;
+}
+}
+if (varonce24) {
+var25 = varonce24;
+} else {
+var26 = ".classes";
+var27 = 8;
+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*) var21;
+((struct instance_array__NativeArray*)var31)->values[1] = (val*) var25;
+{
+((void (*)(val*, val*, long))(var29->class->vft[COLOR_array__Array__with_native]))(var29, var31, var30) /* with_native on <var29:Array[Object]>*/;
+}
+}
+{
+var32 = ((val* (*)(val*))(var29->class->vft[COLOR_string__Object__to_s]))(var29) /* to_s on <var29:Array[Object]>*/;
+}
+{
+var33 = abstract_compiler__AbstractCompiler__new_file(var_compiler, var32);
+}
+{
+separate_compiler__SeparateCompiler__do_property_coloring(var_compiler); /* Direct call separate_compiler#SeparateCompiler#do_property_coloring on <var_compiler:SeparateCompiler>*/
+}
+{
+{ /* Inline mmodule#MModule#in_importation (var_mainmodule) on <var_mainmodule:MModule> */
+var36 = var_mainmodule->attrs[COLOR_mmodule__MModule___in_importation].val; /* _in_importation on <var_mainmodule:MModule> */
+if (unlikely(var36 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _in_importation");
+PRINT_ERROR(" (%s:%d)\n", "model/mmodule.nit", 93);
+show_backtrace(1);
+}
+var34 = var36;
+RET_LABEL35:(void)0;
+}
+}
+{
+var37 = poset__POSetElement__greaters(var34);
+}
+var_ = var37;
+{
+var38 = ((val* (*)(val*))(var_->class->vft[COLOR_abstract_collection__Collection__iterator]))(var_) /* iterator on <var_:Collection[MModule]>*/;
+}
+var_39 = var38;
+for(;;) {
+{
+var40 = ((short int (*)(val*))(var_39->class->vft[COLOR_abstract_collection__Iterator__is_ok]))(var_39) /* is_ok on <var_39:Iterator[MModule]>*/;
+}
+if (var40){
+{
+var41 = ((val* (*)(val*))(var_39->class->vft[COLOR_abstract_collection__Iterator__item]))(var_39) /* item on <var_39:Iterator[MModule]>*/;
+}
+var_m = var41;
+{
+{ /* Inline model#MModule#intro_mclasses (var_m) on <var_m:MModule> */
+var44 = var_m->attrs[COLOR_model__MModule___intro_mclasses].val; /* _intro_mclasses on <var_m:MModule> */
+if (unlikely(var44 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _intro_mclasses");
+PRINT_ERROR(" (%s:%d)\n", "model/model.nit", 136);
+show_backtrace(1);
+}
+var42 = var44;
+RET_LABEL43:(void)0;
+}
+}
+var_45 = var42;
+{
+var46 = array__AbstractArrayRead__iterator(var_45);
+}
+var_47 = var46;
+for(;;) {
+{
+var48 = array__ArrayIterator__is_ok(var_47);
+}
+if (var48){
+{
+var49 = array__ArrayIterator__item(var_47);
+}
+var_mclass = var49;
+{
+((void (*)(val*, val*))(var_compiler->class->vft[COLOR_separate_compiler__SeparateCompiler__compile_class_to_c]))(var_compiler, var_mclass) /* compile_class_to_c on <var_compiler:SeparateCompiler>*/;
+}
+{
+array__ArrayIterator__next(var_47); /* Direct call array#ArrayIterator#next on <var_47:ArrayIterator[MClass]>*/
+}
+} else {
+goto BREAK_label;
+}
+}
+BREAK_label: (void)0;
+{
+{ /* Inline abstract_collection#Iterator#finish (var_47) on <var_47:ArrayIterator[MClass]> */
+RET_LABEL50:(void)0;
+}
+}
+{
+((void (*)(val*))(var_39->class->vft[COLOR_abstract_collection__Iterator__next]))(var_39) /* next on <var_39:Iterator[MModule]>*/;
+}
+} else {
+goto BREAK_label51;
+}
+}
+BREAK_label51: (void)0;
+{
+{ /* Inline abstract_collection#Iterator#finish (var_39) on <var_39:Iterator[MModule]> */
+RET_LABEL52:(void)0;
+}
+}
+{
+{ /* Inline mmodule#MModule#name (var_mainmodule) on <var_mainmodule:MModule> */
+var55 = var_mainmodule->attrs[COLOR_mmodule__MModule___name].val; /* _name on <var_mainmodule:MModule> */
+if (unlikely(var55 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _name");
+PRINT_ERROR(" (%s:%d)\n", "model/mmodule.nit", 78);
+show_backtrace(1);
+}
+var53 = var55;
+RET_LABEL54:(void)0;
+}
+}
+if (varonce56) {
+var57 = varonce56;
+} else {
+var58 = ".main";
+var59 = 5;
+var60 = string__NativeString__to_s_with_length(var58, var59);
+var57 = var60;
+varonce56 = var57;
+}
+var61 = NEW_array__Array(&type_array__Arraykernel__Object);
+{ /* var61 = array_instance Array[Object] */
+var62 = 2;
+var63 = NEW_array__NativeArray(var62, &type_array__NativeArraykernel__Object);
+((struct instance_array__NativeArray*)var63)->values[0] = (val*) var53;
+((struct instance_array__NativeArray*)var63)->values[1] = (val*) var57;
+{
+((void (*)(val*, val*, long))(var61->class->vft[COLOR_array__Array__with_native]))(var61, var63, var62) /* with_native on <var61:Array[Object]>*/;
+}
+}
+{
+var64 = ((val* (*)(val*))(var61->class->vft[COLOR_string__Object__to_s]))(var61) /* to_s on <var61:Array[Object]>*/;
+}
+{
+var65 = abstract_compiler__AbstractCompiler__new_file(var_compiler, var64);
+}
+{
+abstract_compiler__AbstractCompiler__compile_nitni_global_ref_functions(var_compiler); /* Direct call abstract_compiler#AbstractCompiler#compile_nitni_global_ref_functions on <var_compiler:SeparateCompiler>*/
+}
+{
+abstract_compiler__AbstractCompiler__compile_main_function(var_compiler); /* Direct call abstract_compiler#AbstractCompiler#compile_main_function on <var_compiler:SeparateCompiler>*/
+}
+{
+abstract_compiler__AbstractCompiler__compile_finalizer_function(var_compiler); /* Direct call abstract_compiler#AbstractCompiler#compile_finalizer_function on <var_compiler:SeparateCompiler>*/
+}
+{
+{ /* Inline mmodule#MModule#in_importation (var_mainmodule) on <var_mainmodule:MModule> */
+var68 = var_mainmodule->attrs[COLOR_mmodule__MModule___in_importation].val; /* _in_importation on <var_mainmodule:MModule> */
+if (unlikely(var68 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _in_importation");
+PRINT_ERROR(" (%s:%d)\n", "model/mmodule.nit", 93);
+show_backtrace(1);
+}
+var66 = var68;
+RET_LABEL67:(void)0;
+}
+}
+{
+var69 = poset__POSetElement__greaters(var66);
+}
+var_70 = var69;
+{
+var71 = ((val* (*)(val*))(var_70->class->vft[COLOR_abstract_collection__Collection__iterator]))(var_70) /* iterator on <var_70:Collection[MModule]>*/;
+}
+var_72 = var71;
+for(;;) {
+{
+var73 = ((short int (*)(val*))(var_72->class->vft[COLOR_abstract_collection__Iterator__is_ok]))(var_72) /* is_ok on <var_72:Iterator[MModule]>*/;
+}
+if (var73){
+{
+var74 = ((val* (*)(val*))(var_72->class->vft[COLOR_abstract_collection__Iterator__item]))(var_72) /* item on <var_72:Iterator[MModule]>*/;
+}
+var_m75 = var74;
+{
+{ /* Inline modelbuilder#ModelBuilder#toolcontext (self) on <self:ModelBuilder> */
+var78 = self->attrs[COLOR_modelbuilder__ModelBuilder___toolcontext].val; /* _toolcontext on <self:ModelBuilder> */
+if (unlikely(var78 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _toolcontext");
+PRINT_ERROR(" (%s:%d)\n", "modelbuilder.nit", 106);
+show_backtrace(1);
+}
+var76 = var78;
+RET_LABEL77:(void)0;
+}
+}
+if (varonce79) {
+var80 = varonce79;
+} else {
+var81 = "Generate C for module ";
+var82 = 22;
+var83 = string__NativeString__to_s_with_length(var81, var82);
+var80 = var83;
+varonce79 = var80;
+}
+var84 = NEW_array__Array(&type_array__Arraykernel__Object);
+{ /* var84 = array_instance Array[Object] */
+var85 = 2;
+var86 = NEW_array__NativeArray(var85, &type_array__NativeArraykernel__Object);
+((struct instance_array__NativeArray*)var86)->values[0] = (val*) var80;
+((struct instance_array__NativeArray*)var86)->values[1] = (val*) var_m75;
+{
+((void (*)(val*, val*, long))(var84->class->vft[COLOR_array__Array__with_native]))(var84, var86, var85) /* with_native on <var84:Array[Object]>*/;
+}
+}
+{
+var87 = ((val* (*)(val*))(var84->class->vft[COLOR_string__Object__to_s]))(var84) /* to_s on <var84:Array[Object]>*/;
+}
+var88 = 2;
+{
+toolcontext__ToolContext__info(var76, var87, var88); /* Direct call toolcontext#ToolContext#info on <var76:ToolContext>*/
+}
+{
+{ /* Inline mmodule#MModule#name (var_m75) on <var_m75:MModule> */
+var91 = var_m75->attrs[COLOR_mmodule__MModule___name].val; /* _name on <var_m75:MModule> */
+if (unlikely(var91 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _name");
+PRINT_ERROR(" (%s:%d)\n", "model/mmodule.nit", 78);
+show_backtrace(1);
+}
+var89 = var91;
+RET_LABEL90:(void)0;
+}
+}
+if (varonce92) {
+var93 = varonce92;
+} else {
+var94 = ".sep";
+var95 = 4;
+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 = 2;
+var99 = NEW_array__NativeArray(var98, &type_array__NativeArraykernel__Object);
+((struct instance_array__NativeArray*)var99)->values[0] = (val*) var89;
+((struct instance_array__NativeArray*)var99)->values[1] = (val*) var93;
+{
+((void (*)(val*, val*, long))(var97->class->vft[COLOR_array__Array__with_native]))(var97, var99, var98) /* with_native on <var97:Array[Object]>*/;
+}
+}
+{
+var100 = ((val* (*)(val*))(var97->class->vft[COLOR_string__Object__to_s]))(var97) /* to_s on <var97:Array[Object]>*/;
+}
+{
+var101 = abstract_compiler__AbstractCompiler__new_file(var_compiler, var100);
+}
+{
+separate_compiler__SeparateCompiler__compile_module_to_c(var_compiler, var_m75); /* Direct call separate_compiler#SeparateCompiler#compile_module_to_c on <var_compiler:SeparateCompiler>*/
+}
+{
+((void (*)(val*))(var_72->class->vft[COLOR_abstract_collection__Iterator__next]))(var_72) /* next on <var_72:Iterator[MModule]>*/;
+}
+} else {
+goto BREAK_label102;
+}
+}
+BREAK_label102: (void)0;
+{
+{ /* Inline abstract_collection#Iterator#finish (var_72) on <var_72:Iterator[MModule]> */
+RET_LABEL103:(void)0;
+}
+}
+{
+{ /* Inline modelbuilder#ModelBuilder#toolcontext (self) on <self:ModelBuilder> */
+var106 = self->attrs[COLOR_modelbuilder__ModelBuilder___toolcontext].val; /* _toolcontext on <self:ModelBuilder> */
+if (unlikely(var106 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _toolcontext");
+PRINT_ERROR(" (%s:%d)\n", "modelbuilder.nit", 106);
+show_backtrace(1);
+}
+var104 = var106;
+RET_LABEL105:(void)0;
+}
+}
+if (varonce107) {
+var108 = varonce107;
+} else {
+var109 = "Type coloring";
+var110 = 13;
+var111 = string__NativeString__to_s_with_length(var109, var110);
+var108 = var111;
+varonce107 = var108;
+}
+var112 = 2;
+{
+toolcontext__ToolContext__info(var104, var108, var112); /* Direct call toolcontext#ToolContext#info on <var104:ToolContext>*/
+}
+{
+{ /* Inline mmodule#MModule#name (var_mainmodule) on <var_mainmodule:MModule> */
+var115 = var_mainmodule->attrs[COLOR_mmodule__MModule___name].val; /* _name on <var_mainmodule:MModule> */
+if (unlikely(var115 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _name");
+PRINT_ERROR(" (%s:%d)\n", "model/mmodule.nit", 78);
+show_backtrace(1);
+}
+var113 = var115;
+RET_LABEL114:(void)0;
+}
+}
+if (varonce116) {
+var117 = varonce116;
+} else {
+var118 = ".types";
+var119 = 6;
+var120 = string__NativeString__to_s_with_length(var118, var119);
+var117 = var120;
+varonce116 = var117;
+}
+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*) var113;
+((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 <var121:Array[Object]>*/;
+}
+}
+{
+var124 = ((val* (*)(val*))(var121->class->vft[COLOR_string__Object__to_s]))(var121) /* to_s on <var121:Array[Object]>*/;
+}
+{
+var125 = abstract_compiler__AbstractCompiler__new_file(var_compiler, var124);
+}
+{
+var126 = separate_compiler__SeparateCompiler__do_type_coloring(var_compiler);
+}
+var_mtypes = var126;
+var_127 = var_mtypes;
+{
+var128 = poset__POSet__iterator(var_127);
+}
+var_129 = var128;
+for(;;) {
+{
+var130 = ((short int (*)(val*))(var_129->class->vft[COLOR_abstract_collection__Iterator__is_ok]))(var_129) /* is_ok on <var_129:Iterator[MType]>*/;
+}
+if (var130){
+{
+var131 = ((val* (*)(val*))(var_129->class->vft[COLOR_abstract_collection__Iterator__item]))(var_129) /* item on <var_129:Iterator[MType]>*/;
+}
+var_t = var131;
+{
+separate_compiler__SeparateCompiler__compile_type_to_c(var_compiler, var_t); /* Direct call separate_compiler#SeparateCompiler#compile_type_to_c on <var_compiler:SeparateCompiler>*/
+}
+{
+((void (*)(val*))(var_129->class->vft[COLOR_abstract_collection__Iterator__next]))(var_129) /* next on <var_129:Iterator[MType]>*/;
+}
+} else {
+goto BREAK_label132;
+}
+}
+BREAK_label132: (void)0;
+{
+{ /* Inline abstract_collection#Iterator#finish (var_129) on <var_129:Iterator[MType]> */
+RET_LABEL133:(void)0;
+}
+}
+{
+{ /* Inline separate_compiler#SeparateCompiler#undead_types (var_compiler) on <var_compiler:SeparateCompiler> */
+var136 = var_compiler->attrs[COLOR_separate_compiler__SeparateCompiler___undead_types].val; /* _undead_types on <var_compiler:SeparateCompiler> */
+if (unlikely(var136 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _undead_types");
+PRINT_ERROR(" (%s:%d)\n", "compiler/separate_compiler.nit", 156);
+show_backtrace(1);
+}
+var134 = var136;
+RET_LABEL135:(void)0;
+}
+}
+var_137 = var134;
+{
+var138 = ((val* (*)(val*))(var_137->class->vft[COLOR_abstract_collection__Collection__iterator]))(var_137) /* iterator on <var_137:Set[MType]>*/;
+}
+var_139 = var138;
+for(;;) {
+{
+var140 = ((short int (*)(val*))(var_139->class->vft[COLOR_abstract_collection__Iterator__is_ok]))(var_139) /* is_ok on <var_139:Iterator[MType]>*/;
+}
+if (var140){
+{
+var141 = ((val* (*)(val*))(var_139->class->vft[COLOR_abstract_collection__Iterator__item]))(var_139) /* item on <var_139:Iterator[MType]>*/;
+}
+var_t142 = var141;
+{
+var143 = poset__POSet__has(var_mtypes, var_t142);
+}
+if (var143){
+goto BREAK_label144;
+} else {
+}
+{
+separate_compiler__SeparateCompiler__compile_type_to_c(var_compiler, var_t142); /* Direct call separate_compiler#SeparateCompiler#compile_type_to_c on <var_compiler:SeparateCompiler>*/
+}
+BREAK_label144: (void)0;
+{
+((void (*)(val*))(var_139->class->vft[COLOR_abstract_collection__Iterator__next]))(var_139) /* next on <var_139:Iterator[MType]>*/;
+}
+} else {
+goto BREAK_label145;
+}
+}
+BREAK_label145: (void)0;
+{
+{ /* Inline abstract_collection#Iterator#finish (var_139) on <var_139:Iterator[MType]> */
+RET_LABEL146:(void)0;
+}
+}
+{
+separate_compiler__SeparateCompiler__display_stats(var_compiler); /* Direct call separate_compiler#SeparateCompiler#display_stats on <var_compiler:SeparateCompiler>*/
+}
+{
+{ /* Inline time#Object#get_time (self) on <self:ModelBuilder> */
+var149 = kernel_Any_Any_get_time_0(self);
+var147 = var149;
+goto RET_LABEL148;
+RET_LABEL148:(void)0;
+}
+}
+var_time1 = var147;
+{
+{ /* Inline modelbuilder#ModelBuilder#toolcontext (self) on <self:ModelBuilder> */
+var152 = self->attrs[COLOR_modelbuilder__ModelBuilder___toolcontext].val; /* _toolcontext on <self:ModelBuilder> */
+if (unlikely(var152 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _toolcontext");
+PRINT_ERROR(" (%s:%d)\n", "modelbuilder.nit", 106);
+show_backtrace(1);
+}
+var150 = var152;
+RET_LABEL151:(void)0;
+}
+}
+if (varonce153) {
+var154 = varonce153;
+} else {
+var155 = "*** END GENERATING C: ";
+var156 = 22;
+var157 = string__NativeString__to_s_with_length(var155, var156);
+var154 = var157;
+varonce153 = var154;
+}
+{
+{ /* Inline kernel#Int#- (var_time1,var_time0) on <var_time1:Int> */
+/* Covariant cast for argument 0 (i) <var_time0:Int> isa OTHER */
+/* <var_time0:Int> isa OTHER */
+var160 = 1; /* easy <var_time0:Int> isa OTHER*/
+if (unlikely(!var160)) {
+var_class_name = type_kernel__Int.name;
+PRINT_ERROR("Runtime error: Cast failed. Expected `%s`, got `%s`", "OTHER", var_class_name);
+PRINT_ERROR(" (%s:%d)\n", "../lib/standard/kernel.nit", 377);
+show_backtrace(1);
+}
+var161 = var_time1 - var_time0;
+var158 = var161;
+goto RET_LABEL159;
+RET_LABEL159:(void)0;
+}
+}
+if (varonce162) {
+var163 = varonce162;
+} else {
+var164 = " ***";
+var165 = 4;
+var166 = string__NativeString__to_s_with_length(var164, var165);
+var163 = var166;
+varonce162 = var163;
+}
+var167 = NEW_array__Array(&type_array__Arraykernel__Object);
+{ /* var167 = array_instance Array[Object] */
+var168 = 3;
+var169 = NEW_array__NativeArray(var168, &type_array__NativeArraykernel__Object);
+((struct instance_array__NativeArray*)var169)->values[0] = (val*) var154;
+var170 = BOX_kernel__Int(var158); /* autobox from Int to Object */
+((struct instance_array__NativeArray*)var169)->values[1] = (val*) var170;
+((struct instance_array__NativeArray*)var169)->values[2] = (val*) var163;
+{
+((void (*)(val*, val*, long))(var167->class->vft[COLOR_array__Array__with_native]))(var167, var169, var168) /* with_native on <var167:Array[Object]>*/;
+}
+}
+{
+var171 = ((val* (*)(val*))(var167->class->vft[COLOR_string__Object__to_s]))(var167) /* to_s on <var167:Array[Object]>*/;
+}
+var172 = 2;
+{
+toolcontext__ToolContext__info(var150, var171, var172); /* Direct call toolcontext#ToolContext#info on <var150:ToolContext>*/
+}
+{
+abstract_compiler__ModelBuilder__write_and_make(self, var_compiler); /* Direct call abstract_compiler#ModelBuilder#write_and_make on <self:ModelBuilder>*/
+}
+RET_LABEL:;
+}
+/* method separate_compiler#ModelBuilder#run_separate_compiler for (self: Object, MModule, nullable RapidTypeAnalysis) */
+void VIRTUAL_separate_compiler__ModelBuilder__run_separate_compiler(val* self, val* p0, val* p1) {
+separate_compiler__ModelBuilder__run_separate_compiler(self, p0, p1); /* Direct call separate_compiler#ModelBuilder#run_separate_compiler on <self:Object(ModelBuilder)>*/
+RET_LABEL:;
+}
+/* method separate_compiler#ModelBuilder#nb_invok_by_tables for (self: ModelBuilder): Int */
+long separate_compiler__ModelBuilder__nb_invok_by_tables(val* self) {
+long var /* : Int */;
+long var1 /* : Int */;
+var1 = self->attrs[COLOR_separate_compiler__ModelBuilder___nb_invok_by_tables].l; /* _nb_invok_by_tables on <self:ModelBuilder> */
+var = var1;
+RET_LABEL:;
+return var;
+}
+/* method separate_compiler#ModelBuilder#nb_invok_by_tables for (self: Object): Int */
+long VIRTUAL_separate_compiler__ModelBuilder__nb_invok_by_tables(val* self) {
+long var /* : Int */;
+long var1 /* : Int */;
+long var3 /* : Int */;
+{ /* Inline separate_compiler#ModelBuilder#nb_invok_by_tables (self) on <self:Object(ModelBuilder)> */
+var3 = self->attrs[COLOR_separate_compiler__ModelBuilder___nb_invok_by_tables].l; /* _nb_invok_by_tables on <self:Object(ModelBuilder)> */
+var1 = var3;
+RET_LABEL2:(void)0;
+}
+var = var1;
+RET_LABEL:;
+return var;
+}
+/* method separate_compiler#ModelBuilder#nb_invok_by_tables= for (self: ModelBuilder, Int) */
+void separate_compiler__ModelBuilder__nb_invok_by_tables_61d(val* self, long p0) {
+self->attrs[COLOR_separate_compiler__ModelBuilder___nb_invok_by_tables].l = p0; /* _nb_invok_by_tables on <self:ModelBuilder> */
+RET_LABEL:;
+}
+/* method separate_compiler#ModelBuilder#nb_invok_by_tables= for (self: Object, Int) */
+void VIRTUAL_separate_compiler__ModelBuilder__nb_invok_by_tables_61d(val* self, long p0) {
+{ /* Inline separate_compiler#ModelBuilder#nb_invok_by_tables= (self,p0) on <self:Object(ModelBuilder)> */
+self->attrs[COLOR_separate_compiler__ModelBuilder___nb_invok_by_tables].l = p0; /* _nb_invok_by_tables on <self:Object(ModelBuilder)> */
+RET_LABEL1:(void)0;
+}
+RET_LABEL:;
+}
+/* method separate_compiler#ModelBuilder#nb_invok_by_direct for (self: ModelBuilder): Int */
+long separate_compiler__ModelBuilder__nb_invok_by_direct(val* self) {
+long var /* : Int */;
+long var1 /* : Int */;
+var1 = self->attrs[COLOR_separate_compiler__ModelBuilder___nb_invok_by_direct].l; /* _nb_invok_by_direct on <self:ModelBuilder> */
+var = var1;
+RET_LABEL:;
+return var;
+}
+/* method separate_compiler#ModelBuilder#nb_invok_by_direct for (self: Object): Int */
+long VIRTUAL_separate_compiler__ModelBuilder__nb_invok_by_direct(val* self) {
+long var /* : Int */;
+long var1 /* : Int */;
+long var3 /* : Int */;
+{ /* Inline separate_compiler#ModelBuilder#nb_invok_by_direct (self) on <self:Object(ModelBuilder)> */
+var3 = self->attrs[COLOR_separate_compiler__ModelBuilder___nb_invok_by_direct].l; /* _nb_invok_by_direct on <self:Object(ModelBuilder)> */
+var1 = var3;
+RET_LABEL2:(void)0;
+}
+var = var1;
+RET_LABEL:;
+return var;
+}
+/* method separate_compiler#ModelBuilder#nb_invok_by_direct= for (self: ModelBuilder, Int) */
+void separate_compiler__ModelBuilder__nb_invok_by_direct_61d(val* self, long p0) {
+self->attrs[COLOR_separate_compiler__ModelBuilder___nb_invok_by_direct].l = p0; /* _nb_invok_by_direct on <self:ModelBuilder> */
+RET_LABEL:;
+}
+/* method separate_compiler#ModelBuilder#nb_invok_by_direct= for (self: Object, Int) */
+void VIRTUAL_separate_compiler__ModelBuilder__nb_invok_by_direct_61d(val* self, long p0) {
+{ /* Inline separate_compiler#ModelBuilder#nb_invok_by_direct= (self,p0) on <self:Object(ModelBuilder)> */
+self->attrs[COLOR_separate_compiler__ModelBuilder___nb_invok_by_direct].l = p0; /* _nb_invok_by_direct on <self:Object(ModelBuilder)> */
+RET_LABEL1:(void)0;
+}
+RET_LABEL:;
+}
+/* method separate_compiler#ModelBuilder#nb_invok_by_inline for (self: ModelBuilder): Int */
+long separate_compiler__ModelBuilder__nb_invok_by_inline(val* self) {
+long var /* : Int */;
+long var1 /* : Int */;
+var1 = self->attrs[COLOR_separate_compiler__ModelBuilder___nb_invok_by_inline].l; /* _nb_invok_by_inline on <self:ModelBuilder> */
+var = var1;
+RET_LABEL:;
+return var;
+}
+/* method separate_compiler#ModelBuilder#nb_invok_by_inline for (self: Object): Int */
+long VIRTUAL_separate_compiler__ModelBuilder__nb_invok_by_inline(val* self) {
+long var /* : Int */;
+long var1 /* : Int */;
+long var3 /* : Int */;
+{ /* Inline separate_compiler#ModelBuilder#nb_invok_by_inline (self) on <self:Object(ModelBuilder)> */
+var3 = self->attrs[COLOR_separate_compiler__ModelBuilder___nb_invok_by_inline].l; /* _nb_invok_by_inline on <self:Object(ModelBuilder)> */
+var1 = var3;
+RET_LABEL2:(void)0;
+}
+var = var1;
+RET_LABEL:;
+return var;
+}
+/* method separate_compiler#ModelBuilder#nb_invok_by_inline= for (self: ModelBuilder, Int) */
+void separate_compiler__ModelBuilder__nb_invok_by_inline_61d(val* self, long p0) {
+self->attrs[COLOR_separate_compiler__ModelBuilder___nb_invok_by_inline].l = p0; /* _nb_invok_by_inline on <self:ModelBuilder> */
+RET_LABEL:;
+}
+/* method separate_compiler#ModelBuilder#nb_invok_by_inline= for (self: Object, Int) */
+void VIRTUAL_separate_compiler__ModelBuilder__nb_invok_by_inline_61d(val* self, long p0) {
+{ /* Inline separate_compiler#ModelBuilder#nb_invok_by_inline= (self,p0) on <self:Object(ModelBuilder)> */
+self->attrs[COLOR_separate_compiler__ModelBuilder___nb_invok_by_inline].l = p0; /* _nb_invok_by_inline on <self:Object(ModelBuilder)> */
+RET_LABEL1:(void)0;
+}
+RET_LABEL:;
+}
+/* method separate_compiler#SeparateCompiler#runtime_type_analysis for (self: SeparateCompiler): nullable RapidTypeAnalysis */
+val* separate_compiler__SeparateCompiler__runtime_type_analysis(val* self) {
+val* var /* : nullable RapidTypeAnalysis */;
+val* var1 /* : nullable RapidTypeAnalysis */;
+var1 = self->attrs[COLOR_separate_compiler__SeparateCompiler___runtime_type_analysis].val; /* _runtime_type_analysis on <self:SeparateCompiler> */
+var = var1;
+RET_LABEL:;
+return var;
+}
+/* method separate_compiler#SeparateCompiler#runtime_type_analysis for (self: Object): nullable RapidTypeAnalysis */
+val* VIRTUAL_separate_compiler__SeparateCompiler__runtime_type_analysis(val* self) {
+val* var /* : nullable RapidTypeAnalysis */;
+val* var1 /* : nullable RapidTypeAnalysis */;
+val* var3 /* : nullable RapidTypeAnalysis */;
+{ /* Inline separate_compiler#SeparateCompiler#runtime_type_analysis (self) on <self:Object(SeparateCompiler)> */
+var3 = self->attrs[COLOR_separate_compiler__SeparateCompiler___runtime_type_analysis].val; /* _runtime_type_analysis on <self:Object(SeparateCompiler)> */
+var1 = var3;
+RET_LABEL2:(void)0;
+}
+var = var1;
+RET_LABEL:;
+return var;
+}
+/* method separate_compiler#SeparateCompiler#runtime_type_analysis= for (self: SeparateCompiler, nullable RapidTypeAnalysis) */
+void separate_compiler__SeparateCompiler__runtime_type_analysis_61d(val* self, val* p0) {
+self->attrs[COLOR_separate_compiler__SeparateCompiler___runtime_type_analysis].val = p0; /* _runtime_type_analysis on <self:SeparateCompiler> */
+RET_LABEL:;
+}
+/* method separate_compiler#SeparateCompiler#runtime_type_analysis= for (self: Object, nullable RapidTypeAnalysis) */
+void VIRTUAL_separate_compiler__SeparateCompiler__runtime_type_analysis_61d(val* self, val* p0) {
+{ /* Inline separate_compiler#SeparateCompiler#runtime_type_analysis= (self,p0) on <self:Object(SeparateCompiler)> */
+self->attrs[COLOR_separate_compiler__SeparateCompiler___runtime_type_analysis].val = p0; /* _runtime_type_analysis on <self:Object(SeparateCompiler)> */
+RET_LABEL1:(void)0;
+}
+RET_LABEL:;
+}
+/* method separate_compiler#SeparateCompiler#undead_types for (self: SeparateCompiler): Set[MType] */
+val* separate_compiler__SeparateCompiler__undead_types(val* self) {
+val* var /* : Set[MType] */;
+val* var1 /* : Set[MType] */;
+var1 = self->attrs[COLOR_separate_compiler__SeparateCompiler___undead_types].val; /* _undead_types on <self:SeparateCompiler> */
+if (unlikely(var1 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _undead_types");
+PRINT_ERROR(" (%s:%d)\n", "compiler/separate_compiler.nit", 156);
+show_backtrace(1);
+}
+var = var1;
+RET_LABEL:;
+return var;
+}
+/* method separate_compiler#SeparateCompiler#undead_types for (self: Object): Set[MType] */
+val* VIRTUAL_separate_compiler__SeparateCompiler__undead_types(val* self) {
+val* var /* : Set[MType] */;
+val* var1 /* : Set[MType] */;
+val* var3 /* : Set[MType] */;
+{ /* Inline separate_compiler#SeparateCompiler#undead_types (self) on <self:Object(SeparateCompiler)> */
+var3 = self->attrs[COLOR_separate_compiler__SeparateCompiler___undead_types].val; /* _undead_types on <self:Object(SeparateCompiler)> */
+if (unlikely(var3 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _undead_types");
+PRINT_ERROR(" (%s:%d)\n", "compiler/separate_compiler.nit", 156);
+show_backtrace(1);
+}
+var1 = var3;
+RET_LABEL2:(void)0;
+}
+var = var1;
+RET_LABEL:;
+return var;
+}
+/* method separate_compiler#SeparateCompiler#live_unresolved_types for (self: SeparateCompiler): Map[MClassDef, Set[MType]] */
+val* separate_compiler__SeparateCompiler__live_unresolved_types(val* self) {
+val* var /* : Map[MClassDef, Set[MType]] */;
+val* var1 /* : Map[MClassDef, Set[MType]] */;
+var1 = self->attrs[COLOR_separate_compiler__SeparateCompiler___live_unresolved_types].val; /* _live_unresolved_types on <self:SeparateCompiler> */
+if (unlikely(var1 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _live_unresolved_types");
+PRINT_ERROR(" (%s:%d)\n", "compiler/separate_compiler.nit", 157);
+show_backtrace(1);
+}
+var = var1;
+RET_LABEL:;
+return var;
+}
+/* method separate_compiler#SeparateCompiler#live_unresolved_types for (self: Object): Map[MClassDef, Set[MType]] */
+val* VIRTUAL_separate_compiler__SeparateCompiler__live_unresolved_types(val* self) {
+val* var /* : Map[MClassDef, Set[MType]] */;
+val* var1 /* : Map[MClassDef, Set[MType]] */;
+val* var3 /* : Map[MClassDef, Set[MType]] */;
+{ /* Inline separate_compiler#SeparateCompiler#live_unresolved_types (self) on <self:Object(SeparateCompiler)> */
+var3 = self->attrs[COLOR_separate_compiler__SeparateCompiler___live_unresolved_types].val; /* _live_unresolved_types on <self:Object(SeparateCompiler)> */
+if (unlikely(var3 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _live_unresolved_types");
+PRINT_ERROR(" (%s:%d)\n", "compiler/separate_compiler.nit", 157);
+show_backtrace(1);
+}
+var1 = var3;
+RET_LABEL2:(void)0;
+}
+var = var1;
+RET_LABEL:;
+return var;
+}
+/* method separate_compiler#SeparateCompiler#type_ids for (self: SeparateCompiler): Map[MType, Int] */
+val* separate_compiler__SeparateCompiler__type_ids(val* self) {
+val* var /* : Map[MType, Int] */;
+val* var1 /* : Map[MType, Int] */;
+var1 = self->attrs[COLOR_separate_compiler__SeparateCompiler___type_ids].val; /* _type_ids on <self:SeparateCompiler> */
+if (unlikely(var1 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _type_ids");
+PRINT_ERROR(" (%s:%d)\n", "compiler/separate_compiler.nit", 159);
+show_backtrace(1);
+}
+var = var1;
+RET_LABEL:;
+return var;
+}
+/* method separate_compiler#SeparateCompiler#type_ids for (self: Object): Map[MType, Int] */
+val* VIRTUAL_separate_compiler__SeparateCompiler__type_ids(val* self) {
+val* var /* : Map[MType, Int] */;
+val* var1 /* : Map[MType, Int] */;
+val* var3 /* : Map[MType, Int] */;
+{ /* Inline separate_compiler#SeparateCompiler#type_ids (self) on <self:Object(SeparateCompiler)> */
+var3 = self->attrs[COLOR_separate_compiler__SeparateCompiler___type_ids].val; /* _type_ids on <self:Object(SeparateCompiler)> */
+if (unlikely(var3 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _type_ids");
+PRINT_ERROR(" (%s:%d)\n", "compiler/separate_compiler.nit", 159);
+show_backtrace(1);
+}
+var1 = var3;
+RET_LABEL2:(void)0;
+}
+var = var1;
+RET_LABEL:;
+return var;
+}
+/* method separate_compiler#SeparateCompiler#type_ids= for (self: SeparateCompiler, Map[MType, Int]) */
+void separate_compiler__SeparateCompiler__type_ids_61d(val* self, val* p0) {
+self->attrs[COLOR_separate_compiler__SeparateCompiler___type_ids].val = p0; /* _type_ids on <self:SeparateCompiler> */
+RET_LABEL:;
+}
+/* method separate_compiler#SeparateCompiler#type_ids= for (self: Object, Map[MType, Int]) */
+void VIRTUAL_separate_compiler__SeparateCompiler__type_ids_61d(val* self, val* p0) {
+{ /* Inline separate_compiler#SeparateCompiler#type_ids= (self,p0) on <self:Object(SeparateCompiler)> */
+self->attrs[COLOR_separate_compiler__SeparateCompiler___type_ids].val = p0; /* _type_ids on <self:Object(SeparateCompiler)> */
+RET_LABEL1:(void)0;
+}
+RET_LABEL:;
+}
+/* method separate_compiler#SeparateCompiler#type_colors for (self: SeparateCompiler): Map[MType, Int] */
+val* separate_compiler__SeparateCompiler__type_colors(val* self) {
+val* var /* : Map[MType, Int] */;
+val* var1 /* : Map[MType, Int] */;
+var1 = self->attrs[COLOR_separate_compiler__SeparateCompiler___type_colors].val; /* _type_colors on <self:SeparateCompiler> */
+if (unlikely(var1 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _type_colors");
+PRINT_ERROR(" (%s:%d)\n", "compiler/separate_compiler.nit", 160);
+show_backtrace(1);
+}
+var = var1;
+RET_LABEL:;
+return var;
+}
+/* method separate_compiler#SeparateCompiler#type_colors for (self: Object): Map[MType, Int] */
+val* VIRTUAL_separate_compiler__SeparateCompiler__type_colors(val* self) {
+val* var /* : Map[MType, Int] */;
+val* var1 /* : Map[MType, Int] */;
+val* var3 /* : Map[MType, Int] */;
+{ /* Inline separate_compiler#SeparateCompiler#type_colors (self) on <self:Object(SeparateCompiler)> */
+var3 = self->attrs[COLOR_separate_compiler__SeparateCompiler___type_colors].val; /* _type_colors on <self:Object(SeparateCompiler)> */
+if (unlikely(var3 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _type_colors");
+PRINT_ERROR(" (%s:%d)\n", "compiler/separate_compiler.nit", 160);
+show_backtrace(1);
+}
+var1 = var3;
+RET_LABEL2:(void)0;
+}
+var = var1;
+RET_LABEL:;
+return var;
+}
+/* method separate_compiler#SeparateCompiler#type_colors= for (self: SeparateCompiler, Map[MType, Int]) */
+void separate_compiler__SeparateCompiler__type_colors_61d(val* self, val* p0) {
+self->attrs[COLOR_separate_compiler__SeparateCompiler___type_colors].val = p0; /* _type_colors on <self:SeparateCompiler> */
+RET_LABEL:;
+}
+/* method separate_compiler#SeparateCompiler#type_colors= for (self: Object, Map[MType, Int]) */
+void VIRTUAL_separate_compiler__SeparateCompiler__type_colors_61d(val* self, val* p0) {
+{ /* Inline separate_compiler#SeparateCompiler#type_colors= (self,p0) on <self:Object(SeparateCompiler)> */
+self->attrs[COLOR_separate_compiler__SeparateCompiler___type_colors].val = p0; /* _type_colors on <self:Object(SeparateCompiler)> */
+RET_LABEL1:(void)0;
+}
+RET_LABEL:;
+}
+/* method separate_compiler#SeparateCompiler#opentype_colors for (self: SeparateCompiler): Map[MType, Int] */
+val* separate_compiler__SeparateCompiler__opentype_colors(val* self) {
+val* var /* : Map[MType, Int] */;
+val* var1 /* : Map[MType, Int] */;
+var1 = self->attrs[COLOR_separate_compiler__SeparateCompiler___opentype_colors].val; /* _opentype_colors on <self:SeparateCompiler> */
+if (unlikely(var1 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _opentype_colors");
+PRINT_ERROR(" (%s:%d)\n", "compiler/separate_compiler.nit", 161);
+show_backtrace(1);
+}
+var = var1;
+RET_LABEL:;
+return var;
+}
+/* method separate_compiler#SeparateCompiler#opentype_colors for (self: Object): Map[MType, Int] */
+val* VIRTUAL_separate_compiler__SeparateCompiler__opentype_colors(val* self) {
+val* var /* : Map[MType, Int] */;
+val* var1 /* : Map[MType, Int] */;
+val* var3 /* : Map[MType, Int] */;
+{ /* Inline separate_compiler#SeparateCompiler#opentype_colors (self) on <self:Object(SeparateCompiler)> */
+var3 = self->attrs[COLOR_separate_compiler__SeparateCompiler___opentype_colors].val; /* _opentype_colors on <self:Object(SeparateCompiler)> */
+if (unlikely(var3 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _opentype_colors");
+PRINT_ERROR(" (%s:%d)\n", "compiler/separate_compiler.nit", 161);
+show_backtrace(1);
+}
+var1 = var3;
+RET_LABEL2:(void)0;
+}
+var = var1;
+RET_LABEL:;
+return var;
+}
+/* method separate_compiler#SeparateCompiler#opentype_colors= for (self: SeparateCompiler, Map[MType, Int]) */
+void separate_compiler__SeparateCompiler__opentype_colors_61d(val* self, val* p0) {
+self->attrs[COLOR_separate_compiler__SeparateCompiler___opentype_colors].val = p0; /* _opentype_colors on <self:SeparateCompiler> */
+RET_LABEL:;
+}
+/* method separate_compiler#SeparateCompiler#opentype_colors= for (self: Object, Map[MType, Int]) */
+void VIRTUAL_separate_compiler__SeparateCompiler__opentype_colors_61d(val* self, val* p0) {
+{ /* Inline separate_compiler#SeparateCompiler#opentype_colors= (self,p0) on <self:Object(SeparateCompiler)> */
+self->attrs[COLOR_separate_compiler__SeparateCompiler___opentype_colors].val = p0; /* _opentype_colors on <self:Object(SeparateCompiler)> */
+RET_LABEL1:(void)0;
+}
+RET_LABEL:;
+}
+/* method separate_compiler#SeparateCompiler#method_colors for (self: SeparateCompiler): Map[PropertyLayoutElement, Int] */
+val* separate_compiler__SeparateCompiler__method_colors(val* self) {
+val* var /* : Map[PropertyLayoutElement, Int] */;
+val* var1 /* : Map[PropertyLayoutElement, Int] */;
+var1 = self->attrs[COLOR_separate_compiler__SeparateCompiler___method_colors].val; /* _method_colors on <self:SeparateCompiler> */
+if (unlikely(var1 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _method_colors");
+PRINT_ERROR(" (%s:%d)\n", "compiler/separate_compiler.nit", 162);
+show_backtrace(1);
+}
+var = var1;
+RET_LABEL:;
+return var;
+}
+/* method separate_compiler#SeparateCompiler#method_colors for (self: Object): Map[PropertyLayoutElement, Int] */
+val* VIRTUAL_separate_compiler__SeparateCompiler__method_colors(val* self) {
+val* var /* : Map[PropertyLayoutElement, Int] */;
+val* var1 /* : Map[PropertyLayoutElement, Int] */;
+val* var3 /* : Map[PropertyLayoutElement, Int] */;
+{ /* Inline separate_compiler#SeparateCompiler#method_colors (self) on <self:Object(SeparateCompiler)> */
+var3 = self->attrs[COLOR_separate_compiler__SeparateCompiler___method_colors].val; /* _method_colors on <self:Object(SeparateCompiler)> */
+if (unlikely(var3 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _method_colors");
+PRINT_ERROR(" (%s:%d)\n", "compiler/separate_compiler.nit", 162);
+show_backtrace(1);
+}
+var1 = var3;
+RET_LABEL2:(void)0;
+}
+var = var1;
+RET_LABEL:;
+return var;
+}
+/* method separate_compiler#SeparateCompiler#method_colors= for (self: SeparateCompiler, Map[PropertyLayoutElement, Int]) */
+void separate_compiler__SeparateCompiler__method_colors_61d(val* self, val* p0) {
+self->attrs[COLOR_separate_compiler__SeparateCompiler___method_colors].val = p0; /* _method_colors on <self:SeparateCompiler> */
+RET_LABEL:;
+}
+/* method separate_compiler#SeparateCompiler#method_colors= for (self: Object, Map[PropertyLayoutElement, Int]) */
+void VIRTUAL_separate_compiler__SeparateCompiler__method_colors_61d(val* self, val* p0) {
+{ /* Inline separate_compiler#SeparateCompiler#method_colors= (self,p0) on <self:Object(SeparateCompiler)> */
+self->attrs[COLOR_separate_compiler__SeparateCompiler___method_colors].val = p0; /* _method_colors on <self:Object(SeparateCompiler)> */
+RET_LABEL1:(void)0;
+}
+RET_LABEL:;
+}
+/* method separate_compiler#SeparateCompiler#attr_colors for (self: SeparateCompiler): Map[MAttribute, Int] */
+val* separate_compiler__SeparateCompiler__attr_colors(val* self) {
+val* var /* : Map[MAttribute, Int] */;
+val* var1 /* : Map[MAttribute, Int] */;
+var1 = self->attrs[COLOR_separate_compiler__SeparateCompiler___attr_colors].val; /* _attr_colors on <self:SeparateCompiler> */
+if (unlikely(var1 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _attr_colors");
+PRINT_ERROR(" (%s:%d)\n", "compiler/separate_compiler.nit", 163);
+show_backtrace(1);
+}
+var = var1;
+RET_LABEL:;
+return var;
+}
+/* method separate_compiler#SeparateCompiler#attr_colors for (self: Object): Map[MAttribute, Int] */
+val* VIRTUAL_separate_compiler__SeparateCompiler__attr_colors(val* self) {
+val* var /* : Map[MAttribute, Int] */;
+val* var1 /* : Map[MAttribute, Int] */;
+val* var3 /* : Map[MAttribute, Int] */;
+{ /* Inline separate_compiler#SeparateCompiler#attr_colors (self) on <self:Object(SeparateCompiler)> */
+var3 = self->attrs[COLOR_separate_compiler__SeparateCompiler___attr_colors].val; /* _attr_colors on <self:Object(SeparateCompiler)> */
+if (unlikely(var3 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _attr_colors");
+PRINT_ERROR(" (%s:%d)\n", "compiler/separate_compiler.nit", 163);
+show_backtrace(1);
+}
+var1 = var3;
+RET_LABEL2:(void)0;
+}
+var = var1;
+RET_LABEL:;
+return var;
+}
+/* method separate_compiler#SeparateCompiler#attr_colors= for (self: SeparateCompiler, Map[MAttribute, Int]) */
+void separate_compiler__SeparateCompiler__attr_colors_61d(val* self, val* p0) {
+self->attrs[COLOR_separate_compiler__SeparateCompiler___attr_colors].val = p0; /* _attr_colors on <self:SeparateCompiler> */
+RET_LABEL:;
+}
+/* method separate_compiler#SeparateCompiler#attr_colors= for (self: Object, Map[MAttribute, Int]) */
+void VIRTUAL_separate_compiler__SeparateCompiler__attr_colors_61d(val* self, val* p0) {
+{ /* Inline separate_compiler#SeparateCompiler#attr_colors= (self,p0) on <self:Object(SeparateCompiler)> */
+self->attrs[COLOR_separate_compiler__SeparateCompiler___attr_colors].val = p0; /* _attr_colors on <self:Object(SeparateCompiler)> */
+RET_LABEL1:(void)0;
+}
+RET_LABEL:;
+}
+/* method separate_compiler#SeparateCompiler#init for (self: SeparateCompiler, MModule, ModelBuilder, nullable RapidTypeAnalysis) */
+void separate_compiler__SeparateCompiler__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: nullable RapidTypeAnalysis */;
+static val* varonce;
+val* var /* : String */;
+char* var1 /* : NativeString */;
+long var2 /* : Int */;
+val* var3 /* : FlatString */;
+val* var4 /* : CodeFile */;
+val* var_file /* var file: CodeFile */;
+val* var5 /* : CodeWriter */;
+var_mainmodule = p0;
+var_mmbuilder = p1;
+var_runtime_type_analysis = p2;
+{
+abstract_compiler__AbstractCompiler__init(self, var_mainmodule, var_mmbuilder); /* Direct call abstract_compiler#AbstractCompiler#init on <self:SeparateCompiler>*/
+}
+if (varonce) {
+var = varonce;
+} else {
+var1 = "nit.common";
+var2 = 10;
+var3 = string__NativeString__to_s_with_length(var1, var2);
+var = var3;
+varonce = var;
+}
+{
+var4 = abstract_compiler__AbstractCompiler__new_file(self, var);
+}
+var_file = var4;
+var5 = NEW_abstract_compiler__CodeWriter(&type_abstract_compiler__CodeWriter);
+{
+abstract_compiler__CodeWriter__init(var5, var_file); /* Direct call abstract_compiler#CodeWriter#init on <var5:CodeWriter>*/
+}
+{
+{ /* Inline abstract_compiler#AbstractCompiler#header= (self,var5) on <self:SeparateCompiler> */
+self->attrs[COLOR_abstract_compiler__AbstractCompiler___header].val = var5; /* _header on <self:SeparateCompiler> */
+RET_LABEL6:(void)0;
+}
+}
+{
+{ /* Inline separate_compiler#SeparateCompiler#runtime_type_analysis= (self,var_runtime_type_analysis) on <self:SeparateCompiler> */
+self->attrs[COLOR_separate_compiler__SeparateCompiler___runtime_type_analysis].val = var_runtime_type_analysis; /* _runtime_type_analysis on <self:SeparateCompiler> */
+RET_LABEL7:(void)0;
+}
+}
+{
+separate_compiler__SeparateCompiler__compile_box_kinds(self); /* Direct call separate_compiler#SeparateCompiler#compile_box_kinds on <self:SeparateCompiler>*/
+}
+RET_LABEL:;
+}
+/* method separate_compiler#SeparateCompiler#init for (self: Object, MModule, ModelBuilder, nullable RapidTypeAnalysis) */
+void VIRTUAL_separate_compiler__SeparateCompiler__init(val* self, val* p0, val* p1, val* p2) {
+separate_compiler__SeparateCompiler__init(self, p0, p1, p2); /* Direct call separate_compiler#SeparateCompiler#init on <self:Object(SeparateCompiler)>*/
+RET_LABEL:;
+}
+/* method separate_compiler#SeparateCompiler#compile_header_structs for (self: SeparateCompiler) */
+void separate_compiler__SeparateCompiler__compile_header_structs(val* self) {
+val* var /* : CodeWriter */;
+val* var2 /* : CodeWriter */;
+static val* varonce;
+val* var3 /* : String */;
+char* var4 /* : NativeString */;
+long var5 /* : Int */;
+val* var6 /* : FlatString */;
+val* var7 /* : CodeWriter */;
+val* var9 /* : CodeWriter */;
+static val* varonce10;
+val* var11 /* : String */;
+char* var12 /* : NativeString */;
+long var13 /* : Int */;
+val* var14 /* : FlatString */;
+val* var15 /* : CodeWriter */;
+val* var17 /* : CodeWriter */;
+static val* varonce18;
+val* var19 /* : String */;
+char* var20 /* : NativeString */;
+long var21 /* : Int */;
+val* var22 /* : FlatString */;
+val* var23 /* : CodeWriter */;
+val* var25 /* : CodeWriter */;
+static val* varonce26;
+val* var27 /* : String */;
+char* var28 /* : NativeString */;
+long var29 /* : Int */;
+val* var30 /* : FlatString */;
+val* var31 /* : CodeWriter */;
+val* var33 /* : CodeWriter */;
+static val* varonce34;
+val* var35 /* : String */;
+char* var36 /* : NativeString */;
+long var37 /* : Int */;
+val* var38 /* : FlatString */;
+val* var39 /* : CodeWriter */;
+val* var41 /* : CodeWriter */;
+static val* varonce42;
+val* var43 /* : String */;
+char* var44 /* : NativeString */;
+long var45 /* : Int */;
+val* var46 /* : FlatString */;
+{
+{ /* Inline abstract_compiler#AbstractCompiler#header (self) on <self:SeparateCompiler> */
+var2 = self->attrs[COLOR_abstract_compiler__AbstractCompiler___header].val; /* _header on <self:SeparateCompiler> */
+if (unlikely(var2 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _header");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 506);
+show_backtrace(1);
+}
+var = var2;
+RET_LABEL1:(void)0;
+}
+}
+if (varonce) {
+var3 = varonce;
+} else {
+var4 = "typedef void(*nitmethod_t)(void); /* general C type representing a Nit method. */";
+var5 = 81;
+var6 = string__NativeString__to_s_with_length(var4, var5);
+var3 = var6;
+varonce = var3;
+}
+{
+abstract_compiler__CodeWriter__add_decl(var, var3); /* Direct call abstract_compiler#CodeWriter#add_decl on <var:CodeWriter>*/
+}
+{
+separate_compiler__SeparateCompiler__compile_header_attribute_structs(self); /* Direct call separate_compiler#SeparateCompiler#compile_header_attribute_structs on <self:SeparateCompiler>*/
+}
+{
+{ /* Inline abstract_compiler#AbstractCompiler#header (self) on <self:SeparateCompiler> */
+var9 = self->attrs[COLOR_abstract_compiler__AbstractCompiler___header].val; /* _header on <self:SeparateCompiler> */
+if (unlikely(var9 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _header");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 506);
+show_backtrace(1);
+}
+var7 = var9;
+RET_LABEL8:(void)0;
+}
+}
+if (varonce10) {
+var11 = varonce10;
+} else {
+var12 = "struct class { int box_kind; nitmethod_t vft[]; }; /* general C type representing a Nit class. */";
+var13 = 97;
+var14 = string__NativeString__to_s_with_length(var12, var13);
+var11 = var14;
+varonce10 = var11;
+}
+{
+abstract_compiler__CodeWriter__add_decl(var7, var11); /* Direct call abstract_compiler#CodeWriter#add_decl on <var7:CodeWriter>*/
+}
+{
+{ /* Inline abstract_compiler#AbstractCompiler#header (self) on <self:SeparateCompiler> */
+var17 = self->attrs[COLOR_abstract_compiler__AbstractCompiler___header].val; /* _header on <self:SeparateCompiler> */
+if (unlikely(var17 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _header");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 506);
+show_backtrace(1);
+}
+var15 = var17;
+RET_LABEL16:(void)0;
+}
+}
+if (varonce18) {
+var19 = varonce18;
+} else {
+var20 = "struct type { int id; const char *name; int color; short int is_nullable; const struct types *resolution_table; int table_size; int type_table[]; }; /* general C type representing a Nit type. */";
+var21 = 194;
+var22 = string__NativeString__to_s_with_length(var20, var21);
+var19 = var22;
+varonce18 = var19;
+}
+{
+abstract_compiler__CodeWriter__add_decl(var15, var19); /* Direct call abstract_compiler#CodeWriter#add_decl on <var15:CodeWriter>*/
+}
+{
+{ /* Inline abstract_compiler#AbstractCompiler#header (self) on <self:SeparateCompiler> */
+var25 = self->attrs[COLOR_abstract_compiler__AbstractCompiler___header].val; /* _header on <self:SeparateCompiler> */
+if (unlikely(var25 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _header");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 506);
+show_backtrace(1);
+}
+var23 = var25;
+RET_LABEL24:(void)0;
+}
+}
+if (varonce26) {
+var27 = varonce26;
+} else {
+var28 = "struct instance { const struct type *type; const struct class *class; nitattribute_t attrs[]; }; /* general C type representing a Nit instance. */";
+var29 = 146;
+var30 = string__NativeString__to_s_with_length(var28, var29);
+var27 = var30;
+varonce26 = var27;
+}
+{
+abstract_compiler__CodeWriter__add_decl(var23, var27); /* Direct call abstract_compiler#CodeWriter#add_decl on <var23:CodeWriter>*/
+}
+{
+{ /* Inline abstract_compiler#AbstractCompiler#header (self) on <self:SeparateCompiler> */
+var33 = self->attrs[COLOR_abstract_compiler__AbstractCompiler___header].val; /* _header on <self:SeparateCompiler> */
+if (unlikely(var33 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _header");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 506);
+show_backtrace(1);
+}
+var31 = var33;
+RET_LABEL32:(void)0;
+}
+}
+if (varonce34) {
+var35 = varonce34;
+} else {
+var36 = "struct types { int dummy; const struct type *types[]; }; /* a list types (used for vts, fts and unresolved lists). */";
+var37 = 117;
+var38 = string__NativeString__to_s_with_length(var36, var37);
+var35 = var38;
+varonce34 = var35;
+}
+{
+abstract_compiler__CodeWriter__add_decl(var31, var35); /* Direct call abstract_compiler#CodeWriter#add_decl on <var31:CodeWriter>*/
+}
+{
+{ /* Inline abstract_compiler#AbstractCompiler#header (self) on <self:SeparateCompiler> */
+var41 = self->attrs[COLOR_abstract_compiler__AbstractCompiler___header].val; /* _header on <self:SeparateCompiler> */
+if (unlikely(var41 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _header");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 506);
+show_backtrace(1);
+}
+var39 = var41;
+RET_LABEL40:(void)0;
+}
+}
+if (varonce42) {
+var43 = varonce42;
+} else {
+var44 = "typedef struct instance val; /* general C type representing a Nit instance. */";
+var45 = 78;
+var46 = string__NativeString__to_s_with_length(var44, var45);
+var43 = var46;
+varonce42 = var43;
+}
+{
+abstract_compiler__CodeWriter__add_decl(var39, var43); /* Direct call abstract_compiler#CodeWriter#add_decl on <var39:CodeWriter>*/
+}
+RET_LABEL:;
+}
+/* method separate_compiler#SeparateCompiler#compile_header_structs for (self: Object) */
+void VIRTUAL_separate_compiler__SeparateCompiler__compile_header_structs(val* self) {
+separate_compiler__SeparateCompiler__compile_header_structs(self); /* Direct call separate_compiler#SeparateCompiler#compile_header_structs on <self:Object(SeparateCompiler)>*/
+RET_LABEL:;
+}
+/* method separate_compiler#SeparateCompiler#compile_header_attribute_structs for (self: SeparateCompiler) */
+void separate_compiler__SeparateCompiler__compile_header_attribute_structs(val* self) {
+val* var /* : ModelBuilder */;
+val* var2 /* : ModelBuilder */;
+val* var3 /* : ToolContext */;
+val* var5 /* : ToolContext */;
+val* var6 /* : OptionBool */;
+val* var8 /* : OptionBool */;
+val* var9 /* : nullable Object */;
+val* var11 /* : nullable Object */;
+short int var12 /* : Bool */;
+val* var13 /* : CodeWriter */;
+val* var15 /* : CodeWriter */;
+static val* varonce;
+val* var16 /* : String */;
+char* var17 /* : NativeString */;
+long var18 /* : Int */;
+val* var19 /* : FlatString */;
+val* var20 /* : CodeWriter */;
+val* var22 /* : CodeWriter */;
+static val* varonce23;
+val* var24 /* : String */;
+char* var25 /* : NativeString */;
+long var26 /* : Int */;
+val* var27 /* : FlatString */;
+val* var28 /* : CodeWriter */;
+val* var30 /* : CodeWriter */;
+static val* varonce31;
+val* var32 /* : String */;
+char* var33 /* : NativeString */;
+long var34 /* : Int */;
+val* var35 /* : FlatString */;
+val* var36 /* : HashMap[MClass, Int] */;
+val* var38 /* : HashMap[MClass, Int] */;
+val* var_ /* var : HashMap[MClass, Int] */;
+val* var39 /* : HashMapIterator[Object, nullable Object] */;
+val* var_40 /* var : HashMapIterator[MClass, Int] */;
+short int var41 /* : Bool */;
+val* var42 /* : Object */;
+val* var_c /* var c: MClass */;
+val* var43 /* : nullable Object */;
+long var44 /* : Int */;
+long var_v /* var v: Int */;
+val* var45 /* : MClassType */;
+val* var47 /* : MClassType */;
+val* var_t /* var t: MClassType */;
+val* var48 /* : MClass */;
+val* var50 /* : MClass */;
+val* var51 /* : String */;
+val* var53 /* : String */;
+static val* varonce54;
+val* var55 /* : String */;
+char* var56 /* : NativeString */;
+long var57 /* : Int */;
+val* var58 /* : FlatString */;
+short int var59 /* : Bool */;
+short int var60 /* : Bool */;
+val* var61 /* : CodeWriter */;
+val* var63 /* : CodeWriter */;
+val* var64 /* : String */;
+static val* varonce65;
+val* var66 /* : String */;
+char* var67 /* : NativeString */;
+long var68 /* : Int */;
+val* var69 /* : FlatString */;
+val* var70 /* : String */;
+static val* varonce71;
+val* var72 /* : String */;
+char* var73 /* : NativeString */;
+long var74 /* : Int */;
+val* var75 /* : FlatString */;
+val* var76 /* : Array[Object] */;
+long var77 /* : Int */;
+val* var78 /* : NativeArray[Object] */;
+val* var79 /* : String */;
+val* var82 /* : CodeWriter */;
+val* var84 /* : CodeWriter */;
+static val* varonce85;
+val* var86 /* : String */;
+char* var87 /* : NativeString */;
+long var88 /* : Int */;
+val* var89 /* : FlatString */;
+{
+{ /* Inline abstract_compiler#AbstractCompiler#modelbuilder (self) on <self:SeparateCompiler> */
+var2 = self->attrs[COLOR_abstract_compiler__AbstractCompiler___modelbuilder].val; /* _modelbuilder on <self:SeparateCompiler> */
+if (unlikely(var2 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _modelbuilder");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 470);
+show_backtrace(1);
+}
+var = var2;
+RET_LABEL1:(void)0;
+}
+}
+{
+{ /* Inline modelbuilder#ModelBuilder#toolcontext (var) on <var:ModelBuilder> */
+var5 = var->attrs[COLOR_modelbuilder__ModelBuilder___toolcontext].val; /* _toolcontext on <var:ModelBuilder> */
+if (unlikely(var5 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _toolcontext");
+PRINT_ERROR(" (%s:%d)\n", "modelbuilder.nit", 106);
+show_backtrace(1);
+}
+var3 = var5;
+RET_LABEL4:(void)0;
+}
+}
+{
+{ /* Inline separate_compiler#ToolContext#opt_no_union_attribute (var3) on <var3:ToolContext> */
+var8 = var3->attrs[COLOR_separate_compiler__ToolContext___opt_no_union_attribute].val; /* _opt_no_union_attribute on <var3:ToolContext> */
+if (unlikely(var8 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _opt_no_union_attribute");
+PRINT_ERROR(" (%s:%d)\n", "compiler/separate_compiler.nit", 28);
+show_backtrace(1);
+}
+var6 = var8;
+RET_LABEL7:(void)0;
+}
+}
+{
+{ /* Inline opts#Option#value (var6) on <var6:OptionBool> */
+var11 = var6->attrs[COLOR_opts__Option___value].val; /* _value on <var6:OptionBool> */
+var9 = var11;
+RET_LABEL10:(void)0;
+}
+}
+var12 = ((struct instance_kernel__Bool*)var9)->value; /* autounbox from nullable Object to Bool */;
+if (var12){
+{
+{ /* Inline abstract_compiler#AbstractCompiler#header (self) on <self:SeparateCompiler> */
+var15 = self->attrs[COLOR_abstract_compiler__AbstractCompiler___header].val; /* _header on <self:SeparateCompiler> */
+if (unlikely(var15 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _header");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 506);
+show_backtrace(1);
+}
+var13 = var15;
+RET_LABEL14:(void)0;
+}
+}
+if (varonce) {
+var16 = varonce;
+} else {
+var17 = "typedef void* nitattribute_t; /* general C type representing a Nit attribute. */";
+var18 = 80;
+var19 = string__NativeString__to_s_with_length(var17, var18);
+var16 = var19;
+varonce = var16;
+}
+{
+abstract_compiler__CodeWriter__add_decl(var13, var16); /* Direct call abstract_compiler#CodeWriter#add_decl on <var13:CodeWriter>*/
+}
+} else {
+{
+{ /* Inline abstract_compiler#AbstractCompiler#header (self) on <self:SeparateCompiler> */
+var22 = self->attrs[COLOR_abstract_compiler__AbstractCompiler___header].val; /* _header on <self:SeparateCompiler> */
+if (unlikely(var22 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _header");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 506);
+show_backtrace(1);
+}
+var20 = var22;
+RET_LABEL21:(void)0;
+}
+}
+if (varonce23) {
+var24 = varonce23;
+} else {
+var25 = "typedef union {";
+var26 = 15;
+var27 = string__NativeString__to_s_with_length(var25, var26);
+var24 = var27;
+varonce23 = var24;
+}
+{
+abstract_compiler__CodeWriter__add_decl(var20, var24); /* Direct call abstract_compiler#CodeWriter#add_decl on <var20:CodeWriter>*/
+}
+{
+{ /* Inline abstract_compiler#AbstractCompiler#header (self) on <self:SeparateCompiler> */
+var30 = self->attrs[COLOR_abstract_compiler__AbstractCompiler___header].val; /* _header on <self:SeparateCompiler> */
+if (unlikely(var30 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _header");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 506);
+show_backtrace(1);
+}
+var28 = var30;
+RET_LABEL29:(void)0;
+}
+}
+if (varonce31) {
+var32 = varonce31;
+} else {
+var33 = "void* val;";
+var34 = 10;
+var35 = string__NativeString__to_s_with_length(var33, var34);
+var32 = var35;
+varonce31 = var32;
+}
+{
+abstract_compiler__CodeWriter__add_decl(var28, var32); /* Direct call abstract_compiler#CodeWriter#add_decl on <var28:CodeWriter>*/
+}
+{
+{ /* Inline separate_compiler#SeparateCompiler#box_kinds (self) on <self:SeparateCompiler> */
+var38 = self->attrs[COLOR_separate_compiler__SeparateCompiler___box_kinds].val; /* _box_kinds on <self:SeparateCompiler> */
+if (unlikely(var38 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _box_kinds");
+PRINT_ERROR(" (%s:%d)\n", "compiler/separate_compiler.nit", 216);
+show_backtrace(1);
+}
+var36 = var38;
+RET_LABEL37:(void)0;
+}
+}
+var_ = var36;
+{
+var39 = hash_collection__HashMap__iterator(var_);
+}
+var_40 = var39;
+for(;;) {
+{
+var41 = hash_collection__HashMapIterator__is_ok(var_40);
+}
+if (var41){
+{
+var42 = hash_collection__HashMapIterator__key(var_40);
+}
+var_c = var42;
+{
+var43 = hash_collection__HashMapIterator__item(var_40);
+}
+var44 = ((struct instance_kernel__Int*)var43)->value; /* autounbox from nullable Object to Int */;
+var_v = var44;
+{
+{ /* Inline model#MClass#mclass_type (var_c) on <var_c:MClass> */
+var47 = var_c->attrs[COLOR_model__MClass___mclass_type].val; /* _mclass_type on <var_c:MClass> */
+if (unlikely(var47 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _mclass_type");
+PRINT_ERROR(" (%s:%d)\n", "model/model.nit", 435);
+show_backtrace(1);
+}
+var45 = var47;
+RET_LABEL46:(void)0;
+}
+}
+var_t = var45;
+{
+{ /* Inline model#MClassType#mclass (var_t) on <var_t:MClassType> */
+var50 = var_t->attrs[COLOR_model__MClassType___mclass].val; /* _mclass on <var_t:MClassType> */
+if (unlikely(var50 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _mclass");
+PRINT_ERROR(" (%s:%d)\n", "model/model.nit", 986);
+show_backtrace(1);
+}
+var48 = var50;
+RET_LABEL49:(void)0;
+}
+}
+{
+{ /* Inline model#MClass#name (var48) on <var48:MClass> */
+var53 = var48->attrs[COLOR_model__MClass___name].val; /* _name on <var48:MClass> */
+if (unlikely(var53 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _name");
+PRINT_ERROR(" (%s:%d)\n", "model/model.nit", 352);
+show_backtrace(1);
+}
+var51 = var53;
+RET_LABEL52:(void)0;
+}
+}
+if (varonce54) {
+var55 = varonce54;
+} else {
+var56 = "Pointer";
+var57 = 7;
+var58 = string__NativeString__to_s_with_length(var56, var57);
+var55 = var58;
+varonce54 = var55;
+}
+{
+var60 = string__FlatString___61d_61d(var51, var55);
+var59 = var60;
+}
+if (var59){
+goto BREAK_label;
+} else {
+}
+{
+{ /* Inline abstract_compiler#AbstractCompiler#header (self) on <self:SeparateCompiler> */
+var63 = self->attrs[COLOR_abstract_compiler__AbstractCompiler___header].val; /* _header on <self:SeparateCompiler> */
+if (unlikely(var63 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _header");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 506);
+show_backtrace(1);
+}
+var61 = var63;
+RET_LABEL62:(void)0;
+}
+}
+{
+var64 = abstract_compiler__MClassType__ctype_extern(var_t);
+}
+if (varonce65) {
+var66 = varonce65;
+} else {
+var67 = " ";
+var68 = 1;
+var69 = string__NativeString__to_s_with_length(var67, var68);
+var66 = var69;
+varonce65 = var66;
+}
+{
+var70 = abstract_compiler__MClassType__ctypename(var_t);
+}
+if (varonce71) {
+var72 = varonce71;
+} else {
+var73 = ";";
+var74 = 1;
+var75 = string__NativeString__to_s_with_length(var73, var74);
+var72 = var75;
+varonce71 = var72;
+}
+var76 = NEW_array__Array(&type_array__Arraykernel__Object);
+{ /* var76 = array_instance Array[Object] */
+var77 = 4;
+var78 = NEW_array__NativeArray(var77, &type_array__NativeArraykernel__Object);
+((struct instance_array__NativeArray*)var78)->values[0] = (val*) var64;
+((struct instance_array__NativeArray*)var78)->values[1] = (val*) var66;
+((struct instance_array__NativeArray*)var78)->values[2] = (val*) var70;
+((struct instance_array__NativeArray*)var78)->values[3] = (val*) var72;
+{
+((void (*)(val*, val*, long))(var76->class->vft[COLOR_array__Array__with_native]))(var76, var78, var77) /* with_native on <var76:Array[Object]>*/;
+}
+}
+{
+var79 = ((val* (*)(val*))(var76->class->vft[COLOR_string__Object__to_s]))(var76) /* to_s on <var76:Array[Object]>*/;
+}
+{
+abstract_compiler__CodeWriter__add_decl(var61, var79); /* Direct call abstract_compiler#CodeWriter#add_decl on <var61:CodeWriter>*/
+}
+BREAK_label: (void)0;
+{
+hash_collection__HashMapIterator__next(var_40); /* Direct call hash_collection#HashMapIterator#next on <var_40:HashMapIterator[MClass, Int]>*/
+}
+} else {
+goto BREAK_label80;
+}
+}
+BREAK_label80: (void)0;
+{
+{ /* Inline abstract_collection#MapIterator#finish (var_40) on <var_40:HashMapIterator[MClass, Int]> */
+RET_LABEL81:(void)0;
+}
+}
+{
+{ /* Inline abstract_compiler#AbstractCompiler#header (self) on <self:SeparateCompiler> */
+var84 = self->attrs[COLOR_abstract_compiler__AbstractCompiler___header].val; /* _header on <self:SeparateCompiler> */
+if (unlikely(var84 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _header");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 506);
+show_backtrace(1);
+}
+var82 = var84;
+RET_LABEL83:(void)0;
+}
+}
+if (varonce85) {
+var86 = varonce85;
+} else {
+var87 = "} nitattribute_t; /* general C type representing a Nit attribute. */";
+var88 = 68;
+var89 = string__NativeString__to_s_with_length(var87, var88);
+var86 = var89;
+varonce85 = var86;
+}
+{
+abstract_compiler__CodeWriter__add_decl(var82, var86); /* Direct call abstract_compiler#CodeWriter#add_decl on <var82:CodeWriter>*/
+}
+}
+RET_LABEL:;
+}
+/* method separate_compiler#SeparateCompiler#compile_header_attribute_structs for (self: Object) */
+void VIRTUAL_separate_compiler__SeparateCompiler__compile_header_attribute_structs(val* self) {
+separate_compiler__SeparateCompiler__compile_header_attribute_structs(self); /* Direct call separate_compiler#SeparateCompiler#compile_header_attribute_structs on <self:Object(SeparateCompiler)>*/
+RET_LABEL:;
+}
+/* method separate_compiler#SeparateCompiler#compile_box_kinds for (self: SeparateCompiler) */
+void separate_compiler__SeparateCompiler__compile_box_kinds(val* self) {
+val* var /* : Array[String] */;
+long var1 /* : Int */;
+val* var_ /* var : Array[String] */;
+static val* varonce;
+val* var2 /* : String */;
+char* var3 /* : NativeString */;
+long var4 /* : Int */;
+val* var5 /* : FlatString */;
+static val* varonce6;
+val* var7 /* : String */;
+char* var8 /* : NativeString */;
+long var9 /* : Int */;
+val* var10 /* : FlatString */;
+static val* varonce11;
+val* var12 /* : String */;
+char* var13 /* : NativeString */;
+long var14 /* : Int */;
+val* var15 /* : FlatString */;
+static val* varonce16;
+val* var17 /* : String */;
+char* var18 /* : NativeString */;
+long var19 /* : Int */;
+val* var20 /* : FlatString */;
+static val* varonce21;
+val* var22 /* : String */;
+char* var23 /* : NativeString */;
+long var24 /* : Int */;
+val* var25 /* : FlatString */;
+static val* varonce26;
+val* var27 /* : String */;
+char* var28 /* : NativeString */;
+long var29 /* : Int */;
+val* var30 /* : FlatString */;
+val* var_31 /* var : Array[String] */;
+val* var32 /* : ArrayIterator[nullable Object] */;
+val* var_33 /* var : ArrayIterator[String] */;
+short int var34 /* : Bool */;
+val* var35 /* : nullable Object */;
+val* var_classname /* var classname: String */;
+val* var36 /* : MModule */;
+val* var38 /* : MModule */;
+val* var39 /* : Model */;
+val* var41 /* : Model */;
+val* var42 /* : nullable Array[MClass] */;
+val* var_classes /* var classes: nullable Array[MClass] */;
+val* var43 /* : null */;
+short int var44 /* : Bool */;
+short int var45 /* : Bool */;
+long var46 /* : Int */;
+long var48 /* : Int */;
+long var49 /* : Int */;
+short int var50 /* : Bool */;
+short int var51 /* : Bool */;
+short int var53 /* : Bool */;
+static val* varonce54;
+val* var55 /* : String */;
+char* var56 /* : NativeString */;
+long var57 /* : Int */;
+val* var58 /* : FlatString */;
+val* var59 /* : String */;
+val* var60 /* : HashMap[MClass, Int] */;
+val* var62 /* : HashMap[MClass, Int] */;
+val* var63 /* : nullable Object */;
+val* var64 /* : HashMap[MClass, Int] */;
+val* var66 /* : HashMap[MClass, Int] */;
+long var67 /* : Int */;
+long var68 /* : Int */;
+long var69 /* : Int */;
+short int var71 /* : Bool */;
+int cltype;
+int idtype;
+const char* var_class_name;
+long var72 /* : Int */;
+val* var73 /* : nullable Object */;
+var = NEW_array__Array(&type_array__Arraystring__String);
+var1 = 6;
+{
+array__Array__with_capacity(var, var1); /* Direct call array#Array#with_capacity on <var:Array[String]>*/
+}
+var_ = var;
+if (varonce) {
+var2 = varonce;
+} else {
+var3 = "Int";
+var4 = 3;
+var5 = string__NativeString__to_s_with_length(var3, var4);
+var2 = var5;
+varonce = var2;
+}
+{
+array__AbstractArray__push(var_, var2); /* Direct call array#AbstractArray#push on <var_:Array[String]>*/
+}
+if (varonce6) {
+var7 = varonce6;
+} else {
+var8 = "Bool";
+var9 = 4;
+var10 = string__NativeString__to_s_with_length(var8, var9);
+var7 = var10;
+varonce6 = var7;
+}
+{
+array__AbstractArray__push(var_, var7); /* Direct call array#AbstractArray#push on <var_:Array[String]>*/
+}
+if (varonce11) {
+var12 = varonce11;
+} else {
+var13 = "Char";
+var14 = 4;
+var15 = string__NativeString__to_s_with_length(var13, var14);
+var12 = var15;
+varonce11 = var12;
+}
+{
+array__AbstractArray__push(var_, var12); /* Direct call array#AbstractArray#push on <var_:Array[String]>*/
+}
+if (varonce16) {
+var17 = varonce16;
+} else {
+var18 = "Float";
+var19 = 5;
+var20 = string__NativeString__to_s_with_length(var18, var19);
+var17 = var20;
+varonce16 = var17;
+}
+{
+array__AbstractArray__push(var_, var17); /* Direct call array#AbstractArray#push on <var_:Array[String]>*/
+}
+if (varonce21) {
+var22 = varonce21;
+} else {
+var23 = "NativeString";
+var24 = 12;
+var25 = string__NativeString__to_s_with_length(var23, var24);
+var22 = var25;
+varonce21 = var22;
+}
+{
+array__AbstractArray__push(var_, var22); /* Direct call array#AbstractArray#push on <var_:Array[String]>*/
+}
+if (varonce26) {
+var27 = varonce26;
+} else {
+var28 = "Pointer";
+var29 = 7;
+var30 = string__NativeString__to_s_with_length(var28, var29);
+var27 = var30;
+varonce26 = var27;
+}
+{
+array__AbstractArray__push(var_, var27); /* Direct call array#AbstractArray#push on <var_:Array[String]>*/
+}
+var_31 = var_;
+{
+var32 = array__AbstractArrayRead__iterator(var_31);
+}
+var_33 = var32;
+for(;;) {
+{
+var34 = array__ArrayIterator__is_ok(var_33);
+}
+if (var34){
+{
+var35 = array__ArrayIterator__item(var_33);
+}
+var_classname = var35;
+{
+{ /* Inline abstract_compiler#AbstractCompiler#mainmodule (self) on <self:SeparateCompiler> */
+var38 = self->attrs[COLOR_abstract_compiler__AbstractCompiler___mainmodule].val; /* _mainmodule on <self:SeparateCompiler> */
+if (unlikely(var38 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _mainmodule");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 463);
+show_backtrace(1);
+}
+var36 = var38;
+RET_LABEL37:(void)0;
+}
+}
+{
+{ /* Inline mmodule#MModule#model (var36) on <var36:MModule> */
+var41 = var36->attrs[COLOR_mmodule__MModule___model].val; /* _model on <var36:MModule> */
+if (unlikely(var41 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _model");
+PRINT_ERROR(" (%s:%d)\n", "model/mmodule.nit", 72);
+show_backtrace(1);
+}
+var39 = var41;
+RET_LABEL40:(void)0;
+}
+}
+{
+var42 = model__Model__get_mclasses_by_name(var39, var_classname);
+}
+var_classes = var42;
+var43 = NULL;
+if (var_classes == NULL) {
+var44 = 1; /* is null */
+} else {
+var44 = 0; /* arg is null but recv is not */
+}
+if (0) {
+var45 = array__Array___61d_61d(var_classes, var43);
+var44 = var45;
+}
+if (var44){
+goto BREAK_label;
+} else {
+}
+{
+{ /* Inline array#AbstractArrayRead#length (var_classes) on <var_classes:nullable Array[MClass](Array[MClass])> */
+var48 = var_classes->attrs[COLOR_array__AbstractArrayRead___length].l; /* _length on <var_classes:nullable Array[MClass](Array[MClass])> */
+var46 = var48;
+RET_LABEL47:(void)0;
+}
+}
+var49 = 1;
+{
+{ /* Inline kernel#Int#== (var46,var49) on <var46:Int> */
+var53 = var46 == var49;
+var51 = var53;
+goto RET_LABEL52;
+RET_LABEL52:(void)0;
+}
+var50 = var51;
+}
+if (unlikely(!var50)) {
+if (varonce54) {
+var55 = varonce54;
+} else {
+var56 = ", ";
+var57 = 2;
+var58 = string__NativeString__to_s_with_length(var56, var57);
+var55 = var58;
+varonce54 = var55;
+}
+{
+var59 = string__Collection__join(var_classes, var55);
+}
+{
+file__Object__print(self, var59); /* Direct call file#Object#print on <self:SeparateCompiler>*/
+}
+PRINT_ERROR("Runtime error: %s", "Assert failed");
+PRINT_ERROR(" (%s:%d)\n", "compiler/separate_compiler.nit", 211);
+show_backtrace(1);
+}
+{
+{ /* Inline separate_compiler#SeparateCompiler#box_kinds (self) on <self:SeparateCompiler> */
+var62 = self->attrs[COLOR_separate_compiler__SeparateCompiler___box_kinds].val; /* _box_kinds on <self:SeparateCompiler> */
+if (unlikely(var62 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _box_kinds");
+PRINT_ERROR(" (%s:%d)\n", "compiler/separate_compiler.nit", 216);
+show_backtrace(1);
+}
+var60 = var62;
+RET_LABEL61:(void)0;
+}
+}
+{
+var63 = abstract_collection__SequenceRead__first(var_classes);
+}
+{
+{ /* Inline separate_compiler#SeparateCompiler#box_kinds (self) on <self:SeparateCompiler> */
+var66 = self->attrs[COLOR_separate_compiler__SeparateCompiler___box_kinds].val; /* _box_kinds on <self:SeparateCompiler> */
+if (unlikely(var66 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _box_kinds");
+PRINT_ERROR(" (%s:%d)\n", "compiler/separate_compiler.nit", 216);
+show_backtrace(1);
+}
+var64 = var66;
+RET_LABEL65:(void)0;
+}
+}
+{
+var67 = hash_collection__HashMap__length(var64);
+}
+var68 = 1;
+{
+{ /* Inline kernel#Int#+ (var67,var68) on <var67:Int> */
+/* Covariant cast for argument 0 (i) <var68:Int> isa OTHER */
+/* <var68:Int> isa OTHER */
+var71 = 1; /* easy <var68:Int> isa OTHER*/
+if (unlikely(!var71)) {
+var_class_name = type_kernel__Int.name;
+PRINT_ERROR("Runtime error: Cast failed. Expected `%s`, got `%s`", "OTHER", var_class_name);
+PRINT_ERROR(" (%s:%d)\n", "../lib/standard/kernel.nit", 374);
+show_backtrace(1);
+}
+var72 = var67 + var68;
+var69 = var72;
+goto RET_LABEL70;
+RET_LABEL70:(void)0;
+}
+}
+{
+var73 = BOX_kernel__Int(var69); /* autobox from Int to nullable Object */
+hash_collection__HashMap___91d_93d_61d(var60, var63, var73); /* Direct call hash_collection#HashMap#[]= on <var60:HashMap[MClass, Int]>*/
+}
+BREAK_label: (void)0;
+{
+array__ArrayIterator__next(var_33); /* Direct call array#ArrayIterator#next on <var_33:ArrayIterator[String]>*/
+}
+} else {
+goto BREAK_label74;
+}
+}
+BREAK_label74: (void)0;
+{
+{ /* Inline abstract_collection#Iterator#finish (var_33) on <var_33:ArrayIterator[String]> */
+RET_LABEL75:(void)0;
+}
+}
+RET_LABEL:;
+}
+/* method separate_compiler#SeparateCompiler#compile_box_kinds for (self: Object) */
+void VIRTUAL_separate_compiler__SeparateCompiler__compile_box_kinds(val* self) {
+separate_compiler__SeparateCompiler__compile_box_kinds(self); /* Direct call separate_compiler#SeparateCompiler#compile_box_kinds on <self:Object(SeparateCompiler)>*/
+RET_LABEL:;
+}
+/* method separate_compiler#SeparateCompiler#box_kinds for (self: SeparateCompiler): HashMap[MClass, Int] */
+val* separate_compiler__SeparateCompiler__box_kinds(val* self) {
+val* var /* : HashMap[MClass, Int] */;
+val* var1 /* : HashMap[MClass, Int] */;
+var1 = self->attrs[COLOR_separate_compiler__SeparateCompiler___box_kinds].val; /* _box_kinds on <self:SeparateCompiler> */
+if (unlikely(var1 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _box_kinds");
+PRINT_ERROR(" (%s:%d)\n", "compiler/separate_compiler.nit", 216);
+show_backtrace(1);
+}
+var = var1;
+RET_LABEL:;
+return var;
+}
+/* method separate_compiler#SeparateCompiler#box_kinds for (self: Object): HashMap[MClass, Int] */
+val* VIRTUAL_separate_compiler__SeparateCompiler__box_kinds(val* self) {
+val* var /* : HashMap[MClass, Int] */;
+val* var1 /* : HashMap[MClass, Int] */;
+val* var3 /* : HashMap[MClass, Int] */;
+{ /* Inline separate_compiler#SeparateCompiler#box_kinds (self) on <self:Object(SeparateCompiler)> */
+var3 = self->attrs[COLOR_separate_compiler__SeparateCompiler___box_kinds].val; /* _box_kinds on <self:Object(SeparateCompiler)> */
+if (unlikely(var3 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _box_kinds");
+PRINT_ERROR(" (%s:%d)\n", "compiler/separate_compiler.nit", 216);
+show_backtrace(1);
+}
+var1 = var3;
+RET_LABEL2:(void)0;
+}
+var = var1;
+RET_LABEL:;
+return var;
+}
+/* method separate_compiler#SeparateCompiler#box_kind_of for (self: SeparateCompiler, MClass): Int */
+long separate_compiler__SeparateCompiler__box_kind_of(val* self, val* p0) {
+long var /* : Int */;
+val* var_mclass /* var mclass: MClass */;
+val* var1 /* : MClassType */;
+val* var3 /* : MClassType */;
+val* var4 /* : String */;
+static val* varonce;
+val* var5 /* : String */;
+char* var6 /* : NativeString */;
+long var7 /* : Int */;
+val* var8 /* : FlatString */;
+short int var9 /* : Bool */;
+short int var10 /* : Bool */;
+long var11 /* : Int */;
+short int var12 /* : Bool */;
+val* var13 /* : MClassKind */;
+val* var15 /* : MClassKind */;
+val* var16 /* : MClassKind */;
+short int var17 /* : Bool */;
+short int var18 /* : Bool */;
+val* var_other /* var other: nullable Object */;
+short int var20 /* : Bool */;
+short int var22 /* : Bool */;
+short int var_ /* var : Bool */;
+val* var23 /* : String */;
+val* var25 /* : String */;
+static val* varonce26;
+val* var27 /* : String */;
+char* var28 /* : NativeString */;
+long var29 /* : Int */;
+val* var30 /* : FlatString */;
+short int var31 /* : Bool */;
+short int var32 /* : Bool */;
+val* var_other34 /* var other: nullable Object */;
+short int var35 /* : Bool */;
+short int var36 /* : Bool */;
+short int var37 /* : Bool */;
+val* var38 /* : HashMap[MClass, Int] */;
+val* var40 /* : HashMap[MClass, Int] */;
+val* var41 /* : MModule */;
+val* var43 /* : MModule */;
+static val* varonce44;
+val* var45 /* : String */;
+char* var46 /* : NativeString */;
+long var47 /* : Int */;
+val* var48 /* : FlatString */;
+val* var49 /* : MClass */;
+val* var50 /* : nullable Object */;
+long var51 /* : Int */;
+val* var52 /* : HashMap[MClass, Int] */;
+val* var54 /* : HashMap[MClass, Int] */;
+val* var55 /* : nullable Object */;
+long var56 /* : Int */;
+var_mclass = p0;
+{
+{ /* Inline model#MClass#mclass_type (var_mclass) on <var_mclass:MClass> */
+var3 = var_mclass->attrs[COLOR_model__MClass___mclass_type].val; /* _mclass_type on <var_mclass:MClass> */
+if (unlikely(var3 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _mclass_type");
+PRINT_ERROR(" (%s:%d)\n", "model/model.nit", 435);
+show_backtrace(1);
+}
+var1 = var3;
+RET_LABEL2:(void)0;
+}
+}
+{
+var4 = abstract_compiler__MClassType__ctype_extern(var1);
+}
+if (varonce) {
+var5 = varonce;
+} else {
+var6 = "val*";
+var7 = 4;
+var8 = string__NativeString__to_s_with_length(var6, var7);
+var5 = var8;
+varonce = var5;
+}
+{
+var10 = string__FlatString___61d_61d(var4, var5);
+var9 = var10;
+}
+if (var9){
+var11 = 0;
+var = var11;
+goto RET_LABEL;
+} else {
+{
+{ /* Inline model#MClass#kind (var_mclass) on <var_mclass:MClass> */
+var15 = var_mclass->attrs[COLOR_model__MClass___kind].val; /* _kind on <var_mclass:MClass> */
+if (unlikely(var15 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _kind");
+PRINT_ERROR(" (%s:%d)\n", "model/model.nit", 371);
+show_backtrace(1);
+}
+var13 = var15;
+RET_LABEL14:(void)0;
+}
+}
+{
+var16 = model__Object__extern_kind(self);
+}
+{
+{ /* Inline kernel#Object#== (var13,var16) on <var13:MClassKind> */
+var_other = var16;
+{
+{ /* Inline kernel#Object#is_same_instance (var13,var_other) on <var13:MClassKind> */
+var22 = var13 == var_other;
+var20 = var22;
+goto RET_LABEL21;
+RET_LABEL21:(void)0;
+}
+}
+var18 = var20;
+goto RET_LABEL19;
+RET_LABEL19:(void)0;
+}
+var17 = var18;
+}
+var_ = var17;
+if (var17){
+{
+{ /* Inline model#MClass#name (var_mclass) on <var_mclass:MClass> */
+var25 = var_mclass->attrs[COLOR_model__MClass___name].val; /* _name on <var_mclass:MClass> */
+if (unlikely(var25 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _name");
+PRINT_ERROR(" (%s:%d)\n", "model/model.nit", 352);
+show_backtrace(1);
+}
+var23 = var25;
+RET_LABEL24:(void)0;
+}
+}
+if (varonce26) {
+var27 = varonce26;
+} else {
+var28 = "NativeString";
+var29 = 12;
+var30 = string__NativeString__to_s_with_length(var28, var29);
+var27 = var30;
+varonce26 = var27;
+}
+{
+{ /* Inline kernel#Object#!= (var23,var27) on <var23:String> */
+var_other34 = var27;
+{
+var36 = ((short int (*)(val*, val*))(var23->class->vft[COLOR_kernel__Object___61d_61d]))(var23, var_other34) /* == on <var23:String>*/;
+var35 = var36;
+}
+var37 = !var35;
+var32 = var37;
+goto RET_LABEL33;
+RET_LABEL33:(void)0;
+}
+var31 = var32;
+}
+var12 = var31;
+} else {
+var12 = var_;
+}
+if (var12){
+{
+{ /* Inline separate_compiler#SeparateCompiler#box_kinds (self) on <self:SeparateCompiler> */
+var40 = self->attrs[COLOR_separate_compiler__SeparateCompiler___box_kinds].val; /* _box_kinds on <self:SeparateCompiler> */
+if (unlikely(var40 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _box_kinds");
+PRINT_ERROR(" (%s:%d)\n", "compiler/separate_compiler.nit", 216);
+show_backtrace(1);
+}
+var38 = var40;
+RET_LABEL39:(void)0;
+}
+}
+{
+{ /* Inline abstract_compiler#AbstractCompiler#mainmodule (self) on <self:SeparateCompiler> */
+var43 = self->attrs[COLOR_abstract_compiler__AbstractCompiler___mainmodule].val; /* _mainmodule on <self:SeparateCompiler> */
+if (unlikely(var43 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _mainmodule");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 463);
+show_backtrace(1);
+}
+var41 = var43;
+RET_LABEL42:(void)0;
+}
+}
+if (varonce44) {
+var45 = varonce44;
+} else {
+var46 = "Pointer";
+var47 = 7;
+var48 = string__NativeString__to_s_with_length(var46, var47);
+var45 = var48;
+varonce44 = var45;
+}
+{
+var49 = model__MModule__get_primitive_class(var41, var45);
+}
+{
+var50 = hash_collection__HashMap___91d_93d(var38, var49);
+}
+var51 = ((struct instance_kernel__Int*)var50)->value; /* autounbox from nullable Object to Int */;
+var = var51;
+goto RET_LABEL;
+} else {
+{
+{ /* Inline separate_compiler#SeparateCompiler#box_kinds (self) on <self:SeparateCompiler> */
+var54 = self->attrs[COLOR_separate_compiler__SeparateCompiler___box_kinds].val; /* _box_kinds on <self:SeparateCompiler> */
+if (unlikely(var54 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _box_kinds");
+PRINT_ERROR(" (%s:%d)\n", "compiler/separate_compiler.nit", 216);
+show_backtrace(1);
+}
+var52 = var54;
+RET_LABEL53:(void)0;
+}
+}
+{
+var55 = hash_collection__HashMap___91d_93d(var52, var_mclass);
+}
+var56 = ((struct instance_kernel__Int*)var55)->value; /* autounbox from nullable Object to Int */;
+var = var56;
+goto RET_LABEL;
+}
+}
+RET_LABEL:;
+return var;
+}
+/* method separate_compiler#SeparateCompiler#box_kind_of for (self: Object, MClass): Int */
+long VIRTUAL_separate_compiler__SeparateCompiler__box_kind_of(val* self, val* p0) {
+long var /* : Int */;
+long var1 /* : Int */;
+var1 = separate_compiler__SeparateCompiler__box_kind_of(self, p0);
+var = var1;
+RET_LABEL:;
+return var;
+}
+/* method separate_compiler#SeparateCompiler#compile_color_consts for (self: SeparateCompiler, Map[Object, Int]) */
+void separate_compiler__SeparateCompiler__compile_color_consts(val* self, val* p0) {
+val* var_colors /* var colors: Map[Object, Int] */;
+val* var /* : AbstractCompilerVisitor */;
+val* var_v /* var v: SeparateCompilerVisitor */;
+val* var_ /* var : Map[Object, Int] */;
+val* var1 /* : MapIterator[Object, nullable Object] */;
+val* var_2 /* var : MapIterator[Object, Int] */;
+short int var3 /* : Bool */;
+val* var4 /* : Object */;
+val* var_m /* var m: Object */;
+val* var5 /* : nullable Object */;
+long var6 /* : Int */;
+long var_c /* var c: Int */;
+var_colors = p0;
+{
+var = ((val* (*)(val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompiler__new_visitor]))(self) /* new_visitor on <self:SeparateCompiler>*/;
+}
+var_v = var;
+var_ = var_colors;
+{
+var1 = ((val* (*)(val*))(var_->class->vft[COLOR_abstract_collection__MapRead__iterator]))(var_) /* iterator on <var_:Map[Object, Int]>*/;
+}
+var_2 = var1;
+for(;;) {
+{
+var3 = ((short int (*)(val*))(var_2->class->vft[COLOR_abstract_collection__MapIterator__is_ok]))(var_2) /* is_ok on <var_2:MapIterator[Object, Int]>*/;
+}
+if (var3){
+{
+var4 = ((val* (*)(val*))(var_2->class->vft[COLOR_abstract_collection__MapIterator__key]))(var_2) /* key on <var_2:MapIterator[Object, Int]>*/;
+}
+var_m = var4;
+{
+var5 = ((val* (*)(val*))(var_2->class->vft[COLOR_abstract_collection__MapIterator__item]))(var_2) /* item on <var_2:MapIterator[Object, Int]>*/;
+}
+var6 = ((struct instance_kernel__Int*)var5)->value; /* autounbox from nullable Object to Int */;
+var_c = var6;
+{
+separate_compiler__SeparateCompiler__compile_color_const(self, var_v, var_m, var_c); /* Direct call separate_compiler#SeparateCompiler#compile_color_const on <self:SeparateCompiler>*/
+}
+{
+((void (*)(val*))(var_2->class->vft[COLOR_abstract_collection__MapIterator__next]))(var_2) /* next on <var_2:MapIterator[Object, Int]>*/;
+}
+} else {
+goto BREAK_label;
+}
+}
+BREAK_label: (void)0;
+{
+{ /* Inline abstract_collection#MapIterator#finish (var_2) on <var_2:MapIterator[Object, Int]> */
+RET_LABEL7:(void)0;
+}
+}
+RET_LABEL:;
+}
+/* method separate_compiler#SeparateCompiler#compile_color_consts for (self: Object, Map[Object, Int]) */
+void VIRTUAL_separate_compiler__SeparateCompiler__compile_color_consts(val* self, val* p0) {
+separate_compiler__SeparateCompiler__compile_color_consts(self, p0); /* Direct call separate_compiler#SeparateCompiler#compile_color_consts on <self:Object(SeparateCompiler)>*/
+RET_LABEL:;
+}
+/* method separate_compiler#SeparateCompiler#compile_color_const for (self: SeparateCompiler, SeparateCompilerVisitor, Object, Int) */
+void separate_compiler__SeparateCompiler__compile_color_const(val* self, val* p0, val* p1, long p2) {
+val* var_v /* var v: SeparateCompilerVisitor */;
+val* var_m /* var m: Object */;
+long var_color /* var color: Int */;
+val* var /* : HashSet[Object] */;
+val* var2 /* : HashSet[Object] */;
+short int var3 /* : Bool */;
+short int var4 /* : Bool */;
+int cltype;
+int idtype;
+val* var5 /* : ModelBuilder */;
+val* var7 /* : ModelBuilder */;
+val* var8 /* : ToolContext */;
+val* var10 /* : ToolContext */;
+val* var11 /* : OptionBool */;
+val* var13 /* : OptionBool */;
+val* var14 /* : nullable Object */;
+val* var16 /* : nullable Object */;
+short int var17 /* : Bool */;
+val* var18 /* : String */;
+static val* varonce;
+val* var19 /* : String */;
+char* var20 /* : NativeString */;
+long var21 /* : Int */;
+val* var22 /* : FlatString */;
+val* var23 /* : String */;
+static val* varonce24;
+val* var25 /* : String */;
+char* var26 /* : NativeString */;
+long var27 /* : Int */;
+val* var28 /* : FlatString */;
+val* var29 /* : Array[Object] */;
+long var30 /* : Int */;
+val* var31 /* : NativeArray[Object] */;
+val* var32 /* : Object */;
+val* var33 /* : String */;
+val* var34 /* : String */;
+static val* varonce35;
+val* var36 /* : String */;
+char* var37 /* : NativeString */;
+long var38 /* : Int */;
+val* var39 /* : FlatString */;
+val* var40 /* : String */;
+static val* varonce41;
+val* var42 /* : String */;
+char* var43 /* : NativeString */;
+long var44 /* : Int */;
+val* var45 /* : FlatString */;
+val* var46 /* : Array[Object] */;
+long var47 /* : Int */;
+val* var48 /* : NativeArray[Object] */;
+val* var49 /* : String */;
+static val* varonce50;
+val* var51 /* : String */;
+char* var52 /* : NativeString */;
+long var53 /* : Int */;
+val* var54 /* : FlatString */;
+val* var55 /* : String */;
+static val* varonce56;
+val* var57 /* : String */;
+char* var58 /* : NativeString */;
+long var59 /* : Int */;
+val* var60 /* : FlatString */;
+static val* varonce61;
+val* var62 /* : String */;
+char* var63 /* : NativeString */;
+long var64 /* : Int */;
+val* var65 /* : FlatString */;
+val* var66 /* : Array[Object] */;
+long var67 /* : Int */;
+val* var68 /* : NativeArray[Object] */;
+val* var69 /* : Object */;
+val* var70 /* : String */;
+short int var71 /* : Bool */;
+int cltype72;
+int idtype73;
+val* var74 /* : ModelBuilder */;
+val* var76 /* : ModelBuilder */;
+val* var77 /* : ToolContext */;
+val* var79 /* : ToolContext */;
+val* var80 /* : OptionBool */;
+val* var82 /* : OptionBool */;
+val* var83 /* : nullable Object */;
+val* var85 /* : nullable Object */;
+short int var86 /* : Bool */;
+val* var87 /* : String */;
+static val* varonce88;
+val* var89 /* : String */;
+char* var90 /* : NativeString */;
+long var91 /* : Int */;
+val* var92 /* : FlatString */;
+val* var93 /* : String */;
+static val* varonce94;
+val* var95 /* : String */;
+char* var96 /* : NativeString */;
+long var97 /* : Int */;
+val* var98 /* : FlatString */;
+val* var99 /* : Array[Object] */;
+long var100 /* : Int */;
+val* var101 /* : NativeArray[Object] */;
+val* var102 /* : Object */;
+val* var103 /* : String */;
+val* var104 /* : String */;
+static val* varonce105;
+val* var106 /* : String */;
+char* var107 /* : NativeString */;
+long var108 /* : Int */;
+val* var109 /* : FlatString */;
+val* var110 /* : String */;
+static val* varonce111;
+val* var112 /* : String */;
+char* var113 /* : NativeString */;
+long var114 /* : Int */;
+val* var115 /* : FlatString */;
+val* var116 /* : Array[Object] */;
+long var117 /* : Int */;
+val* var118 /* : NativeArray[Object] */;
+val* var119 /* : String */;
+static val* varonce120;
+val* var121 /* : String */;
+char* var122 /* : NativeString */;
+long var123 /* : Int */;
+val* var124 /* : FlatString */;
+val* var125 /* : String */;
+static val* varonce126;
+val* var127 /* : String */;
+char* var128 /* : NativeString */;
+long var129 /* : Int */;
+val* var130 /* : FlatString */;
+static val* varonce131;
+val* var132 /* : String */;
+char* var133 /* : NativeString */;
+long var134 /* : Int */;
+val* var135 /* : FlatString */;
+val* var136 /* : Array[Object] */;
+long var137 /* : Int */;
+val* var138 /* : NativeArray[Object] */;
+val* var139 /* : Object */;
+val* var140 /* : String */;
+short int var141 /* : Bool */;
+int cltype142;
+int idtype143;
+val* var144 /* : ModelBuilder */;
+val* var146 /* : ModelBuilder */;
+val* var147 /* : ToolContext */;
+val* var149 /* : ToolContext */;
+val* var150 /* : OptionBool */;
+val* var152 /* : OptionBool */;
+val* var153 /* : nullable Object */;
+val* var155 /* : nullable Object */;
+short int var156 /* : Bool */;
+val* var157 /* : String */;
+static val* varonce158;
+val* var159 /* : String */;
+char* var160 /* : NativeString */;
+long var161 /* : Int */;
+val* var162 /* : FlatString */;
+val* var163 /* : String */;
+static val* varonce164;
+val* var165 /* : String */;
+char* var166 /* : NativeString */;
+long var167 /* : Int */;
+val* var168 /* : FlatString */;
+val* var169 /* : Array[Object] */;
+long var170 /* : Int */;
+val* var171 /* : NativeArray[Object] */;
+val* var172 /* : Object */;
+val* var173 /* : String */;
+val* var174 /* : String */;
+static val* varonce175;
+val* var176 /* : String */;
+char* var177 /* : NativeString */;
+long var178 /* : Int */;
+val* var179 /* : FlatString */;
+val* var180 /* : String */;
+static val* varonce181;
+val* var182 /* : String */;
+char* var183 /* : NativeString */;
+long var184 /* : Int */;
+val* var185 /* : FlatString */;
+val* var186 /* : Array[Object] */;
+long var187 /* : Int */;
+val* var188 /* : NativeArray[Object] */;
+val* var189 /* : String */;
+static val* varonce190;
+val* var191 /* : String */;
+char* var192 /* : NativeString */;
+long var193 /* : Int */;
+val* var194 /* : FlatString */;
+val* var195 /* : String */;
+static val* varonce196;
+val* var197 /* : String */;
+char* var198 /* : NativeString */;
+long var199 /* : Int */;
+val* var200 /* : FlatString */;
+static val* varonce201;
+val* var202 /* : String */;
+char* var203 /* : NativeString */;
+long var204 /* : Int */;
+val* var205 /* : FlatString */;
+val* var206 /* : Array[Object] */;
+long var207 /* : Int */;
+val* var208 /* : NativeArray[Object] */;
+val* var209 /* : Object */;
+val* var210 /* : String */;
+val* var211 /* : HashSet[Object] */;
+val* var213 /* : HashSet[Object] */;
+var_v = p0;
+var_m = p1;
+var_color = p2;
+{
+{ /* Inline separate_compiler#SeparateCompiler#color_consts_done (self) on <self:SeparateCompiler> */
+var2 = self->attrs[COLOR_separate_compiler__SeparateCompiler___color_consts_done].val; /* _color_consts_done on <self:SeparateCompiler> */
+if (unlikely(var2 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _color_consts_done");
+PRINT_ERROR(" (%s:%d)\n", "compiler/separate_compiler.nit", 266);
+show_backtrace(1);
+}
+var = var2;
+RET_LABEL1:(void)0;
+}
+}
+{
+var3 = hash_collection__HashSet__has(var, var_m);
+}
+if (var3){
+goto RET_LABEL;
+} else {
+}
+/* <var_m:Object> isa MProperty */
+cltype = type_model__MProperty.color;
+idtype = type_model__MProperty.id;
+if(cltype >= var_m->type->table_size) {
+var4 = 0;
+} else {
+var4 = var_m->type->type_table[cltype] == idtype;
+}
+if (var4){
+{
+{ /* Inline abstract_compiler#AbstractCompiler#modelbuilder (self) on <self:SeparateCompiler> */
+var7 = self->attrs[COLOR_abstract_compiler__AbstractCompiler___modelbuilder].val; /* _modelbuilder on <self:SeparateCompiler> */
+if (unlikely(var7 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _modelbuilder");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 470);
+show_backtrace(1);
+}
+var5 = var7;
+RET_LABEL6:(void)0;
+}
+}
+{
+{ /* Inline modelbuilder#ModelBuilder#toolcontext (var5) on <var5:ModelBuilder> */
+var10 = var5->attrs[COLOR_modelbuilder__ModelBuilder___toolcontext].val; /* _toolcontext on <var5:ModelBuilder> */
+if (unlikely(var10 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _toolcontext");
+PRINT_ERROR(" (%s:%d)\n", "modelbuilder.nit", 106);
+show_backtrace(1);
+}
+var8 = var10;
+RET_LABEL9:(void)0;
+}
+}
+{
+{ /* Inline separate_compiler#ToolContext#opt_inline_coloring_numbers (var8) on <var8:ToolContext> */
+var13 = var8->attrs[COLOR_separate_compiler__ToolContext___opt_inline_coloring_numbers].val; /* _opt_inline_coloring_numbers on <var8:ToolContext> */
+if (unlikely(var13 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _opt_inline_coloring_numbers");
+PRINT_ERROR(" (%s:%d)\n", "compiler/separate_compiler.nit", 32);
+show_backtrace(1);
+}
+var11 = var13;
+RET_LABEL12:(void)0;
+}
+}
+{
+{ /* Inline opts#Option#value (var11) on <var11:OptionBool> */
+var16 = var11->attrs[COLOR_opts__Option___value].val; /* _value on <var11:OptionBool> */
+var14 = var16;
+RET_LABEL15:(void)0;
+}
+}
+var17 = ((struct instance_kernel__Bool*)var14)->value; /* autounbox from nullable Object to Bool */;
+if (var17){
+{
+var18 = separate_compiler__MProperty__const_color(var_m);
+}
+if (varonce) {
+var19 = varonce;
+} else {
+var20 = "#define ";
+var21 = 8;
+var22 = string__NativeString__to_s_with_length(var20, var21);
+var19 = var22;
+varonce = var19;
+}
+{
+var23 = separate_compiler__MProperty__const_color(var_m);
+}
+if (varonce24) {
+var25 = varonce24;
+} else {
+var26 = " ";
+var27 = 1;
+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 = 4;
+var31 = NEW_array__NativeArray(var30, &type_array__NativeArraykernel__Object);
+((struct instance_array__NativeArray*)var31)->values[0] = (val*) var19;
+((struct instance_array__NativeArray*)var31)->values[1] = (val*) var23;
+((struct instance_array__NativeArray*)var31)->values[2] = (val*) var25;
+var32 = BOX_kernel__Int(var_color); /* autobox from Int to Object */
+((struct instance_array__NativeArray*)var31)->values[3] = (val*) var32;
+{
+((void (*)(val*, val*, long))(var29->class->vft[COLOR_array__Array__with_native]))(var29, var31, var30) /* with_native on <var29:Array[Object]>*/;
+}
+}
+{
+var33 = ((val* (*)(val*))(var29->class->vft[COLOR_string__Object__to_s]))(var29) /* to_s on <var29:Array[Object]>*/;
+}
+{
+abstract_compiler__AbstractCompiler__provide_declaration(self, var18, var33); /* Direct call abstract_compiler#AbstractCompiler#provide_declaration on <self:SeparateCompiler>*/
+}
+} else {
+{
+var34 = separate_compiler__MProperty__const_color(var_m);
+}
+if (varonce35) {
+var36 = varonce35;
+} else {
+var37 = "extern const int ";
+var38 = 17;
+var39 = string__NativeString__to_s_with_length(var37, var38);
+var36 = var39;
+varonce35 = var36;
+}
+{
+var40 = separate_compiler__MProperty__const_color(var_m);
+}
+if (varonce41) {
+var42 = varonce41;
+} else {
+var43 = ";";
+var44 = 1;
+var45 = string__NativeString__to_s_with_length(var43, var44);
+var42 = var45;
+varonce41 = var42;
+}
+var46 = NEW_array__Array(&type_array__Arraykernel__Object);
+{ /* var46 = array_instance Array[Object] */
+var47 = 3;
+var48 = NEW_array__NativeArray(var47, &type_array__NativeArraykernel__Object);
+((struct instance_array__NativeArray*)var48)->values[0] = (val*) var36;
+((struct instance_array__NativeArray*)var48)->values[1] = (val*) var40;
+((struct instance_array__NativeArray*)var48)->values[2] = (val*) var42;
+{
+((void (*)(val*, val*, long))(var46->class->vft[COLOR_array__Array__with_native]))(var46, var48, var47) /* with_native on <var46:Array[Object]>*/;
+}
+}
+{
+var49 = ((val* (*)(val*))(var46->class->vft[COLOR_string__Object__to_s]))(var46) /* to_s on <var46:Array[Object]>*/;
+}
+{
+abstract_compiler__AbstractCompiler__provide_declaration(self, var34, var49); /* Direct call abstract_compiler#AbstractCompiler#provide_declaration on <self:SeparateCompiler>*/
+}
+if (varonce50) {
+var51 = varonce50;
+} else {
+var52 = "const int ";
+var53 = 10;
+var54 = string__NativeString__to_s_with_length(var52, var53);
+var51 = var54;
+varonce50 = var51;
+}
+{
+var55 = separate_compiler__MProperty__const_color(var_m);
+}
+if (varonce56) {
+var57 = varonce56;
+} else {
+var58 = " = ";
+var59 = 3;
+var60 = string__NativeString__to_s_with_length(var58, var59);
+var57 = var60;
+varonce56 = var57;
+}
+if (varonce61) {
+var62 = varonce61;
+} else {
+var63 = ";";
+var64 = 1;
+var65 = string__NativeString__to_s_with_length(var63, var64);
+var62 = var65;
+varonce61 = var62;
+}
+var66 = NEW_array__Array(&type_array__Arraykernel__Object);
+{ /* var66 = array_instance Array[Object] */
+var67 = 5;
+var68 = NEW_array__NativeArray(var67, &type_array__NativeArraykernel__Object);
+((struct instance_array__NativeArray*)var68)->values[0] = (val*) var51;
+((struct instance_array__NativeArray*)var68)->values[1] = (val*) var55;
+((struct instance_array__NativeArray*)var68)->values[2] = (val*) var57;
+var69 = BOX_kernel__Int(var_color); /* autobox from Int to Object */
+((struct instance_array__NativeArray*)var68)->values[3] = (val*) var69;
+((struct instance_array__NativeArray*)var68)->values[4] = (val*) var62;
+{
+((void (*)(val*, val*, long))(var66->class->vft[COLOR_array__Array__with_native]))(var66, var68, var67) /* with_native on <var66:Array[Object]>*/;
+}
+}
+{
+var70 = ((val* (*)(val*))(var66->class->vft[COLOR_string__Object__to_s]))(var66) /* to_s on <var66:Array[Object]>*/;
+}
+{
+abstract_compiler__AbstractCompilerVisitor__add(var_v, var70); /* Direct call abstract_compiler#AbstractCompilerVisitor#add on <var_v:SeparateCompilerVisitor>*/
+}
+}
+} else {
+/* <var_m:Object> isa MPropDef */
+cltype72 = type_model__MPropDef.color;
+idtype73 = type_model__MPropDef.id;
+if(cltype72 >= var_m->type->table_size) {
+var71 = 0;
+} else {
+var71 = var_m->type->type_table[cltype72] == idtype73;
+}
+if (var71){
+{
+{ /* Inline abstract_compiler#AbstractCompiler#modelbuilder (self) on <self:SeparateCompiler> */
+var76 = self->attrs[COLOR_abstract_compiler__AbstractCompiler___modelbuilder].val; /* _modelbuilder on <self:SeparateCompiler> */
+if (unlikely(var76 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _modelbuilder");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 470);
+show_backtrace(1);
+}
+var74 = var76;
+RET_LABEL75:(void)0;
+}
+}
+{
+{ /* Inline modelbuilder#ModelBuilder#toolcontext (var74) on <var74:ModelBuilder> */
+var79 = var74->attrs[COLOR_modelbuilder__ModelBuilder___toolcontext].val; /* _toolcontext on <var74:ModelBuilder> */
+if (unlikely(var79 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _toolcontext");
+PRINT_ERROR(" (%s:%d)\n", "modelbuilder.nit", 106);
+show_backtrace(1);
+}
+var77 = var79;
+RET_LABEL78:(void)0;
+}
+}
+{
+{ /* Inline separate_compiler#ToolContext#opt_inline_coloring_numbers (var77) on <var77:ToolContext> */
+var82 = var77->attrs[COLOR_separate_compiler__ToolContext___opt_inline_coloring_numbers].val; /* _opt_inline_coloring_numbers on <var77:ToolContext> */
+if (unlikely(var82 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _opt_inline_coloring_numbers");
+PRINT_ERROR(" (%s:%d)\n", "compiler/separate_compiler.nit", 32);
+show_backtrace(1);
+}
+var80 = var82;
+RET_LABEL81:(void)0;
+}
+}
+{
+{ /* Inline opts#Option#value (var80) on <var80:OptionBool> */
+var85 = var80->attrs[COLOR_opts__Option___value].val; /* _value on <var80:OptionBool> */
+var83 = var85;
+RET_LABEL84:(void)0;
+}
+}
+var86 = ((struct instance_kernel__Bool*)var83)->value; /* autounbox from nullable Object to Bool */;
+if (var86){
+{
+var87 = separate_compiler__MPropDef__const_color(var_m);
+}
+if (varonce88) {
+var89 = varonce88;
+} else {
+var90 = "#define ";
+var91 = 8;
+var92 = string__NativeString__to_s_with_length(var90, var91);
+var89 = var92;
+varonce88 = var89;
+}
+{
+var93 = separate_compiler__MPropDef__const_color(var_m);
+}
+if (varonce94) {
+var95 = varonce94;
+} else {
+var96 = " ";
+var97 = 1;
+var98 = string__NativeString__to_s_with_length(var96, var97);
+var95 = var98;
+varonce94 = var95;
+}
+var99 = NEW_array__Array(&type_array__Arraykernel__Object);
+{ /* var99 = array_instance Array[Object] */
+var100 = 4;
+var101 = NEW_array__NativeArray(var100, &type_array__NativeArraykernel__Object);
+((struct instance_array__NativeArray*)var101)->values[0] = (val*) var89;
+((struct instance_array__NativeArray*)var101)->values[1] = (val*) var93;
+((struct instance_array__NativeArray*)var101)->values[2] = (val*) var95;
+var102 = BOX_kernel__Int(var_color); /* autobox from Int to Object */
+((struct instance_array__NativeArray*)var101)->values[3] = (val*) var102;
+{
+((void (*)(val*, val*, long))(var99->class->vft[COLOR_array__Array__with_native]))(var99, var101, var100) /* with_native on <var99:Array[Object]>*/;
+}
+}
+{
+var103 = ((val* (*)(val*))(var99->class->vft[COLOR_string__Object__to_s]))(var99) /* to_s on <var99:Array[Object]>*/;
+}
+{
+abstract_compiler__AbstractCompiler__provide_declaration(self, var87, var103); /* Direct call abstract_compiler#AbstractCompiler#provide_declaration on <self:SeparateCompiler>*/
+}
+} else {
+{
+var104 = separate_compiler__MPropDef__const_color(var_m);
+}
+if (varonce105) {
+var106 = varonce105;
+} else {
+var107 = "extern const int ";
+var108 = 17;
+var109 = string__NativeString__to_s_with_length(var107, var108);
+var106 = var109;
+varonce105 = var106;
+}
+{
+var110 = separate_compiler__MPropDef__const_color(var_m);
+}
+if (varonce111) {
+var112 = varonce111;
+} else {
+var113 = ";";
+var114 = 1;
+var115 = string__NativeString__to_s_with_length(var113, var114);
+var112 = var115;
+varonce111 = var112;
+}
+var116 = NEW_array__Array(&type_array__Arraykernel__Object);
+{ /* var116 = array_instance Array[Object] */
+var117 = 3;
+var118 = NEW_array__NativeArray(var117, &type_array__NativeArraykernel__Object);
+((struct instance_array__NativeArray*)var118)->values[0] = (val*) var106;
+((struct instance_array__NativeArray*)var118)->values[1] = (val*) var110;
+((struct instance_array__NativeArray*)var118)->values[2] = (val*) var112;
+{
+((void (*)(val*, val*, long))(var116->class->vft[COLOR_array__Array__with_native]))(var116, var118, var117) /* with_native on <var116:Array[Object]>*/;
+}
+}
+{
+var119 = ((val* (*)(val*))(var116->class->vft[COLOR_string__Object__to_s]))(var116) /* to_s on <var116:Array[Object]>*/;
+}
+{
+abstract_compiler__AbstractCompiler__provide_declaration(self, var104, var119); /* Direct call abstract_compiler#AbstractCompiler#provide_declaration on <self:SeparateCompiler>*/
+}
+if (varonce120) {
+var121 = varonce120;
+} else {
+var122 = "const int ";
+var123 = 10;
+var124 = string__NativeString__to_s_with_length(var122, var123);
+var121 = var124;
+varonce120 = var121;
+}
+{
+var125 = separate_compiler__MPropDef__const_color(var_m);
+}
+if (varonce126) {
+var127 = varonce126;
+} else {
+var128 = " = ";
+var129 = 3;
+var130 = string__NativeString__to_s_with_length(var128, var129);
+var127 = var130;
+varonce126 = var127;
+}
+if (varonce131) {
+var132 = varonce131;
+} else {
+var133 = ";";
+var134 = 1;
+var135 = string__NativeString__to_s_with_length(var133, var134);
+var132 = var135;
+varonce131 = var132;
+}
+var136 = NEW_array__Array(&type_array__Arraykernel__Object);
+{ /* var136 = array_instance Array[Object] */
+var137 = 5;
+var138 = NEW_array__NativeArray(var137, &type_array__NativeArraykernel__Object);
+((struct instance_array__NativeArray*)var138)->values[0] = (val*) var121;
+((struct instance_array__NativeArray*)var138)->values[1] = (val*) var125;
+((struct instance_array__NativeArray*)var138)->values[2] = (val*) var127;
+var139 = BOX_kernel__Int(var_color); /* autobox from Int to Object */
+((struct instance_array__NativeArray*)var138)->values[3] = (val*) var139;
+((struct instance_array__NativeArray*)var138)->values[4] = (val*) var132;
+{
+((void (*)(val*, val*, long))(var136->class->vft[COLOR_array__Array__with_native]))(var136, var138, var137) /* with_native on <var136:Array[Object]>*/;
+}
+}
+{
+var140 = ((val* (*)(val*))(var136->class->vft[COLOR_string__Object__to_s]))(var136) /* to_s on <var136:Array[Object]>*/;
+}
+{
+abstract_compiler__AbstractCompilerVisitor__add(var_v, var140); /* Direct call abstract_compiler#AbstractCompilerVisitor#add on <var_v:SeparateCompilerVisitor>*/
+}
+}
+} else {
+/* <var_m:Object> isa MType */
+cltype142 = type_model__MType.color;
+idtype143 = type_model__MType.id;
+if(cltype142 >= var_m->type->table_size) {
+var141 = 0;
+} else {
+var141 = var_m->type->type_table[cltype142] == idtype143;
+}
+if (var141){
+{
+{ /* Inline abstract_compiler#AbstractCompiler#modelbuilder (self) on <self:SeparateCompiler> */
+var146 = self->attrs[COLOR_abstract_compiler__AbstractCompiler___modelbuilder].val; /* _modelbuilder on <self:SeparateCompiler> */
+if (unlikely(var146 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _modelbuilder");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 470);
+show_backtrace(1);
+}
+var144 = var146;
+RET_LABEL145:(void)0;
+}
+}
+{
+{ /* Inline modelbuilder#ModelBuilder#toolcontext (var144) on <var144:ModelBuilder> */
+var149 = var144->attrs[COLOR_modelbuilder__ModelBuilder___toolcontext].val; /* _toolcontext on <var144:ModelBuilder> */
+if (unlikely(var149 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _toolcontext");
+PRINT_ERROR(" (%s:%d)\n", "modelbuilder.nit", 106);
+show_backtrace(1);
+}
+var147 = var149;
+RET_LABEL148:(void)0;
+}
+}
+{
+{ /* Inline separate_compiler#ToolContext#opt_inline_coloring_numbers (var147) on <var147:ToolContext> */
+var152 = var147->attrs[COLOR_separate_compiler__ToolContext___opt_inline_coloring_numbers].val; /* _opt_inline_coloring_numbers on <var147:ToolContext> */
+if (unlikely(var152 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _opt_inline_coloring_numbers");
+PRINT_ERROR(" (%s:%d)\n", "compiler/separate_compiler.nit", 32);
+show_backtrace(1);
+}
+var150 = var152;
+RET_LABEL151:(void)0;
+}
+}
+{
+{ /* Inline opts#Option#value (var150) on <var150:OptionBool> */
+var155 = var150->attrs[COLOR_opts__Option___value].val; /* _value on <var150:OptionBool> */
+var153 = var155;
+RET_LABEL154:(void)0;
+}
+}
+var156 = ((struct instance_kernel__Bool*)var153)->value; /* autounbox from nullable Object to Bool */;
+if (var156){
+{
+var157 = separate_compiler__MType__const_color(var_m);
+}
+if (varonce158) {
+var159 = varonce158;
+} else {
+var160 = "#define ";
+var161 = 8;
+var162 = string__NativeString__to_s_with_length(var160, var161);
+var159 = var162;
+varonce158 = var159;
+}
+{
+var163 = separate_compiler__MType__const_color(var_m);
+}
+if (varonce164) {
+var165 = varonce164;
+} else {
+var166 = " ";
+var167 = 1;
+var168 = string__NativeString__to_s_with_length(var166, var167);
+var165 = var168;
+varonce164 = var165;
+}
+var169 = NEW_array__Array(&type_array__Arraykernel__Object);
+{ /* var169 = array_instance Array[Object] */
+var170 = 4;
+var171 = NEW_array__NativeArray(var170, &type_array__NativeArraykernel__Object);
+((struct instance_array__NativeArray*)var171)->values[0] = (val*) var159;
+((struct instance_array__NativeArray*)var171)->values[1] = (val*) var163;
+((struct instance_array__NativeArray*)var171)->values[2] = (val*) var165;
+var172 = BOX_kernel__Int(var_color); /* autobox from Int to Object */
+((struct instance_array__NativeArray*)var171)->values[3] = (val*) var172;
+{
+((void (*)(val*, val*, long))(var169->class->vft[COLOR_array__Array__with_native]))(var169, var171, var170) /* with_native on <var169:Array[Object]>*/;
+}
+}
+{
+var173 = ((val* (*)(val*))(var169->class->vft[COLOR_string__Object__to_s]))(var169) /* to_s on <var169:Array[Object]>*/;
+}
+{
+abstract_compiler__AbstractCompiler__provide_declaration(self, var157, var173); /* Direct call abstract_compiler#AbstractCompiler#provide_declaration on <self:SeparateCompiler>*/
+}
+} else {
+{
+var174 = separate_compiler__MType__const_color(var_m);
+}
+if (varonce175) {
+var176 = varonce175;
+} else {
+var177 = "extern const int ";
+var178 = 17;
+var179 = string__NativeString__to_s_with_length(var177, var178);
+var176 = var179;
+varonce175 = var176;
+}
+{
+var180 = separate_compiler__MType__const_color(var_m);
+}
+if (varonce181) {
+var182 = varonce181;
+} else {
+var183 = ";";
+var184 = 1;
+var185 = string__NativeString__to_s_with_length(var183, var184);
+var182 = var185;
+varonce181 = var182;
+}
+var186 = NEW_array__Array(&type_array__Arraykernel__Object);
+{ /* var186 = array_instance Array[Object] */
+var187 = 3;
+var188 = NEW_array__NativeArray(var187, &type_array__NativeArraykernel__Object);
+((struct instance_array__NativeArray*)var188)->values[0] = (val*) var176;
+((struct instance_array__NativeArray*)var188)->values[1] = (val*) var180;
+((struct instance_array__NativeArray*)var188)->values[2] = (val*) var182;
+{
+((void (*)(val*, val*, long))(var186->class->vft[COLOR_array__Array__with_native]))(var186, var188, var187) /* with_native on <var186:Array[Object]>*/;
+}
+}
+{
+var189 = ((val* (*)(val*))(var186->class->vft[COLOR_string__Object__to_s]))(var186) /* to_s on <var186:Array[Object]>*/;
+}
+{
+abstract_compiler__AbstractCompiler__provide_declaration(self, var174, var189); /* Direct call abstract_compiler#AbstractCompiler#provide_declaration on <self:SeparateCompiler>*/
+}
+if (varonce190) {
+var191 = varonce190;
+} else {
+var192 = "const int ";
+var193 = 10;
+var194 = string__NativeString__to_s_with_length(var192, var193);
+var191 = var194;
+varonce190 = var191;
+}
+{
+var195 = separate_compiler__MType__const_color(var_m);
+}
+if (varonce196) {
+var197 = varonce196;
+} else {
+var198 = " = ";
+var199 = 3;
+var200 = string__NativeString__to_s_with_length(var198, var199);
+var197 = var200;
+varonce196 = var197;
+}
+if (varonce201) {
+var202 = varonce201;
+} else {
+var203 = ";";
+var204 = 1;
+var205 = string__NativeString__to_s_with_length(var203, var204);
+var202 = var205;
+varonce201 = var202;
+}
+var206 = NEW_array__Array(&type_array__Arraykernel__Object);
+{ /* var206 = array_instance Array[Object] */
+var207 = 5;
+var208 = NEW_array__NativeArray(var207, &type_array__NativeArraykernel__Object);
+((struct instance_array__NativeArray*)var208)->values[0] = (val*) var191;
+((struct instance_array__NativeArray*)var208)->values[1] = (val*) var195;
+((struct instance_array__NativeArray*)var208)->values[2] = (val*) var197;
+var209 = BOX_kernel__Int(var_color); /* autobox from Int to Object */
+((struct instance_array__NativeArray*)var208)->values[3] = (val*) var209;
+((struct instance_array__NativeArray*)var208)->values[4] = (val*) var202;
+{
+((void (*)(val*, val*, long))(var206->class->vft[COLOR_array__Array__with_native]))(var206, var208, var207) /* with_native on <var206:Array[Object]>*/;
+}
+}
+{
+var210 = ((val* (*)(val*))(var206->class->vft[COLOR_string__Object__to_s]))(var206) /* to_s on <var206:Array[Object]>*/;
+}
+{
+abstract_compiler__AbstractCompilerVisitor__add(var_v, var210); /* Direct call abstract_compiler#AbstractCompilerVisitor#add on <var_v:SeparateCompilerVisitor>*/
+}
+}
+} else {
+}
+}
+}
+{
+{ /* Inline separate_compiler#SeparateCompiler#color_consts_done (self) on <self:SeparateCompiler> */
+var213 = self->attrs[COLOR_separate_compiler__SeparateCompiler___color_consts_done].val; /* _color_consts_done on <self:SeparateCompiler> */
+if (unlikely(var213 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _color_consts_done");
+PRINT_ERROR(" (%s:%d)\n", "compiler/separate_compiler.nit", 266);
+show_backtrace(1);
+}
+var211 = var213;
+RET_LABEL212:(void)0;
+}
+}
+{
+hash_collection__HashSet__add(var211, var_m); /* Direct call hash_collection#HashSet#add on <var211:HashSet[Object]>*/
+}
+RET_LABEL:;
+}
+/* method separate_compiler#SeparateCompiler#compile_color_const for (self: Object, SeparateCompilerVisitor, Object, Int) */
+void VIRTUAL_separate_compiler__SeparateCompiler__compile_color_const(val* self, val* p0, val* p1, long p2) {
+separate_compiler__SeparateCompiler__compile_color_const(self, p0, p1, p2); /* Direct call separate_compiler#SeparateCompiler#compile_color_const on <self:Object(SeparateCompiler)>*/
+RET_LABEL:;
+}
+/* method separate_compiler#SeparateCompiler#color_consts_done for (self: SeparateCompiler): HashSet[Object] */
+val* separate_compiler__SeparateCompiler__color_consts_done(val* self) {
+val* var /* : HashSet[Object] */;
+val* var1 /* : HashSet[Object] */;
+var1 = self->attrs[COLOR_separate_compiler__SeparateCompiler___color_consts_done].val; /* _color_consts_done on <self:SeparateCompiler> */
+if (unlikely(var1 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _color_consts_done");
+PRINT_ERROR(" (%s:%d)\n", "compiler/separate_compiler.nit", 266);
+show_backtrace(1);
+}
+var = var1;
+RET_LABEL:;
+return var;
+}
+/* method separate_compiler#SeparateCompiler#color_consts_done for (self: Object): HashSet[Object] */
+val* VIRTUAL_separate_compiler__SeparateCompiler__color_consts_done(val* self) {
+val* var /* : HashSet[Object] */;
+val* var1 /* : HashSet[Object] */;
+val* var3 /* : HashSet[Object] */;
+{ /* Inline separate_compiler#SeparateCompiler#color_consts_done (self) on <self:Object(SeparateCompiler)> */
+var3 = self->attrs[COLOR_separate_compiler__SeparateCompiler___color_consts_done].val; /* _color_consts_done on <self:Object(SeparateCompiler)> */
+if (unlikely(var3 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _color_consts_done");
+PRINT_ERROR(" (%s:%d)\n", "compiler/separate_compiler.nit", 266);
+show_backtrace(1);
+}
+var1 = var3;
+RET_LABEL2:(void)0;
+}
+var = var1;
+RET_LABEL:;
+return var;
+}
+/* method separate_compiler#SeparateCompiler#do_property_coloring for (self: SeparateCompiler) */
+void separate_compiler__SeparateCompiler__do_property_coloring(val* self) {
+val* var /* : nullable RapidTypeAnalysis */;
+val* var2 /* : nullable RapidTypeAnalysis */;
+val* var_rta /* var rta: nullable RapidTypeAnalysis */;
+val* var3 /* : MModule */;
+val* var5 /* : MModule */;
+val* var6 /* : POSet[MClass] */;
+val* var_poset /* var poset: POSet[MClass] */;
+val* var7 /* : HashSet[MClass] */;
+val* var_mclasses /* var mclasses: HashSet[MClass] */;
+val* var8 /* : POSetColorer[MClass] */;
+val* var_colorer /* var colorer: POSetColorer[MClass] */;
+val* var9 /* : Array[MMethod] */;
+val* var_dead_methods /* var dead_methods: Array[MMethod] */;
+val* var10 /* : HashMap[MClass, Set[PropertyLayoutElement]] */;
+val* var_mmethods /* var mmethods: HashMap[MClass, Set[PropertyLayoutElement]] */;
+val* var11 /* : HashMap[MClass, Set[MAttribute]] */;
+val* var_mattributes /* var mattributes: HashMap[MClass, Set[MAttribute]] */;
+val* var_ /* var : HashSet[MClass] */;
+val* var12 /* : Iterator[Object] */;
+val* var_13 /* var : Iterator[MClass] */;
+short int var14 /* : Bool */;
+val* var15 /* : nullable Object */;
+val* var_mclass /* var mclass: MClass */;
+val* var16 /* : HashSet[PropertyLayoutElement] */;
+val* var17 /* : HashSet[MAttribute] */;
+val* var18 /* : MModule */;
+val* var20 /* : MModule */;
+val* var21 /* : Set[MProperty] */;
+val* var_22 /* var : Set[MProperty] */;
+val* var23 /* : Iterator[nullable Object] */;
+val* var_24 /* var : Iterator[MProperty] */;
+short int var25 /* : Bool */;
+val* var26 /* : nullable Object */;
+val* var_mprop /* var mprop: MProperty */;
+short int var27 /* : Bool */;
+int cltype;
+int idtype;
+short int var28 /* : Bool */;
+short int var29 /* : Bool */;
+val* var30 /* : ModelBuilder */;
+val* var32 /* : ModelBuilder */;
+val* var33 /* : ToolContext */;
+val* var35 /* : ToolContext */;
+val* var36 /* : OptionBool */;
+val* var38 /* : OptionBool */;
+val* var39 /* : nullable Object */;
+val* var41 /* : nullable Object */;
+short int var42 /* : Bool */;
+short int var43 /* : Bool */;
+short int var_44 /* var : Bool */;
+val* var45 /* : null */;
+short int var46 /* : Bool */;
+short int var47 /* : Bool */;
+val* var_other /* var other: nullable Object */;
+short int var49 /* : Bool */;
+short int var50 /* : Bool */;
+short int var51 /* : Bool */;
+short int var_52 /* var : Bool */;
+val* var53 /* : HashSet[MMethod] */;
+val* var55 /* : HashSet[MMethod] */;
+short int var56 /* : Bool */;
+short int var57 /* : Bool */;
+val* var58 /* : nullable Object */;
+short int var59 /* : Bool */;
+int cltype60;
+int idtype61;
+val* var62 /* : nullable Object */;
+val* var67 /* : HashSet[MMethodDef] */;
+val* var_all_super_calls /* var all_super_calls: HashSet[MMethodDef] */;
+val* var68 /* : MModule */;
+val* var70 /* : MModule */;
+val* var71 /* : POSetElement[MModule] */;
+val* var73 /* : POSetElement[MModule] */;
+val* var74 /* : Collection[Object] */;
+val* var_75 /* var : Collection[MModule] */;
+val* var76 /* : Iterator[nullable Object] */;
+val* var_77 /* var : Iterator[MModule] */;
+short int var78 /* : Bool */;
+val* var79 /* : nullable Object */;
+val* var_mmodule /* var mmodule: MModule */;
+val* var80 /* : Array[MClassDef] */;
+val* var82 /* : Array[MClassDef] */;
+val* var_83 /* var : Array[MClassDef] */;
+val* var84 /* : ArrayIterator[nullable Object] */;
+val* var_85 /* var : ArrayIterator[MClassDef] */;
+short int var86 /* : Bool */;
+val* var87 /* : nullable Object */;
+val* var_mclassdef /* var mclassdef: MClassDef */;
+val* var88 /* : Array[MPropDef] */;
+val* var90 /* : Array[MPropDef] */;
+val* var_91 /* var : Array[MPropDef] */;
+val* var92 /* : ArrayIterator[nullable Object] */;
+val* var_93 /* var : ArrayIterator[MPropDef] */;
+short int var94 /* : Bool */;
+val* var95 /* : nullable Object */;
+val* var_mpropdef /* var mpropdef: MPropDef */;
+short int var96 /* : Bool */;
+int cltype97;
+int idtype98;
+short int var99 /* : Bool */;
+short int var101 /* : Bool */;
+short int var103 /* : Bool */;
+val* var110 /* : null */;
+short int var111 /* : Bool */;
+short int var112 /* : Bool */;
+short int var114 /* : Bool */;
+short int var115 /* : Bool */;
+short int var116 /* : Bool */;
+val* var117 /* : HashSet[MMethodDef] */;
+val* var119 /* : HashSet[MMethodDef] */;
+val* var_super_calls /* var super_calls: nullable Object */;
+val* var_120 /* var : HashSet[MMethodDef] */;
+val* var121 /* : Iterator[Object] */;
+val* var_122 /* var : Iterator[MMethodDef] */;
+short int var123 /* : Bool */;
+val* var124 /* : nullable Object */;
+val* var_mmethoddef /* var mmethoddef: MMethodDef */;
+val* var125 /* : MClassDef */;
+val* var127 /* : MClassDef */;
+val* var128 /* : MClass */;
+val* var130 /* : MClass */;
+val* var_mclass131 /* var mclass: MClass */;
+val* var132 /* : nullable Object */;
+val* var133 /* : MModule */;
+val* var135 /* : MModule */;
+val* var136 /* : POSetElement[MClass] */;
+val* var137 /* : Collection[Object] */;
+val* var_138 /* var : Collection[MClass] */;
+val* var139 /* : Iterator[nullable Object] */;
+val* var_140 /* var : Iterator[MClass] */;
+short int var141 /* : Bool */;
+val* var142 /* : nullable Object */;
+val* var_descendant /* var descendant: MClass */;
+val* var143 /* : nullable Object */;
+val* var148 /* : POSetBucketsColorer[MClass, PropertyLayoutElement] */;
+val* var149 /* : Map[Object, Set[Object]] */;
+val* var_meth_colorer /* var meth_colorer: POSetBucketsColorer[MClass, PropertyLayoutElement] */;
+val* var150 /* : Map[Object, Int] */;
+val* var152 /* : Map[MClass, Array[nullable MPropDef]] */;
+val* var154 /* : Map[PropertyLayoutElement, Int] */;
+val* var156 /* : Map[PropertyLayoutElement, Int] */;
+val* var_157 /* var : Array[MMethod] */;
+val* var158 /* : ArrayIterator[nullable Object] */;
+val* var_159 /* var : ArrayIterator[MMethod] */;
+short int var160 /* : Bool */;
+val* var161 /* : nullable Object */;
+val* var_mproperty /* var mproperty: MMethod */;
+val* var162 /* : AbstractCompilerVisitor */;
+long var163 /* : Int */;
+long var164 /* : Int */;
+long var166 /* : Int */;
+val* var_169 /* var : HashSet[MMethodDef] */;
+val* var170 /* : Iterator[Object] */;
+val* var_171 /* var : Iterator[MMethodDef] */;
+short int var172 /* : Bool */;
+val* var173 /* : nullable Object */;
+val* var_mpropdef174 /* var mpropdef: MMethodDef */;
+short int var175 /* : Bool */;
+val* var177 /* : AbstractCompilerVisitor */;
+long var178 /* : Int */;
+long var179 /* : Int */;
+long var181 /* : Int */;
+val* var184 /* : POSetBucketsColorer[MClass, MAttribute] */;
+val* var185 /* : Map[Object, Set[Object]] */;
+val* var_attr_colorer /* var attr_colorer: POSetBucketsColorer[MClass, MAttribute] */;
+val* var186 /* : Map[Object, Int] */;
+val* var188 /* : Map[MClass, Array[nullable MPropDef]] */;
+val* var190 /* : Map[MAttribute, Int] */;
+val* var192 /* : Map[MAttribute, Int] */;
+{
+{ /* Inline separate_compiler#SeparateCompiler#runtime_type_analysis (self) on <self:SeparateCompiler> */
+var2 = self->attrs[COLOR_separate_compiler__SeparateCompiler___runtime_type_analysis].val; /* _runtime_type_analysis on <self:SeparateCompiler> */
+var = var2;
+RET_LABEL1:(void)0;
+}
+}
+var_rta = var;
+{
+{ /* Inline abstract_compiler#AbstractCompiler#mainmodule (self) on <self:SeparateCompiler> */
+var5 = self->attrs[COLOR_abstract_compiler__AbstractCompiler___mainmodule].val; /* _mainmodule on <self:SeparateCompiler> */
+if (unlikely(var5 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _mainmodule");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 463);
+show_backtrace(1);
+}
+var3 = var5;
+RET_LABEL4:(void)0;
+}
+}
+{
+var6 = model__MModule__flatten_mclass_hierarchy(var3);
+}
+var_poset = var6;
+var7 = NEW_hash_collection__HashSet(&type_hash_collection__HashSetmodel__MClass);
+{
+hash_collection__HashSet__from(var7, var_poset); /* Direct call hash_collection#HashSet#from on <var7:HashSet[MClass]>*/
+}
+var_mclasses = var7;
+var8 = NEW_coloring__POSetColorer(&type_coloring__POSetColorermodel__MClass);
+{
+((void (*)(val*))(var8->class->vft[COLOR_kernel__Object__init]))(var8) /* init on <var8:POSetColorer[MClass]>*/;
+}
+var_colorer = var8;
+{
+coloring__POSetColorer__colorize(var_colorer, var_poset); /* Direct call coloring#POSetColorer#colorize on <var_colorer:POSetColorer[MClass]>*/
+}
+var9 = NEW_array__Array(&type_array__Arraymodel__MMethod);
+{
+((void (*)(val*))(var9->class->vft[COLOR_kernel__Object__init]))(var9) /* init on <var9:Array[MMethod]>*/;
+}
+var_dead_methods = var9;
+var10 = NEW_hash_collection__HashMap(&type_hash_collection__HashMapmodel__MClassabstract_collection__Setseparate_compiler__PropertyLayoutElement);
+{
+((void (*)(val*))(var10->class->vft[COLOR_kernel__Object__init]))(var10) /* init on <var10:HashMap[MClass, Set[PropertyLayoutElement]]>*/;
+}
+var_mmethods = var10;
+var11 = NEW_hash_collection__HashMap(&type_hash_collection__HashMapmodel__MClassabstract_collection__Setmodel__MAttribute);
+{
+((void (*)(val*))(var11->class->vft[COLOR_kernel__Object__init]))(var11) /* init on <var11:HashMap[MClass, Set[MAttribute]]>*/;
+}
+var_mattributes = var11;
+var_ = var_mclasses;
+{
+var12 = hash_collection__HashSet__iterator(var_);
+}
+var_13 = var12;
+for(;;) {
+{
+var14 = ((short int (*)(val*))(var_13->class->vft[COLOR_abstract_collection__Iterator__is_ok]))(var_13) /* is_ok on <var_13:Iterator[MClass]>*/;
+}
+if (var14){
+{
+var15 = ((val* (*)(val*))(var_13->class->vft[COLOR_abstract_collection__Iterator__item]))(var_13) /* item on <var_13:Iterator[MClass]>*/;
+}
+var_mclass = var15;
+var16 = NEW_hash_collection__HashSet(&type_hash_collection__HashSetseparate_compiler__PropertyLayoutElement);
+{
+((void (*)(val*))(var16->class->vft[COLOR_kernel__Object__init]))(var16) /* init on <var16:HashSet[PropertyLayoutElement]>*/;
+}
+{
+hash_collection__HashMap___91d_93d_61d(var_mmethods, var_mclass, var16); /* Direct call hash_collection#HashMap#[]= on <var_mmethods:HashMap[MClass, Set[PropertyLayoutElement]]>*/
+}
+var17 = NEW_hash_collection__HashSet(&type_hash_collection__HashSetmodel__MAttribute);
+{
+((void (*)(val*))(var17->class->vft[COLOR_kernel__Object__init]))(var17) /* init on <var17:HashSet[MAttribute]>*/;
+}
+{
+hash_collection__HashMap___91d_93d_61d(var_mattributes, var_mclass, var17); /* Direct call hash_collection#HashMap#[]= on <var_mattributes:HashMap[MClass, Set[MAttribute]]>*/
+}
+{
+{ /* Inline abstract_compiler#AbstractCompiler#mainmodule (self) on <self:SeparateCompiler> */
+var20 = self->attrs[COLOR_abstract_compiler__AbstractCompiler___mainmodule].val; /* _mainmodule on <self:SeparateCompiler> */
+if (unlikely(var20 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _mainmodule");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 463);
+show_backtrace(1);
+}
+var18 = var20;
+RET_LABEL19:(void)0;
+}
+}
+{
+var21 = abstract_compiler__MModule__properties(var18, var_mclass);
+}
+var_22 = var21;
+{
+var23 = ((val* (*)(val*))(var_22->class->vft[COLOR_abstract_collection__Collection__iterator]))(var_22) /* iterator on <var_22:Set[MProperty]>*/;
+}
+var_24 = var23;
+for(;;) {
+{
+var25 = ((short int (*)(val*))(var_24->class->vft[COLOR_abstract_collection__Iterator__is_ok]))(var_24) /* is_ok on <var_24:Iterator[MProperty]>*/;
+}
+if (var25){
+{
+var26 = ((val* (*)(val*))(var_24->class->vft[COLOR_abstract_collection__Iterator__item]))(var_24) /* item on <var_24:Iterator[MProperty]>*/;
+}
+var_mprop = var26;
+/* <var_mprop:MProperty> isa MMethod */
+cltype = type_model__MMethod.color;
+idtype = type_model__MMethod.id;
+if(cltype >= var_mprop->type->table_size) {
+var27 = 0;
+} else {
+var27 = var_mprop->type->type_table[cltype] == idtype;
+}
+if (var27){
+{
+{ /* Inline abstract_compiler#AbstractCompiler#modelbuilder (self) on <self:SeparateCompiler> */
+var32 = self->attrs[COLOR_abstract_compiler__AbstractCompiler___modelbuilder].val; /* _modelbuilder on <self:SeparateCompiler> */
+if (unlikely(var32 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _modelbuilder");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 470);
+show_backtrace(1);
+}
+var30 = var32;
+RET_LABEL31:(void)0;
+}
+}
+{
+{ /* Inline modelbuilder#ModelBuilder#toolcontext (var30) on <var30:ModelBuilder> */
+var35 = var30->attrs[COLOR_modelbuilder__ModelBuilder___toolcontext].val; /* _toolcontext on <var30:ModelBuilder> */
+if (unlikely(var35 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _toolcontext");
+PRINT_ERROR(" (%s:%d)\n", "modelbuilder.nit", 106);
+show_backtrace(1);
+}
+var33 = var35;
+RET_LABEL34:(void)0;
+}
+}
+{
+{ /* Inline separate_compiler#ToolContext#opt_colo_dead_methods (var33) on <var33:ToolContext> */
+var38 = var33->attrs[COLOR_separate_compiler__ToolContext___opt_colo_dead_methods].val; /* _opt_colo_dead_methods on <var33:ToolContext> */
+if (unlikely(var38 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _opt_colo_dead_methods");
+PRINT_ERROR(" (%s:%d)\n", "compiler/separate_compiler.nit", 42);
+show_backtrace(1);
+}
+var36 = var38;
+RET_LABEL37:(void)0;
+}
+}
+{
+{ /* Inline opts#Option#value (var36) on <var36:OptionBool> */
+var41 = var36->attrs[COLOR_opts__Option___value].val; /* _value on <var36:OptionBool> */
+var39 = var41;
+RET_LABEL40:(void)0;
+}
+}
+var42 = ((struct instance_kernel__Bool*)var39)->value; /* autounbox from nullable Object to Bool */;
+var43 = !var42;
+var_44 = var43;
+if (var43){
+var45 = NULL;
+if (var_rta == NULL) {
+var46 = 0; /* is null */
+} else {
+var46 = 1; /* arg is null and recv is not */
+}
+if (0) {
+{ /* Inline kernel#Object#!= (var_rta,var45) on <var_rta:nullable RapidTypeAnalysis> */
+var_other = var45;
+{
+var50 = ((short int (*)(val*, val*))(var_rta->class->vft[COLOR_kernel__Object___61d_61d]))(var_rta, var_other) /* == on <var_rta:nullable RapidTypeAnalysis(RapidTypeAnalysis)>*/;
+var49 = var50;
+}
+var51 = !var49;
+var47 = var51;
+goto RET_LABEL48;
+RET_LABEL48:(void)0;
+}
+var46 = var47;
+}
+var29 = var46;
+} else {
+var29 = var_44;
+}
+var_52 = var29;
+if (var29){
+{
+{ /* Inline rapid_type_analysis#RapidTypeAnalysis#live_methods (var_rta) on <var_rta:nullable RapidTypeAnalysis(RapidTypeAnalysis)> */
+var55 = var_rta->attrs[COLOR_rapid_type_analysis__RapidTypeAnalysis___live_methods].val; /* _live_methods on <var_rta:nullable RapidTypeAnalysis(RapidTypeAnalysis)> */
+if (unlikely(var55 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _live_methods");
+PRINT_ERROR(" (%s:%d)\n", "rapid_type_analysis.nit", 75);
+show_backtrace(1);
+}
+var53 = var55;
+RET_LABEL54:(void)0;
+}
+}
+{
+var56 = hash_collection__HashSet__has(var53, var_mprop);
+}
+var57 = !var56;
+var28 = var57;
+} else {
+var28 = var_52;
+}
+if (var28){
+{
+array__Array__add(var_dead_methods, var_mprop); /* Direct call array#Array#add on <var_dead_methods:Array[MMethod]>*/
+}
+goto BREAK_label;
+} else {
+}
+{
+var58 = hash_collection__HashMap___91d_93d(var_mmethods, var_mclass);
+}
+{
+((void (*)(val*, val*))(var58->class->vft[COLOR_abstract_collection__SimpleCollection__add]))(var58, var_mprop) /* add on <var58:nullable Object(Set[PropertyLayoutElement])>*/;
+}
+} else {
+/* <var_mprop:MProperty> isa MAttribute */
+cltype60 = type_model__MAttribute.color;
+idtype61 = type_model__MAttribute.id;
+if(cltype60 >= var_mprop->type->table_size) {
+var59 = 0;
+} else {
+var59 = var_mprop->type->type_table[cltype60] == idtype61;
+}
+if (var59){
+{
+var62 = hash_collection__HashMap___91d_93d(var_mattributes, var_mclass);
+}
+{
+((void (*)(val*, val*))(var62->class->vft[COLOR_abstract_collection__SimpleCollection__add]))(var62, var_mprop) /* add on <var62:nullable Object(Set[MAttribute])>*/;
+}
+} else {
+}
+}
+BREAK_label: (void)0;
+{
+((void (*)(val*))(var_24->class->vft[COLOR_abstract_collection__Iterator__next]))(var_24) /* next on <var_24:Iterator[MProperty]>*/;
+}
+} else {
+goto BREAK_label63;
+}
+}
+BREAK_label63: (void)0;
+{
+{ /* Inline abstract_collection#Iterator#finish (var_24) on <var_24:Iterator[MProperty]> */
+RET_LABEL64:(void)0;
+}
+}
+{
+((void (*)(val*))(var_13->class->vft[COLOR_abstract_collection__Iterator__next]))(var_13) /* next on <var_13:Iterator[MClass]>*/;
+}
+} else {
+goto BREAK_label65;
+}
+}
+BREAK_label65: (void)0;
+{
+{ /* Inline abstract_collection#Iterator#finish (var_13) on <var_13:Iterator[MClass]> */
+RET_LABEL66:(void)0;
+}
+}
+var67 = NEW_hash_collection__HashSet(&type_hash_collection__HashSetmodel__MMethodDef);
+{
+((void (*)(val*))(var67->class->vft[COLOR_kernel__Object__init]))(var67) /* init on <var67:HashSet[MMethodDef]>*/;
+}
+var_all_super_calls = var67;
+{
+{ /* Inline abstract_compiler#AbstractCompiler#mainmodule (self) on <self:SeparateCompiler> */
+var70 = self->attrs[COLOR_abstract_compiler__AbstractCompiler___mainmodule].val; /* _mainmodule on <self:SeparateCompiler> */
+if (unlikely(var70 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _mainmodule");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 463);
+show_backtrace(1);
+}
+var68 = var70;
+RET_LABEL69:(void)0;
+}
+}
+{
+{ /* Inline mmodule#MModule#in_importation (var68) on <var68:MModule> */
+var73 = var68->attrs[COLOR_mmodule__MModule___in_importation].val; /* _in_importation on <var68:MModule> */
+if (unlikely(var73 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _in_importation");
+PRINT_ERROR(" (%s:%d)\n", "model/mmodule.nit", 93);
+show_backtrace(1);
+}
+var71 = var73;
+RET_LABEL72:(void)0;
+}
+}
+{
+var74 = poset__POSetElement__greaters(var71);
+}
+var_75 = var74;
+{
+var76 = ((val* (*)(val*))(var_75->class->vft[COLOR_abstract_collection__Collection__iterator]))(var_75) /* iterator on <var_75:Collection[MModule]>*/;
+}
+var_77 = var76;
+for(;;) {
+{
+var78 = ((short int (*)(val*))(var_77->class->vft[COLOR_abstract_collection__Iterator__is_ok]))(var_77) /* is_ok on <var_77:Iterator[MModule]>*/;
+}
+if (var78){
+{
+var79 = ((val* (*)(val*))(var_77->class->vft[COLOR_abstract_collection__Iterator__item]))(var_77) /* item on <var_77:Iterator[MModule]>*/;
+}
+var_mmodule = var79;
+{
+{ /* Inline model#MModule#mclassdefs (var_mmodule) on <var_mmodule:MModule> */
+var82 = var_mmodule->attrs[COLOR_model__MModule___mclassdefs].val; /* _mclassdefs on <var_mmodule:MModule> */
+if (unlikely(var82 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _mclassdefs");
+PRINT_ERROR(" (%s:%d)\n", "model/model.nit", 139);
+show_backtrace(1);
+}
+var80 = var82;
+RET_LABEL81:(void)0;
+}
+}
+var_83 = var80;
+{
+var84 = array__AbstractArrayRead__iterator(var_83);
+}
+var_85 = var84;
+for(;;) {
+{
+var86 = array__ArrayIterator__is_ok(var_85);
+}
+if (var86){
+{
+var87 = array__ArrayIterator__item(var_85);
+}
+var_mclassdef = var87;
+{
+{ /* Inline model#MClassDef#mpropdefs (var_mclassdef) on <var_mclassdef:MClassDef> */
+var90 = var_mclassdef->attrs[COLOR_model__MClassDef___mpropdefs].val; /* _mpropdefs on <var_mclassdef:MClassDef> */
+if (unlikely(var90 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _mpropdefs");
+PRINT_ERROR(" (%s:%d)\n", "model/model.nit", 591);
+show_backtrace(1);
+}
+var88 = var90;
+RET_LABEL89:(void)0;
+}
+}
+var_91 = var88;
+{
+var92 = array__AbstractArrayRead__iterator(var_91);
+}
+var_93 = var92;
+for(;;) {
+{
+var94 = array__ArrayIterator__is_ok(var_93);
+}
+if (var94){
+{
+var95 = array__ArrayIterator__item(var_93);
+}
+var_mpropdef = var95;
+/* <var_mpropdef:MPropDef> isa MMethodDef */
+cltype97 = type_model__MMethodDef.color;
+idtype98 = type_model__MMethodDef.id;
+if(cltype97 >= var_mpropdef->type->table_size) {
+var96 = 0;
+} else {
+var96 = var_mpropdef->type->type_table[cltype97] == idtype98;
+}
+var99 = !var96;
+if (var99){
+goto BREAK_label100;
+} else {
+}
+{
+{ /* Inline modelize_property#MPropDef#has_supercall (var_mpropdef) on <var_mpropdef:MPropDef(MMethodDef)> */
+var103 = var_mpropdef->attrs[COLOR_modelize_property__MPropDef___has_supercall].s; /* _has_supercall on <var_mpropdef:MPropDef(MMethodDef)> */
+var101 = var103;
+RET_LABEL102:(void)0;
+}
+}
+if (var101){
+{
+hash_collection__HashSet__add(var_all_super_calls, var_mpropdef); /* Direct call hash_collection#HashSet#add on <var_all_super_calls:HashSet[MMethodDef]>*/
+}
+} else {
+}
+BREAK_label100: (void)0;
+{
+array__ArrayIterator__next(var_93); /* Direct call array#ArrayIterator#next on <var_93:ArrayIterator[MPropDef]>*/
+}
+} else {
+goto BREAK_label104;
+}
+}
+BREAK_label104: (void)0;
+{
+{ /* Inline abstract_collection#Iterator#finish (var_93) on <var_93:ArrayIterator[MPropDef]> */
+RET_LABEL105:(void)0;
+}
+}
+{
+array__ArrayIterator__next(var_85); /* Direct call array#ArrayIterator#next on <var_85:ArrayIterator[MClassDef]>*/
+}
+} else {
+goto BREAK_label106;
+}
+}
+BREAK_label106: (void)0;
+{
+{ /* Inline abstract_collection#Iterator#finish (var_85) on <var_85:ArrayIterator[MClassDef]> */
+RET_LABEL107:(void)0;
+}
+}
+{
+((void (*)(val*))(var_77->class->vft[COLOR_abstract_collection__Iterator__next]))(var_77) /* next on <var_77:Iterator[MModule]>*/;
+}
+} else {
+goto BREAK_label108;
+}
+}
+BREAK_label108: (void)0;
+{
+{ /* Inline abstract_collection#Iterator#finish (var_77) on <var_77:Iterator[MModule]> */
+RET_LABEL109:(void)0;
+}
+}
+var110 = NULL;
+if (var_rta == NULL) {
+var111 = 0; /* is null */
+} else {
+var111 = 1; /* arg is null and recv is not */
+}
+if (0) {
+{ /* Inline kernel#Object#!= (var_rta,var110) on <var_rta:nullable RapidTypeAnalysis> */
+var_other = var110;
+{
+var115 = ((short int (*)(val*, val*))(var_rta->class->vft[COLOR_kernel__Object___61d_61d]))(var_rta, var_other) /* == on <var_rta:nullable RapidTypeAnalysis(RapidTypeAnalysis)>*/;
+var114 = var115;
+}
+var116 = !var114;
+var112 = var116;
+goto RET_LABEL113;
+RET_LABEL113:(void)0;
+}
+var111 = var112;
+}
+if (var111){
+{
+{ /* Inline rapid_type_analysis#RapidTypeAnalysis#live_super_sends (var_rta) on <var_rta:nullable RapidTypeAnalysis(RapidTypeAnalysis)> */
+var119 = var_rta->attrs[COLOR_rapid_type_analysis__RapidTypeAnalysis___live_super_sends].val; /* _live_super_sends on <var_rta:nullable RapidTypeAnalysis(RapidTypeAnalysis)> */
+if (unlikely(var119 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _live_super_sends");
+PRINT_ERROR(" (%s:%d)\n", "rapid_type_analysis.nit", 108);
+show_backtrace(1);
+}
+var117 = var119;
+RET_LABEL118:(void)0;
+}
+}
+var_super_calls = var117;
+} else {
+var_super_calls = var_all_super_calls;
+}
+var_120 = var_super_calls;
+{
+var121 = hash_collection__HashSet__iterator(var_120);
+}
+var_122 = var121;
+for(;;) {
+{
+var123 = ((short int (*)(val*))(var_122->class->vft[COLOR_abstract_collection__Iterator__is_ok]))(var_122) /* is_ok on <var_122:Iterator[MMethodDef]>*/;
+}
+if (var123){
+{
+var124 = ((val* (*)(val*))(var_122->class->vft[COLOR_abstract_collection__Iterator__item]))(var_122) /* item on <var_122:Iterator[MMethodDef]>*/;
+}
+var_mmethoddef = var124;
+{
+{ /* Inline model#MPropDef#mclassdef (var_mmethoddef) on <var_mmethoddef:MMethodDef> */
+var127 = var_mmethoddef->attrs[COLOR_model__MPropDef___mclassdef].val; /* _mclassdef on <var_mmethoddef:MMethodDef> */
+if (unlikely(var127 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _mclassdef");
+PRINT_ERROR(" (%s:%d)\n", "model/model.nit", 1895);
+show_backtrace(1);
+}
+var125 = var127;
+RET_LABEL126:(void)0;
+}
+}
+{
+{ /* Inline model#MClassDef#mclass (var125) on <var125:MClassDef> */
+var130 = var125->attrs[COLOR_model__MClassDef___mclass].val; /* _mclass on <var125:MClassDef> */
+if (unlikely(var130 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _mclass");
+PRINT_ERROR(" (%s:%d)\n", "model/model.nit", 492);
+show_backtrace(1);
+}
+var128 = var130;
+RET_LABEL129:(void)0;
+}
+}
+var_mclass131 = var128;
+{
+var132 = hash_collection__HashMap___91d_93d(var_mmethods, var_mclass131);
+}
+{
+((void (*)(val*, val*))(var132->class->vft[COLOR_abstract_collection__SimpleCollection__add]))(var132, var_mmethoddef) /* add on <var132:nullable Object(Set[PropertyLayoutElement])>*/;
+}
+{
+{ /* Inline abstract_compiler#AbstractCompiler#mainmodule (self) on <self:SeparateCompiler> */
+var135 = self->attrs[COLOR_abstract_compiler__AbstractCompiler___mainmodule].val; /* _mainmodule on <self:SeparateCompiler> */
+if (unlikely(var135 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _mainmodule");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 463);
+show_backtrace(1);
+}
+var133 = var135;
+RET_LABEL134:(void)0;
+}
+}
+{
+var136 = model__MClass__in_hierarchy(var_mclass131, var133);
+}
+{
+var137 = poset__POSetElement__smallers(var136);
+}
+var_138 = var137;
+{
+var139 = ((val* (*)(val*))(var_138->class->vft[COLOR_abstract_collection__Collection__iterator]))(var_138) /* iterator on <var_138:Collection[MClass]>*/;
+}
+var_140 = var139;
+for(;;) {
+{
+var141 = ((short int (*)(val*))(var_140->class->vft[COLOR_abstract_collection__Iterator__is_ok]))(var_140) /* is_ok on <var_140:Iterator[MClass]>*/;
+}
+if (var141){
+{
+var142 = ((val* (*)(val*))(var_140->class->vft[COLOR_abstract_collection__Iterator__item]))(var_140) /* item on <var_140:Iterator[MClass]>*/;
+}
+var_descendant = var142;
+{
+var143 = hash_collection__HashMap___91d_93d(var_mmethods, var_descendant);
+}
+{
+((void (*)(val*, val*))(var143->class->vft[COLOR_abstract_collection__SimpleCollection__add]))(var143, var_mmethoddef) /* add on <var143:nullable Object(Set[PropertyLayoutElement])>*/;
+}
+{
+((void (*)(val*))(var_140->class->vft[COLOR_abstract_collection__Iterator__next]))(var_140) /* next on <var_140:Iterator[MClass]>*/;