update NOTICE
[nit.git] / c_src / abstract_compiler.sep.2.c
index 802a1b6..6520256 100644 (file)
 #include "abstract_compiler.sep.0.h"
-/* method abstract_compiler#AbstractCompilerVisitor#debug for (self: AbstractCompilerVisitor, String) */
-void abstract_compiler__AbstractCompilerVisitor__debug(val* self, val* p0) {
-val* var_message /* var message: String */;
-val* var /* : nullable ANode */;
-val* var_node /* var node: nullable ANode */;
-val* var1 /* : null */;
-short int var2 /* : Bool */;
+/* method abstract_compiler#AbstractCompiler#compile_main_function for (self: AbstractCompiler) */
+void abstract_compiler__AbstractCompiler__compile_main_function(val* self) {
+val* var /* : AbstractCompilerVisitor */;
+val* var_v /* var v: AbstractCompilerVisitor */;
 static val* varonce;
-val* var3 /* : String */;
-char* var4 /* : NativeString */;
-long var5 /* : Int */;
-val* var6 /* : String */;
-val* var7 /* : Array[Object] */;
-long var8 /* : Int */;
-val* var9 /* : NativeArray[Object] */;
-val* var10 /* : String */;
-static val* varonce11;
-val* var12 /* : String */;
-char* var13 /* : NativeString */;
-long var14 /* : Int */;
-val* var15 /* : String */;
-static val* varonce16;
-val* var17 /* : String */;
-char* var18 /* : NativeString */;
-long var19 /* : Int */;
-val* var20 /* : String */;
-val* var21 /* : Array[Object] */;
-long var22 /* : Int */;
-val* var23 /* : NativeArray[Object] */;
-val* var24 /* : String */;
-var_message = p0;
-var = ((val* (*)(val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__current_node]))(self) /* current_node on <self:AbstractCompilerVisitor>*/;
-var_node = var;
-var1 = NULL;
-if (var_node == NULL) {
-var2 = 1; /* is null */
+val* var1 /* : String */;
+char* var2 /* : NativeString */;
+long var3 /* : Int */;
+val* var4 /* : FlatString */;
+val* var5 /* : ModelBuilder */;
+val* var7 /* : ModelBuilder */;
+val* var8 /* : ToolContext */;
+val* var10 /* : ToolContext */;
+val* var11 /* : OptionString */;
+val* var13 /* : OptionString */;
+val* var14 /* : nullable Object */;
+val* var16 /* : nullable Object */;
+val* var_ost /* var ost: nullable String */;
+val* var17 /* : MModule */;
+val* var19 /* : MModule */;
+val* var20 /* : nullable Platform */;
+val* var_platform /* var platform: nullable Platform */;
+short int var21 /* : Bool */;
+val* var22 /* : null */;
+short int var23 /* : Bool */;
+short int var24 /* : Bool */;
+short int var_ /* var : Bool */;
+short int var25 /* : Bool */;
+short int var26 /* : Bool */;
+static val* varonce27;
+val* var28 /* : String */;
+char* var29 /* : NativeString */;
+long var30 /* : Int */;
+val* var31 /* : FlatString */;
+short int var32 /* : Bool */;
+short int var33 /* : Bool */;
+val* var34 /* : null */;
+short int var35 /* : Bool */;
+short int var36 /* : Bool */;
+short int var_37 /* var : Bool */;
+short int var38 /* : Bool */;
+short int var_39 /* var : Bool */;
+val* var40 /* : ModelBuilder */;
+val* var42 /* : ModelBuilder */;
+val* var43 /* : ToolContext */;
+val* var45 /* : ToolContext */;
+val* var46 /* : OptionBool */;
+val* var48 /* : OptionBool */;
+val* var49 /* : nullable Object */;
+val* var51 /* : nullable Object */;
+short int var52 /* : Bool */;
+short int var_no_main /* var no_main: Bool */;
+short int var53 /* : Bool */;
+static val* varonce54;
+val* var55 /* : String */;
+char* var56 /* : NativeString */;
+long var57 /* : Int */;
+val* var58 /* : FlatString */;
+short int var59 /* : Bool */;
+short int var60 /* : Bool */;
+short int var_61 /* var : Bool */;
+static val* varonce62;
+val* var63 /* : String */;
+char* var64 /* : NativeString */;
+long var65 /* : Int */;
+val* var66 /* : FlatString */;
+short int var67 /* : Bool */;
+short int var68 /* : Bool */;
+static val* varonce69;
+val* var70 /* : String */;
+char* var71 /* : NativeString */;
+long var72 /* : Int */;
+val* var73 /* : FlatString */;
+static val* varonce74;
+val* var75 /* : String */;
+char* var76 /* : NativeString */;
+long var77 /* : Int */;
+val* var78 /* : FlatString */;
+static val* varonce79;
+val* var80 /* : String */;
+char* var81 /* : NativeString */;
+long var82 /* : Int */;
+val* var83 /* : FlatString */;
+short int var84 /* : Bool */;
+short int var85 /* : Bool */;
+static val* varonce86;
+val* var87 /* : String */;
+char* var88 /* : NativeString */;
+long var89 /* : Int */;
+val* var90 /* : FlatString */;
+static val* varonce91;
+val* var92 /* : String */;
+char* var93 /* : NativeString */;
+long var94 /* : Int */;
+val* var95 /* : FlatString */;
+static val* varonce96;
+val* var97 /* : String */;
+char* var98 /* : NativeString */;
+long var99 /* : Int */;
+val* var100 /* : FlatString */;
+static val* varonce101;
+val* var102 /* : String */;
+char* var103 /* : NativeString */;
+long var104 /* : Int */;
+val* var105 /* : FlatString */;
+val* var106 /* : ModelBuilder */;
+val* var108 /* : ModelBuilder */;
+val* var109 /* : ToolContext */;
+val* var111 /* : ToolContext */;
+val* var112 /* : OptionBool */;
+val* var114 /* : OptionBool */;
+val* var115 /* : nullable Object */;
+val* var117 /* : nullable Object */;
+short int var118 /* : Bool */;
+val* var119 /* : Array[String] */;
+val* var121 /* : Array[String] */;
+val* var_122 /* var : Array[String] */;
+val* var123 /* : ArrayIterator[nullable Object] */;
+val* var_124 /* var : ArrayIterator[String] */;
+short int var125 /* : Bool */;
+val* var126 /* : nullable Object */;
+val* var_tag /* var tag: String */;
+static val* varonce127;
+val* var128 /* : String */;
+char* var129 /* : NativeString */;
+long var130 /* : Int */;
+val* var131 /* : FlatString */;
+static val* varonce132;
+val* var133 /* : String */;
+char* var134 /* : NativeString */;
+long var135 /* : Int */;
+val* var136 /* : FlatString */;
+val* var137 /* : Array[Object] */;
+long var138 /* : Int */;
+val* var139 /* : NativeArray[Object] */;
+val* var140 /* : String */;
+static val* varonce141;
+val* var142 /* : String */;
+char* var143 /* : NativeString */;
+long var144 /* : Int */;
+val* var145 /* : FlatString */;
+static val* varonce146;
+val* var147 /* : String */;
+char* var148 /* : NativeString */;
+long var149 /* : Int */;
+val* var150 /* : FlatString */;
+val* var151 /* : Array[Object] */;
+long var152 /* : Int */;
+val* var153 /* : NativeArray[Object] */;
+val* var154 /* : String */;
+static val* varonce155;
+val* var156 /* : String */;
+char* var157 /* : NativeString */;
+long var158 /* : Int */;
+val* var159 /* : FlatString */;
+static val* varonce160;
+val* var161 /* : String */;
+char* var162 /* : NativeString */;
+long var163 /* : Int */;
+val* var164 /* : FlatString */;
+val* var165 /* : Array[Object] */;
+long var166 /* : Int */;
+val* var167 /* : NativeArray[Object] */;
+val* var168 /* : String */;
+val* var169 /* : AbstractCompiler */;
+val* var171 /* : AbstractCompiler */;
+val* var172 /* : CodeWriter */;
+val* var174 /* : CodeWriter */;
+static val* varonce175;
+val* var176 /* : String */;
+char* var177 /* : NativeString */;
+long var178 /* : Int */;
+val* var179 /* : FlatString */;
+static val* varonce180;
+val* var181 /* : String */;
+char* var182 /* : NativeString */;
+long var183 /* : Int */;
+val* var184 /* : FlatString */;
+val* var185 /* : Array[Object] */;
+long var186 /* : Int */;
+val* var187 /* : NativeArray[Object] */;
+val* var188 /* : String */;
+val* var189 /* : AbstractCompiler */;
+val* var191 /* : AbstractCompiler */;
+val* var192 /* : CodeWriter */;
+val* var194 /* : CodeWriter */;
+static val* varonce195;
+val* var196 /* : String */;
+char* var197 /* : NativeString */;
+long var198 /* : Int */;
+val* var199 /* : FlatString */;
+static val* varonce200;
+val* var201 /* : String */;
+char* var202 /* : NativeString */;
+long var203 /* : Int */;
+val* var204 /* : FlatString */;
+val* var205 /* : Array[Object] */;
+long var206 /* : Int */;
+val* var207 /* : NativeArray[Object] */;
+val* var208 /* : String */;
+val* var209 /* : AbstractCompiler */;
+val* var211 /* : AbstractCompiler */;
+val* var212 /* : CodeWriter */;
+val* var214 /* : CodeWriter */;
+static val* varonce215;
+val* var216 /* : String */;
+char* var217 /* : NativeString */;
+long var218 /* : Int */;
+val* var219 /* : FlatString */;
+static val* varonce220;
+val* var221 /* : String */;
+char* var222 /* : NativeString */;
+long var223 /* : Int */;
+val* var224 /* : FlatString */;
+val* var225 /* : Array[Object] */;
+long var226 /* : Int */;
+val* var227 /* : NativeArray[Object] */;
+val* var228 /* : String */;
+val* var230 /* : ModelBuilder */;
+val* var232 /* : ModelBuilder */;
+val* var233 /* : ToolContext */;
+val* var235 /* : ToolContext */;
+val* var236 /* : OptionBool */;
+val* var238 /* : OptionBool */;
+val* var239 /* : nullable Object */;
+val* var241 /* : nullable Object */;
+short int var242 /* : Bool */;
+static val* varonce243;
+val* var244 /* : String */;
+char* var245 /* : NativeString */;
+long var246 /* : Int */;
+val* var247 /* : FlatString */;
+static val* varonce248;
+val* var249 /* : String */;
+char* var250 /* : NativeString */;
+long var251 /* : Int */;
+val* var252 /* : FlatString */;
+static val* varonce253;
+val* var254 /* : String */;
+char* var255 /* : NativeString */;
+long var256 /* : Int */;
+val* var257 /* : FlatString */;
+val* var258 /* : AbstractCompiler */;
+val* var260 /* : AbstractCompiler */;
+val* var261 /* : CodeWriter */;
+val* var263 /* : CodeWriter */;
+static val* varonce264;
+val* var265 /* : String */;
+char* var266 /* : NativeString */;
+long var267 /* : Int */;
+val* var268 /* : FlatString */;
+val* var269 /* : AbstractCompiler */;
+val* var271 /* : AbstractCompiler */;
+val* var272 /* : CodeWriter */;
+val* var274 /* : CodeWriter */;
+static val* varonce275;
+val* var276 /* : String */;
+char* var277 /* : NativeString */;
+long var278 /* : Int */;
+val* var279 /* : FlatString */;
+val* var280 /* : AbstractCompiler */;
+val* var282 /* : AbstractCompiler */;
+val* var283 /* : CodeWriter */;
+val* var285 /* : CodeWriter */;
+static val* varonce286;
+val* var287 /* : String */;
+char* var288 /* : NativeString */;
+long var289 /* : Int */;
+val* var290 /* : FlatString */;
+val* var291 /* : ModelBuilder */;
+val* var293 /* : ModelBuilder */;
+val* var294 /* : ToolContext */;
+val* var296 /* : ToolContext */;
+val* var297 /* : OptionBool */;
+val* var299 /* : OptionBool */;
+val* var300 /* : nullable Object */;
+val* var302 /* : nullable Object */;
+short int var303 /* : Bool */;
+static val* varonce304;
+val* var305 /* : String */;
+char* var306 /* : NativeString */;
+long var307 /* : Int */;
+val* var308 /* : FlatString */;
+static val* varonce309;
+val* var310 /* : String */;
+char* var311 /* : NativeString */;
+long var312 /* : Int */;
+val* var313 /* : FlatString */;
+val* var314 /* : AbstractCompiler */;
+val* var316 /* : AbstractCompiler */;
+val* var317 /* : CodeWriter */;
+val* var319 /* : CodeWriter */;
+static val* varonce320;
+val* var321 /* : String */;
+char* var322 /* : NativeString */;
+long var323 /* : Int */;
+val* var324 /* : FlatString */;
+val* var325 /* : AbstractCompiler */;
+val* var327 /* : AbstractCompiler */;
+val* var328 /* : CodeWriter */;
+val* var330 /* : CodeWriter */;
+static val* varonce331;
+val* var332 /* : String */;
+char* var333 /* : NativeString */;
+long var334 /* : Int */;
+val* var335 /* : FlatString */;
+static val* varonce336;
+val* var337 /* : String */;
+char* var338 /* : NativeString */;
+long var339 /* : Int */;
+val* var340 /* : FlatString */;
+static val* varonce341;
+val* var342 /* : String */;
+char* var343 /* : NativeString */;
+long var344 /* : Int */;
+val* var345 /* : FlatString */;
+static val* varonce346;
+val* var347 /* : String */;
+char* var348 /* : NativeString */;
+long var349 /* : Int */;
+val* var350 /* : FlatString */;
+static val* varonce351;
+val* var352 /* : String */;
+char* var353 /* : NativeString */;
+long var354 /* : Int */;
+val* var355 /* : FlatString */;
+static val* varonce356;
+val* var357 /* : String */;
+char* var358 /* : NativeString */;
+long var359 /* : Int */;
+val* var360 /* : FlatString */;
+short int var361 /* : Bool */;
+static val* varonce362;
+val* var363 /* : String */;
+char* var364 /* : NativeString */;
+long var365 /* : Int */;
+val* var366 /* : FlatString */;
+short int var367 /* : Bool */;
+short int var368 /* : Bool */;
+short int var_369 /* var : Bool */;
+static val* varonce370;
+val* var371 /* : String */;
+char* var372 /* : NativeString */;
+long var373 /* : Int */;
+val* var374 /* : FlatString */;
+short int var375 /* : Bool */;
+short int var376 /* : Bool */;
+static val* varonce377;
+val* var378 /* : String */;
+char* var379 /* : NativeString */;
+long var380 /* : Int */;
+val* var381 /* : FlatString */;
+static val* varonce382;
+val* var383 /* : String */;
+char* var384 /* : NativeString */;
+long var385 /* : Int */;
+val* var386 /* : FlatString */;
+static val* varonce387;
+val* var388 /* : String */;
+char* var389 /* : NativeString */;
+long var390 /* : Int */;
+val* var391 /* : FlatString */;
+static val* varonce392;
+val* var393 /* : String */;
+char* var394 /* : NativeString */;
+long var395 /* : Int */;
+val* var396 /* : FlatString */;
+static val* varonce397;
+val* var398 /* : String */;
+char* var399 /* : NativeString */;
+long var400 /* : Int */;
+val* var401 /* : FlatString */;
+static val* varonce402;
+val* var403 /* : String */;
+char* var404 /* : NativeString */;
+long var405 /* : Int */;
+val* var406 /* : FlatString */;
+static val* varonce407;
+val* var408 /* : String */;
+char* var409 /* : NativeString */;
+long var410 /* : Int */;
+val* var411 /* : FlatString */;
+static val* varonce412;
+val* var413 /* : String */;
+char* var414 /* : NativeString */;
+long var415 /* : Int */;
+val* var416 /* : FlatString */;
+static val* varonce417;
+val* var418 /* : String */;
+char* var419 /* : NativeString */;
+long var420 /* : Int */;
+val* var421 /* : FlatString */;
+static val* varonce422;
+val* var423 /* : String */;
+char* var424 /* : NativeString */;
+long var425 /* : Int */;
+val* var426 /* : FlatString */;
+static val* varonce427;
+val* var428 /* : String */;
+char* var429 /* : NativeString */;
+long var430 /* : Int */;
+val* var431 /* : FlatString */;
+static val* varonce432;
+val* var433 /* : String */;
+char* var434 /* : NativeString */;
+long var435 /* : Int */;
+val* var436 /* : FlatString */;
+static val* varonce437;
+val* var438 /* : String */;
+char* var439 /* : NativeString */;
+long var440 /* : Int */;
+val* var441 /* : FlatString */;
+static val* varonce442;
+val* var443 /* : String */;
+char* var444 /* : NativeString */;
+long var445 /* : Int */;
+val* var446 /* : FlatString */;
+short int var447 /* : Bool */;
+short int var448 /* : Bool */;
+static val* varonce449;
+val* var450 /* : String */;
+char* var451 /* : NativeString */;
+long var452 /* : Int */;
+val* var453 /* : FlatString */;
+static val* varonce454;
+val* var455 /* : String */;
+char* var456 /* : NativeString */;
+long var457 /* : Int */;
+val* var458 /* : FlatString */;
+static val* varonce459;
+val* var460 /* : String */;
+char* var461 /* : NativeString */;
+long var462 /* : Int */;
+val* var463 /* : FlatString */;
+static val* varonce464;
+val* var465 /* : String */;
+char* var466 /* : NativeString */;
+long var467 /* : Int */;
+val* var468 /* : FlatString */;
+static val* varonce469;
+val* var470 /* : String */;
+char* var471 /* : NativeString */;
+long var472 /* : Int */;
+val* var473 /* : FlatString */;
+static val* varonce474;
+val* var475 /* : String */;
+char* var476 /* : NativeString */;
+long var477 /* : Int */;
+val* var478 /* : FlatString */;
+static val* varonce479;
+val* var480 /* : String */;
+char* var481 /* : NativeString */;
+long var482 /* : Int */;
+val* var483 /* : FlatString */;
+static val* varonce484;
+val* var485 /* : String */;
+char* var486 /* : NativeString */;
+long var487 /* : Int */;
+val* var488 /* : FlatString */;
+static val* varonce489;
+val* var490 /* : String */;
+char* var491 /* : NativeString */;
+long var492 /* : Int */;
+val* var493 /* : FlatString */;
+static val* varonce494;
+val* var495 /* : String */;
+char* var496 /* : NativeString */;
+long var497 /* : Int */;
+val* var498 /* : FlatString */;
+static val* varonce499;
+val* var500 /* : String */;
+char* var501 /* : NativeString */;
+long var502 /* : Int */;
+val* var503 /* : FlatString */;
+static val* varonce504;
+val* var505 /* : String */;
+char* var506 /* : NativeString */;
+long var507 /* : Int */;
+val* var508 /* : FlatString */;
+static val* varonce509;
+val* var510 /* : String */;
+char* var511 /* : NativeString */;
+long var512 /* : Int */;
+val* var513 /* : FlatString */;
+static val* varonce514;
+val* var515 /* : String */;
+char* var516 /* : NativeString */;
+long var517 /* : Int */;
+val* var518 /* : FlatString */;
+static val* varonce519;
+val* var520 /* : String */;
+char* var521 /* : NativeString */;
+long var522 /* : Int */;
+val* var523 /* : FlatString */;
+static val* varonce524;
+val* var525 /* : String */;
+char* var526 /* : NativeString */;
+long var527 /* : Int */;
+val* var528 /* : FlatString */;
+static val* varonce529;
+val* var530 /* : String */;
+char* var531 /* : NativeString */;
+long var532 /* : Int */;
+val* var533 /* : FlatString */;
+static val* varonce534;
+val* var535 /* : String */;
+char* var536 /* : NativeString */;
+long var537 /* : Int */;
+val* var538 /* : FlatString */;
+static val* varonce539;
+val* var540 /* : String */;
+char* var541 /* : NativeString */;
+long var542 /* : Int */;
+val* var543 /* : FlatString */;
+static val* varonce544;
+val* var545 /* : String */;
+char* var546 /* : NativeString */;
+long var547 /* : Int */;
+val* var548 /* : FlatString */;
+static val* varonce549;
+val* var550 /* : String */;
+char* var551 /* : NativeString */;
+long var552 /* : Int */;
+val* var553 /* : FlatString */;
+static val* varonce554;
+val* var555 /* : String */;
+char* var556 /* : NativeString */;
+long var557 /* : Int */;
+val* var558 /* : FlatString */;
+static val* varonce559;
+val* var560 /* : String */;
+char* var561 /* : NativeString */;
+long var562 /* : Int */;
+val* var563 /* : FlatString */;
+static val* varonce564;
+val* var565 /* : String */;
+char* var566 /* : NativeString */;
+long var567 /* : Int */;
+val* var568 /* : FlatString */;
+static val* varonce569;
+val* var570 /* : String */;
+char* var571 /* : NativeString */;
+long var572 /* : Int */;
+val* var573 /* : FlatString */;
+val* var574 /* : MModule */;
+val* var576 /* : MModule */;
+val* var577 /* : nullable MClassType */;
+val* var_main_type /* var main_type: nullable MClassType */;
+val* var578 /* : null */;
+short int var579 /* : Bool */;
+short int var580 /* : Bool */;
+val* var_other /* var other: nullable Object */;
+short int var582 /* : Bool */;
+short int var583 /* : Bool */;
+short int var584 /* : Bool */;
+val* var585 /* : AbstractCompiler */;
+val* var587 /* : AbstractCompiler */;
+val* var588 /* : MModule */;
+val* var590 /* : MModule */;
+val* var_mainmodule /* var mainmodule: MModule */;
+val* var591 /* : RuntimeVariable */;
+val* var_glob_sys /* var glob_sys: RuntimeVariable */;
+static val* varonce592;
+val* var593 /* : String */;
+char* var594 /* : NativeString */;
+long var595 /* : Int */;
+val* var596 /* : FlatString */;
+static val* varonce597;
+val* var598 /* : String */;
+char* var599 /* : NativeString */;
+long var600 /* : Int */;
+val* var601 /* : FlatString */;
+val* var602 /* : Array[Object] */;
+long var603 /* : Int */;
+val* var604 /* : NativeArray[Object] */;
+val* var605 /* : String */;
+static val* varonce606;
+val* var607 /* : String */;
+char* var608 /* : NativeString */;
+long var609 /* : Int */;
+val* var610 /* : FlatString */;
+val* var611 /* : MClass */;
+val* var613 /* : MClass */;
+val* var614 /* : nullable MMethod */;
+val* var_main_init /* var main_init: nullable MMethod */;
+val* var615 /* : null */;
+short int var616 /* : Bool */;
+short int var617 /* : Bool */;
+short int var619 /* : Bool */;
+short int var620 /* : Bool */;
+short int var621 /* : Bool */;
+val* var622 /* : Array[RuntimeVariable] */;
+long var623 /* : Int */;
+val* var_624 /* var : Array[RuntimeVariable] */;
+val* var625 /* : nullable RuntimeVariable */;
+val* var626 /* : nullable MMethod */;
+static val* varonce627;
+val* var628 /* : String */;
+char* var629 /* : NativeString */;
+long var630 /* : Int */;
+val* var631 /* : FlatString */;
+val* var632 /* : MClass */;
+val* var634 /* : MClass */;
+val* var635 /* : nullable MMethod */;
+static val* varonce636;
+val* var637 /* : String */;
+char* var638 /* : NativeString */;
+long var639 /* : Int */;
+val* var640 /* : FlatString */;
+val* var641 /* : MClass */;
+val* var643 /* : MClass */;
+val* var644 /* : nullable MMethod */;
+val* var_main_method /* var main_method: nullable MMethod */;
+val* var645 /* : null */;
+short int var646 /* : Bool */;
+short int var647 /* : Bool */;
+short int var649 /* : Bool */;
+short int var650 /* : Bool */;
+short int var651 /* : Bool */;
+val* var652 /* : Array[RuntimeVariable] */;
+long var653 /* : Int */;
+val* var_654 /* var : Array[RuntimeVariable] */;
+val* var655 /* : nullable RuntimeVariable */;
+val* var656 /* : ModelBuilder */;
+val* var658 /* : ModelBuilder */;
+val* var659 /* : ToolContext */;
+val* var661 /* : ToolContext */;
+val* var662 /* : OptionBool */;
+val* var664 /* : OptionBool */;
+val* var665 /* : nullable Object */;
+val* var667 /* : nullable Object */;
+short int var668 /* : Bool */;
+static val* varonce669;
+val* var670 /* : String */;
+char* var671 /* : NativeString */;
+long var672 /* : Int */;
+val* var673 /* : FlatString */;
+static val* varonce674;
+val* var675 /* : String */;
+char* var676 /* : NativeString */;
+long var677 /* : Int */;
+val* var678 /* : FlatString */;
+static val* varonce679;
+val* var680 /* : String */;
+char* var681 /* : NativeString */;
+long var682 /* : Int */;
+val* var683 /* : FlatString */;
+static val* varonce684;
+val* var685 /* : String */;
+char* var686 /* : NativeString */;
+long var687 /* : Int */;
+val* var688 /* : FlatString */;
+val* var689 /* : Array[String] */;
+val* var691 /* : Array[String] */;
+val* var_692 /* var : Array[String] */;
+val* var693 /* : ArrayIterator[nullable Object] */;
+val* var_694 /* var : ArrayIterator[String] */;
+short int var695 /* : Bool */;
+val* var696 /* : nullable Object */;
+val* var_tag697 /* var tag: String */;
+static val* varonce698;
+val* var699 /* : String */;
+char* var700 /* : NativeString */;
+long var701 /* : Int */;
+val* var702 /* : FlatString */;
+static val* varonce703;
+val* var704 /* : String */;
+char* var705 /* : NativeString */;
+long var706 /* : Int */;
+val* var707 /* : FlatString */;
+val* var708 /* : Array[Object] */;
+long var709 /* : Int */;
+val* var710 /* : NativeArray[Object] */;
+val* var711 /* : String */;
+static val* varonce712;
+val* var713 /* : String */;
+char* var714 /* : NativeString */;
+long var715 /* : Int */;
+val* var716 /* : FlatString */;
+static val* varonce717;
+val* var718 /* : String */;
+char* var719 /* : NativeString */;
+long var720 /* : Int */;
+val* var721 /* : FlatString */;
+static val* varonce722;
+val* var723 /* : String */;
+char* var724 /* : NativeString */;
+long var725 /* : Int */;
+val* var726 /* : FlatString */;
+static val* varonce727;
+val* var728 /* : String */;
+char* var729 /* : NativeString */;
+long var730 /* : Int */;
+val* var731 /* : FlatString */;
+static val* varonce732;
+val* var733 /* : String */;
+char* var734 /* : NativeString */;
+long var735 /* : Int */;
+val* var736 /* : FlatString */;
+val* var737 /* : Array[Object] */;
+long var738 /* : Int */;
+val* var739 /* : NativeArray[Object] */;
+val* var740 /* : String */;
+static val* varonce741;
+val* var742 /* : String */;
+char* var743 /* : NativeString */;
+long var744 /* : Int */;
+val* var745 /* : FlatString */;
+static val* varonce746;
+val* var747 /* : String */;
+char* var748 /* : NativeString */;
+long var749 /* : Int */;
+val* var750 /* : FlatString */;
+val* var751 /* : Array[Object] */;
+long var752 /* : Int */;
+val* var753 /* : NativeArray[Object] */;
+val* var754 /* : String */;
+static val* varonce755;
+val* var756 /* : String */;
+char* var757 /* : NativeString */;
+long var758 /* : Int */;
+val* var759 /* : FlatString */;
+static val* varonce760;
+val* var761 /* : String */;
+char* var762 /* : NativeString */;
+long var763 /* : Int */;
+val* var764 /* : FlatString */;
+val* var765 /* : Array[Object] */;
+long var766 /* : Int */;
+val* var767 /* : NativeArray[Object] */;
+val* var768 /* : String */;
+static val* varonce769;
+val* var770 /* : String */;
+char* var771 /* : NativeString */;
+long var772 /* : Int */;
+val* var773 /* : FlatString */;
+static val* varonce774;
+val* var775 /* : String */;
+char* var776 /* : NativeString */;
+long var777 /* : Int */;
+val* var778 /* : FlatString */;
+val* var779 /* : Array[Object] */;
+long var780 /* : Int */;
+val* var781 /* : NativeArray[Object] */;
+val* var782 /* : String */;
+static val* varonce783;
+val* var784 /* : String */;
+char* var785 /* : NativeString */;
+long var786 /* : Int */;
+val* var787 /* : FlatString */;
+static val* varonce788;
+val* var789 /* : String */;
+char* var790 /* : NativeString */;
+long var791 /* : Int */;
+val* var792 /* : FlatString */;
+val* var793 /* : Array[Object] */;
+long var794 /* : Int */;
+val* var795 /* : NativeArray[Object] */;
+val* var796 /* : String */;
+static val* varonce799;
+val* var800 /* : String */;
+char* var801 /* : NativeString */;
+long var802 /* : Int */;
+val* var803 /* : FlatString */;
+static val* varonce804;
+val* var805 /* : String */;
+char* var806 /* : NativeString */;
+long var807 /* : Int */;
+val* var808 /* : FlatString */;
+val* var809 /* : Array[String] */;
+val* var811 /* : Array[String] */;
+val* var812 /* : Array[nullable Object] */;
+val* var_tags /* var tags: Array[String] */;
+static val* varonce813;
+val* var814 /* : String */;
+char* var815 /* : NativeString */;
+long var816 /* : Int */;
+val* var817 /* : FlatString */;
+val* var_818 /* var : Array[String] */;
+val* var819 /* : ArrayIterator[nullable Object] */;
+val* var_820 /* var : ArrayIterator[String] */;
+short int var821 /* : Bool */;
+val* var822 /* : nullable Object */;
+val* var_tag823 /* var tag: String */;
+static val* varonce824;
+val* var825 /* : String */;
+char* var826 /* : NativeString */;
+long var827 /* : Int */;
+val* var828 /* : FlatString */;
+static val* varonce829;
+val* var830 /* : String */;
+char* var831 /* : NativeString */;
+long var832 /* : Int */;
+val* var833 /* : FlatString */;
+val* var834 /* : Array[Object] */;
+long var835 /* : Int */;
+val* var836 /* : NativeArray[Object] */;
+val* var837 /* : String */;
+static val* varonce838;
+val* var839 /* : String */;
+char* var840 /* : NativeString */;
+long var841 /* : Int */;
+val* var842 /* : FlatString */;
+static val* varonce843;
+val* var844 /* : String */;
+char* var845 /* : NativeString */;
+long var846 /* : Int */;
+val* var847 /* : FlatString */;
+static val* varonce848;
+val* var849 /* : String */;
+char* var850 /* : NativeString */;
+long var851 /* : Int */;
+val* var852 /* : FlatString */;
+val* var853 /* : Array[Object] */;
+long var854 /* : Int */;
+val* var855 /* : NativeArray[Object] */;
+val* var856 /* : String */;
+static val* varonce857;
+val* var858 /* : String */;
+char* var859 /* : NativeString */;
+long var860 /* : Int */;
+val* var861 /* : FlatString */;
+static val* varonce862;
+val* var863 /* : String */;
+char* var864 /* : NativeString */;
+long var865 /* : Int */;
+val* var866 /* : FlatString */;
+static val* varonce867;
+val* var868 /* : String */;
+char* var869 /* : NativeString */;
+long var870 /* : Int */;
+val* var871 /* : FlatString */;
+val* var872 /* : Array[Object] */;
+long var873 /* : Int */;
+val* var874 /* : NativeArray[Object] */;
+val* var875 /* : String */;
+static val* varonce876;
+val* var877 /* : String */;
+char* var878 /* : NativeString */;
+long var879 /* : Int */;
+val* var880 /* : FlatString */;
+static val* varonce881;
+val* var882 /* : String */;
+char* var883 /* : NativeString */;
+long var884 /* : Int */;
+val* var885 /* : FlatString */;
+static val* varonce886;
+val* var887 /* : String */;
+char* var888 /* : NativeString */;
+long var889 /* : Int */;
+val* var890 /* : FlatString */;
+val* var891 /* : Array[Object] */;
+long var892 /* : Int */;
+val* var893 /* : NativeArray[Object] */;
+val* var894 /* : String */;
+static val* varonce895;
+val* var896 /* : String */;
+char* var897 /* : NativeString */;
+long var898 /* : Int */;
+val* var899 /* : FlatString */;
+static val* varonce900;
+val* var901 /* : String */;
+char* var902 /* : NativeString */;
+long var903 /* : Int */;
+val* var904 /* : FlatString */;
+static val* varonce905;
+val* var906 /* : String */;
+char* var907 /* : NativeString */;
+long var908 /* : Int */;
+val* var909 /* : FlatString */;
+val* var910 /* : Array[Object] */;
+long var911 /* : Int */;
+val* var912 /* : NativeArray[Object] */;
+val* var913 /* : String */;
+val* var916 /* : ModelBuilder */;
+val* var918 /* : ModelBuilder */;
+val* var919 /* : ToolContext */;
+val* var921 /* : ToolContext */;
+val* var922 /* : OptionBool */;
+val* var924 /* : OptionBool */;
+val* var925 /* : nullable Object */;
+val* var927 /* : nullable Object */;
+short int var928 /* : Bool */;
+static val* varonce929;
+val* var930 /* : String */;
+char* var931 /* : NativeString */;
+long var932 /* : Int */;
+val* var933 /* : FlatString */;
+static val* varonce934;
+val* var935 /* : String */;
+char* var936 /* : NativeString */;
+long var937 /* : Int */;
+val* var938 /* : FlatString */;
+static val* varonce939;
+val* var940 /* : String */;
+char* var941 /* : NativeString */;
+long var942 /* : Int */;
+val* var943 /* : FlatString */;
+static val* varonce944;
+val* var945 /* : String */;
+char* var946 /* : NativeString */;
+long var947 /* : Int */;
+val* var948 /* : FlatString */;
+static val* varonce949;
+val* var950 /* : String */;
+char* var951 /* : NativeString */;
+long var952 /* : Int */;
+val* var953 /* : FlatString */;
+static val* varonce954;
+val* var955 /* : String */;
+char* var956 /* : NativeString */;
+long var957 /* : Int */;
+val* var958 /* : FlatString */;
+val* var959 /* : ModelBuilder */;
+val* var961 /* : ModelBuilder */;
+val* var962 /* : ToolContext */;
+val* var964 /* : ToolContext */;
+val* var965 /* : OptionBool */;
+val* var967 /* : OptionBool */;
+val* var968 /* : nullable Object */;
+val* var970 /* : nullable Object */;
+short int var971 /* : Bool */;
+static val* varonce972;
+val* var973 /* : String */;
+char* var974 /* : NativeString */;
+long var975 /* : Int */;
+val* var976 /* : FlatString */;
+static val* varonce977;
+val* var978 /* : String */;
+char* var979 /* : NativeString */;
+long var980 /* : Int */;
+val* var981 /* : FlatString */;
+static val* varonce982;
+val* var983 /* : String */;
+char* var984 /* : NativeString */;
+long var985 /* : Int */;
+val* var986 /* : FlatString */;
+static val* varonce987;
+val* var988 /* : String */;
+char* var989 /* : NativeString */;
+long var990 /* : Int */;
+val* var991 /* : FlatString */;
+{
+var = ((val* (*)(val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompiler__new_visitor]))(self) /* new_visitor on <self:AbstractCompiler>*/;
+}
+var_v = var;
+if (varonce) {
+var1 = varonce;
+} else {
+var2 = "#include <signal.h>";
+var3 = 19;
+var4 = string__NativeString__to_s_with_length(var2, var3);
+var1 = var4;
+varonce = var1;
+}
+{
+abstract_compiler__AbstractCompilerVisitor__add_decl(var_v, var1); /* Direct call abstract_compiler#AbstractCompilerVisitor#add_decl on <var_v:AbstractCompilerVisitor>*/
+}
+{
+{ /* Inline abstract_compiler#AbstractCompiler#modelbuilder (self) on <self:AbstractCompiler> */
+var7 = self->attrs[COLOR_abstract_compiler__AbstractCompiler___modelbuilder].val; /* _modelbuilder on <self:AbstractCompiler> */
+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 abstract_compiler#ToolContext#opt_stacktrace (var8) on <var8:ToolContext> */
+var13 = var8->attrs[COLOR_abstract_compiler__ToolContext___opt_stacktrace].val; /* _opt_stacktrace on <var8:ToolContext> */
+if (unlikely(var13 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _opt_stacktrace");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 67);
+show_backtrace(1);
+}
+var11 = var13;
+RET_LABEL12:(void)0;
+}
+}
+{
+{ /* Inline opts#Option#value (var11) on <var11:OptionString> */
+var16 = var11->attrs[COLOR_opts__Option___value].val; /* _value on <var11:OptionString> */
+var14 = var16;
+RET_LABEL15:(void)0;
+}
+}
+var_ost = var14;
+{
+{ /* Inline abstract_compiler#AbstractCompiler#mainmodule (self) on <self:AbstractCompiler> */
+var19 = self->attrs[COLOR_abstract_compiler__AbstractCompiler___mainmodule].val; /* _mainmodule on <self:AbstractCompiler> */
+if (unlikely(var19 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _mainmodule");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 463);
+show_backtrace(1);
+}
+var17 = var19;
+RET_LABEL18:(void)0;
+}
+}
+{
+var20 = platform__MModule__target_platform(var17);
+}
+var_platform = var20;
+var22 = NULL;
+if (var_platform == NULL) {
+var23 = 0; /* is null */
+} else {
+var23 = 1; /* arg is null and recv is not */
+}
+if (0) {
+var24 = ((short int (*)(val*, val*))(var_platform->class->vft[COLOR_kernel__Object___33d_61d]))(var_platform, var22) /* != on <var_platform:nullable Platform>*/;
+var23 = var24;
+}
+var_ = var23;
+if (var23){
+{
+var25 = ((short int (*)(val*))(var_platform->class->vft[COLOR_platform__Platform__supports_libunwind]))(var_platform) /* supports_libunwind on <var_platform:nullable Platform(Platform)>*/;
+}
+var26 = !var25;
+var21 = var26;
+} else {
+var21 = var_;
+}
+if (var21){
+if (varonce27) {
+var28 = varonce27;
+} else {
+var29 = "none";
+var30 = 4;
+var31 = string__NativeString__to_s_with_length(var29, var30);
+var28 = var31;
+varonce27 = var28;
+}
+var_ost = var28;
+} else {
+}
+var34 = NULL;
+if (var_platform == NULL) {
+var35 = 0; /* is null */
+} else {
+var35 = 1; /* arg is null and recv is not */
+}
+if (0) {
+var36 = ((short int (*)(val*, val*))(var_platform->class->vft[COLOR_kernel__Object___33d_61d]))(var_platform, var34) /* != on <var_platform:nullable Platform>*/;
+var35 = var36;
+}
+var_37 = var35;
+if (var35){
+{
+var38 = ((short int (*)(val*))(var_platform->class->vft[COLOR_platform__Platform__no_main]))(var_platform) /* no_main on <var_platform:nullable Platform(Platform)>*/;
+}
+var33 = var38;
+} else {
+var33 = var_37;
+}
+var_39 = var33;
+if (var33){
+var32 = var_39;
+} else {
+{
+{ /* Inline abstract_compiler#AbstractCompiler#modelbuilder (self) on <self:AbstractCompiler> */
+var42 = self->attrs[COLOR_abstract_compiler__AbstractCompiler___modelbuilder].val; /* _modelbuilder on <self:AbstractCompiler> */
+if (unlikely(var42 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _modelbuilder");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 470);
+show_backtrace(1);
+}
+var40 = var42;
+RET_LABEL41:(void)0;
+}
+}
+{
+{ /* Inline modelbuilder#ModelBuilder#toolcontext (var40) on <var40:ModelBuilder> */
+var45 = var40->attrs[COLOR_modelbuilder__ModelBuilder___toolcontext].val; /* _toolcontext on <var40:ModelBuilder> */
+if (unlikely(var45 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _toolcontext");
+PRINT_ERROR(" (%s:%d)\n", "modelbuilder.nit", 106);
+show_backtrace(1);
+}
+var43 = var45;
+RET_LABEL44:(void)0;
+}
+}
+{
+{ /* Inline abstract_compiler#ToolContext#opt_no_main (var43) on <var43:ToolContext> */
+var48 = var43->attrs[COLOR_abstract_compiler__ToolContext___opt_no_main].val; /* _opt_no_main on <var43:ToolContext> */
+if (unlikely(var48 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _opt_no_main");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 35);
+show_backtrace(1);
+}
+var46 = var48;
+RET_LABEL47:(void)0;
+}
+}
+{
+{ /* Inline opts#Option#value (var46) on <var46:OptionBool> */
+var51 = var46->attrs[COLOR_opts__Option___value].val; /* _value on <var46:OptionBool> */
+var49 = var51;
+RET_LABEL50:(void)0;
+}
+}
+var52 = ((struct instance_kernel__Bool*)var49)->value; /* autounbox from nullable Object to Bool */;
+var32 = var52;
+}
+var_no_main = var32;
+if (varonce54) {
+var55 = varonce54;
+} else {
+var56 = "nitstack";
+var57 = 8;
+var58 = string__NativeString__to_s_with_length(var56, var57);
+var55 = var58;
+varonce54 = var55;
+}
+if (var_ost == NULL) {
+var59 = 0; /* <var55:String> cannot be null */
+} else {
+var60 = string__FlatString___61d_61d(var_ost, var55);
+var59 = var60;
+}
+var_61 = var59;
+if (var59){
+var53 = var_61;
+} else {
+if (varonce62) {
+var63 = varonce62;
+} else {
+var64 = "libunwind";
+var65 = 9;
+var66 = string__NativeString__to_s_with_length(var64, var65);
+var63 = var66;
+varonce62 = var63;
+}
+if (var_ost == NULL) {
+var67 = 0; /* <var63:String> cannot be null */
+} else {
+var68 = string__FlatString___61d_61d(var_ost, var63);
+var67 = var68;
+}
+var53 = var67;
+}
+if (var53){
+if (varonce69) {
+var70 = varonce69;
+} else {
+var71 = "#define UNW_LOCAL_ONLY";
+var72 = 22;
+var73 = string__NativeString__to_s_with_length(var71, var72);
+var70 = var73;
+varonce69 = var70;
+}
+{
+abstract_compiler__AbstractCompilerVisitor__add_decl(var_v, var70); /* Direct call abstract_compiler#AbstractCompilerVisitor#add_decl on <var_v:AbstractCompilerVisitor>*/
+}
+if (varonce74) {
+var75 = varonce74;
+} else {
+var76 = "#include <libunwind.h>";
+var77 = 22;
+var78 = string__NativeString__to_s_with_length(var76, var77);
+var75 = var78;
+varonce74 = var75;
+}
+{
+abstract_compiler__AbstractCompilerVisitor__add_decl(var_v, var75); /* Direct call abstract_compiler#AbstractCompilerVisitor#add_decl on <var_v:AbstractCompilerVisitor>*/
+}
+if (varonce79) {
+var80 = varonce79;
+} else {
+var81 = "nitstack";
+var82 = 8;
+var83 = string__NativeString__to_s_with_length(var81, var82);
+var80 = var83;
+varonce79 = var80;
+}
+if (var_ost == NULL) {
+var84 = 0; /* <var80:String> cannot be null */
+} else {
+var85 = string__FlatString___61d_61d(var_ost, var80);
+var84 = var85;
+}
+if (var84){
+if (varonce86) {
+var87 = varonce86;
+} else {
+var88 = "#include \"c_functions_hash.h\"";
+var89 = 29;
+var90 = string__NativeString__to_s_with_length(var88, var89);
+var87 = var90;
+varonce86 = var87;
+}
+{
+abstract_compiler__AbstractCompilerVisitor__add_decl(var_v, var87); /* Direct call abstract_compiler#AbstractCompilerVisitor#add_decl on <var_v:AbstractCompilerVisitor>*/
+}
+} else {
+}
+} else {
+}
+if (varonce91) {
+var92 = varonce91;
+} else {
+var93 = "int glob_argc;";
+var94 = 14;
+var95 = string__NativeString__to_s_with_length(var93, var94);
+var92 = var95;
+varonce91 = var92;
+}
+{
+abstract_compiler__AbstractCompilerVisitor__add_decl(var_v, var92); /* Direct call abstract_compiler#AbstractCompilerVisitor#add_decl on <var_v:AbstractCompilerVisitor>*/
+}
+if (varonce96) {
+var97 = varonce96;
+} else {
+var98 = "char **glob_argv;";
+var99 = 17;
+var100 = string__NativeString__to_s_with_length(var98, var99);
+var97 = var100;
+varonce96 = var97;
+}
+{
+abstract_compiler__AbstractCompilerVisitor__add_decl(var_v, var97); /* Direct call abstract_compiler#AbstractCompilerVisitor#add_decl on <var_v:AbstractCompilerVisitor>*/
+}
+if (varonce101) {
+var102 = varonce101;
+} else {
+var103 = "val *glob_sys;";
+var104 = 14;
+var105 = string__NativeString__to_s_with_length(var103, var104);
+var102 = var105;
+varonce101 = var102;
+}
+{
+abstract_compiler__AbstractCompilerVisitor__add_decl(var_v, var102); /* Direct call abstract_compiler#AbstractCompilerVisitor#add_decl on <var_v:AbstractCompilerVisitor>*/
+}
+{
+{ /* Inline abstract_compiler#AbstractCompiler#modelbuilder (self) on <self:AbstractCompiler> */
+var108 = self->attrs[COLOR_abstract_compiler__AbstractCompiler___modelbuilder].val; /* _modelbuilder on <self:AbstractCompiler> */
+if (unlikely(var108 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _modelbuilder");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 470);
+show_backtrace(1);
+}
+var106 = var108;
+RET_LABEL107:(void)0;
+}
+}
+{
+{ /* Inline modelbuilder#ModelBuilder#toolcontext (var106) on <var106:ModelBuilder> */
+var111 = var106->attrs[COLOR_modelbuilder__ModelBuilder___toolcontext].val; /* _toolcontext on <var106:ModelBuilder> */
+if (unlikely(var111 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _toolcontext");
+PRINT_ERROR(" (%s:%d)\n", "modelbuilder.nit", 106);
+show_backtrace(1);
+}
+var109 = var111;
+RET_LABEL110:(void)0;
+}
+}
+{
+{ /* Inline abstract_compiler#ToolContext#opt_typing_test_metrics (var109) on <var109:ToolContext> */
+var114 = var109->attrs[COLOR_abstract_compiler__ToolContext___opt_typing_test_metrics].val; /* _opt_typing_test_metrics on <var109:ToolContext> */
+if (unlikely(var114 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _opt_typing_test_metrics");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 61);
+show_backtrace(1);
+}
+var112 = var114;
+RET_LABEL113:(void)0;
+}
+}
+{
+{ /* Inline opts#Option#value (var112) on <var112:OptionBool> */
+var117 = var112->attrs[COLOR_opts__Option___value].val; /* _value on <var112:OptionBool> */
+var115 = var117;
+RET_LABEL116:(void)0;
+}
+}
+var118 = ((struct instance_kernel__Bool*)var115)->value; /* autounbox from nullable Object to Bool */;
+if (var118){
+{
+{ /* Inline abstract_compiler#AbstractCompiler#count_type_test_tags (self) on <self:AbstractCompiler> */
+var121 = self->attrs[COLOR_abstract_compiler__AbstractCompiler___count_type_test_tags].val; /* _count_type_test_tags on <self:AbstractCompiler> */
+if (unlikely(var121 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _count_type_test_tags");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 944);
+show_backtrace(1);
+}
+var119 = var121;
+RET_LABEL120:(void)0;
+}
+}
+var_122 = var119;
+{
+var123 = array__AbstractArrayRead__iterator(var_122);
+}
+var_124 = var123;
+for(;;) {
+{
+var125 = array__ArrayIterator__is_ok(var_124);
+}
+if (var125){
+{
+var126 = array__ArrayIterator__item(var_124);
+}
+var_tag = var126;
+if (varonce127) {
+var128 = varonce127;
+} else {
+var129 = "long count_type_test_resolved_";
+var130 = 30;
+var131 = string__NativeString__to_s_with_length(var129, var130);
+var128 = var131;
+varonce127 = var128;
+}
+if (varonce132) {
+var133 = varonce132;
+} else {
+var134 = ";";
+var135 = 1;
+var136 = string__NativeString__to_s_with_length(var134, var135);
+var133 = var136;
+varonce132 = var133;
+}
+var137 = NEW_array__Array(&type_array__Arraykernel__Object);
+{ /* var137 = array_instance Array[Object] */
+var138 = 3;
+var139 = NEW_array__NativeArray(var138, &type_array__NativeArraykernel__Object);
+((struct instance_array__NativeArray*)var139)->values[0] = (val*) var128;
+((struct instance_array__NativeArray*)var139)->values[1] = (val*) var_tag;
+((struct instance_array__NativeArray*)var139)->values[2] = (val*) var133;
+{
+((void (*)(val*, val*, long))(var137->class->vft[COLOR_array__Array__with_native]))(var137, var139, var138) /* with_native on <var137:Array[Object]>*/;
+}
+}
+{
+var140 = ((val* (*)(val*))(var137->class->vft[COLOR_string__Object__to_s]))(var137) /* to_s on <var137:Array[Object]>*/;
+}
+{
+abstract_compiler__AbstractCompilerVisitor__add_decl(var_v, var140); /* Direct call abstract_compiler#AbstractCompilerVisitor#add_decl on <var_v:AbstractCompilerVisitor>*/
+}
+if (varonce141) {
+var142 = varonce141;
+} else {
+var143 = "long count_type_test_unresolved_";
+var144 = 32;
+var145 = string__NativeString__to_s_with_length(var143, var144);
+var142 = var145;
+varonce141 = var142;
+}
+if (varonce146) {
+var147 = varonce146;
+} else {
+var148 = ";";
+var149 = 1;
+var150 = string__NativeString__to_s_with_length(var148, var149);
+var147 = var150;
+varonce146 = var147;
+}
+var151 = NEW_array__Array(&type_array__Arraykernel__Object);
+{ /* var151 = array_instance Array[Object] */
+var152 = 3;
+var153 = NEW_array__NativeArray(var152, &type_array__NativeArraykernel__Object);
+((struct instance_array__NativeArray*)var153)->values[0] = (val*) var142;
+((struct instance_array__NativeArray*)var153)->values[1] = (val*) var_tag;
+((struct instance_array__NativeArray*)var153)->values[2] = (val*) var147;
+{
+((void (*)(val*, val*, long))(var151->class->vft[COLOR_array__Array__with_native]))(var151, var153, var152) /* with_native on <var151:Array[Object]>*/;
+}
+}
+{
+var154 = ((val* (*)(val*))(var151->class->vft[COLOR_string__Object__to_s]))(var151) /* to_s on <var151:Array[Object]>*/;
+}
+{
+abstract_compiler__AbstractCompilerVisitor__add_decl(var_v, var154); /* Direct call abstract_compiler#AbstractCompilerVisitor#add_decl on <var_v:AbstractCompilerVisitor>*/
+}
+if (varonce155) {
+var156 = varonce155;
+} else {
+var157 = "long count_type_test_skipped_";
+var158 = 29;
+var159 = string__NativeString__to_s_with_length(var157, var158);
+var156 = var159;
+varonce155 = var156;
+}
+if (varonce160) {
+var161 = varonce160;
+} else {
+var162 = ";";
+var163 = 1;
+var164 = string__NativeString__to_s_with_length(var162, var163);
+var161 = var164;
+varonce160 = var161;
+}
+var165 = NEW_array__Array(&type_array__Arraykernel__Object);
+{ /* var165 = array_instance Array[Object] */
+var166 = 3;
+var167 = NEW_array__NativeArray(var166, &type_array__NativeArraykernel__Object);
+((struct instance_array__NativeArray*)var167)->values[0] = (val*) var156;
+((struct instance_array__NativeArray*)var167)->values[1] = (val*) var_tag;
+((struct instance_array__NativeArray*)var167)->values[2] = (val*) var161;
+{
+((void (*)(val*, val*, long))(var165->class->vft[COLOR_array__Array__with_native]))(var165, var167, var166) /* with_native on <var165:Array[Object]>*/;
+}
+}
+{
+var168 = ((val* (*)(val*))(var165->class->vft[COLOR_string__Object__to_s]))(var165) /* to_s on <var165:Array[Object]>*/;
+}
+{
+abstract_compiler__AbstractCompilerVisitor__add_decl(var_v, var168); /* Direct call abstract_compiler#AbstractCompilerVisitor#add_decl on <var_v:AbstractCompilerVisitor>*/
+}
+{
+{ /* Inline abstract_compiler#AbstractCompilerVisitor#compiler (var_v) on <var_v:AbstractCompilerVisitor> */
+var171 = var_v->attrs[COLOR_abstract_compiler__AbstractCompilerVisitor___compiler].val; /* _compiler on <var_v:AbstractCompilerVisitor> */
+if (unlikely(var171 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _compiler");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 1041);
+show_backtrace(1);
+}
+var169 = var171;
+RET_LABEL170:(void)0;
+}
+}
+{
+{ /* Inline abstract_compiler#AbstractCompiler#header (var169) on <var169:AbstractCompiler> */
+var174 = var169->attrs[COLOR_abstract_compiler__AbstractCompiler___header].val; /* _header on <var169:AbstractCompiler> */
+if (unlikely(var174 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _header");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 506);
+show_backtrace(1);
+}
+var172 = var174;
+RET_LABEL173:(void)0;
+}
+}
+if (varonce175) {
+var176 = varonce175;
+} else {
+var177 = "extern long count_type_test_resolved_";
+var178 = 37;
+var179 = string__NativeString__to_s_with_length(var177, var178);
+var176 = var179;
+varonce175 = var176;
+}
+if (varonce180) {
+var181 = varonce180;
+} else {
+var182 = ";";
+var183 = 1;
+var184 = string__NativeString__to_s_with_length(var182, var183);
+var181 = var184;
+varonce180 = var181;
+}
+var185 = NEW_array__Array(&type_array__Arraykernel__Object);
+{ /* var185 = array_instance Array[Object] */
+var186 = 3;
+var187 = NEW_array__NativeArray(var186, &type_array__NativeArraykernel__Object);
+((struct instance_array__NativeArray*)var187)->values[0] = (val*) var176;
+((struct instance_array__NativeArray*)var187)->values[1] = (val*) var_tag;
+((struct instance_array__NativeArray*)var187)->values[2] = (val*) var181;
+{
+((void (*)(val*, val*, long))(var185->class->vft[COLOR_array__Array__with_native]))(var185, var187, var186) /* with_native on <var185:Array[Object]>*/;
+}
+}
+{
+var188 = ((val* (*)(val*))(var185->class->vft[COLOR_string__Object__to_s]))(var185) /* to_s on <var185:Array[Object]>*/;
+}
+{
+abstract_compiler__CodeWriter__add_decl(var172, var188); /* Direct call abstract_compiler#CodeWriter#add_decl on <var172:CodeWriter>*/
+}
+{
+{ /* Inline abstract_compiler#AbstractCompilerVisitor#compiler (var_v) on <var_v:AbstractCompilerVisitor> */
+var191 = var_v->attrs[COLOR_abstract_compiler__AbstractCompilerVisitor___compiler].val; /* _compiler on <var_v:AbstractCompilerVisitor> */
+if (unlikely(var191 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _compiler");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 1041);
+show_backtrace(1);
+}
+var189 = var191;
+RET_LABEL190:(void)0;
+}
+}
+{
+{ /* Inline abstract_compiler#AbstractCompiler#header (var189) on <var189:AbstractCompiler> */
+var194 = var189->attrs[COLOR_abstract_compiler__AbstractCompiler___header].val; /* _header on <var189:AbstractCompiler> */
+if (unlikely(var194 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _header");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 506);
+show_backtrace(1);
+}
+var192 = var194;
+RET_LABEL193:(void)0;
+}
+}
+if (varonce195) {
+var196 = varonce195;
+} else {
+var197 = "extern long count_type_test_unresolved_";
+var198 = 39;
+var199 = string__NativeString__to_s_with_length(var197, var198);
+var196 = var199;
+varonce195 = var196;
+}
+if (varonce200) {
+var201 = varonce200;
+} else {
+var202 = ";";
+var203 = 1;
+var204 = string__NativeString__to_s_with_length(var202, var203);
+var201 = var204;
+varonce200 = var201;
+}
+var205 = NEW_array__Array(&type_array__Arraykernel__Object);
+{ /* var205 = array_instance Array[Object] */
+var206 = 3;
+var207 = NEW_array__NativeArray(var206, &type_array__NativeArraykernel__Object);
+((struct instance_array__NativeArray*)var207)->values[0] = (val*) var196;
+((struct instance_array__NativeArray*)var207)->values[1] = (val*) var_tag;
+((struct instance_array__NativeArray*)var207)->values[2] = (val*) var201;
+{
+((void (*)(val*, val*, long))(var205->class->vft[COLOR_array__Array__with_native]))(var205, var207, var206) /* with_native on <var205:Array[Object]>*/;
+}
+}
+{
+var208 = ((val* (*)(val*))(var205->class->vft[COLOR_string__Object__to_s]))(var205) /* to_s on <var205:Array[Object]>*/;
+}
+{
+abstract_compiler__CodeWriter__add_decl(var192, var208); /* Direct call abstract_compiler#CodeWriter#add_decl on <var192:CodeWriter>*/
+}
+{
+{ /* Inline abstract_compiler#AbstractCompilerVisitor#compiler (var_v) on <var_v:AbstractCompilerVisitor> */
+var211 = var_v->attrs[COLOR_abstract_compiler__AbstractCompilerVisitor___compiler].val; /* _compiler on <var_v:AbstractCompilerVisitor> */
+if (unlikely(var211 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _compiler");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 1041);
+show_backtrace(1);
+}
+var209 = var211;
+RET_LABEL210:(void)0;
+}
+}
+{
+{ /* Inline abstract_compiler#AbstractCompiler#header (var209) on <var209:AbstractCompiler> */
+var214 = var209->attrs[COLOR_abstract_compiler__AbstractCompiler___header].val; /* _header on <var209:AbstractCompiler> */
+if (unlikely(var214 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _header");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 506);
+show_backtrace(1);
+}
+var212 = var214;
+RET_LABEL213:(void)0;
+}
+}
+if (varonce215) {
+var216 = varonce215;
+} else {
+var217 = "extern long count_type_test_skipped_";
+var218 = 36;
+var219 = string__NativeString__to_s_with_length(var217, var218);
+var216 = var219;
+varonce215 = var216;
+}
+if (varonce220) {
+var221 = varonce220;
+} else {
+var222 = ";";
+var223 = 1;
+var224 = string__NativeString__to_s_with_length(var222, var223);
+var221 = var224;
+varonce220 = var221;
+}
+var225 = NEW_array__Array(&type_array__Arraykernel__Object);
+{ /* var225 = array_instance Array[Object] */
+var226 = 3;
+var227 = NEW_array__NativeArray(var226, &type_array__NativeArraykernel__Object);
+((struct instance_array__NativeArray*)var227)->values[0] = (val*) var216;
+((struct instance_array__NativeArray*)var227)->values[1] = (val*) var_tag;
+((struct instance_array__NativeArray*)var227)->values[2] = (val*) var221;
+{
+((void (*)(val*, val*, long))(var225->class->vft[COLOR_array__Array__with_native]))(var225, var227, var226) /* with_native on <var225:Array[Object]>*/;
+}
+}
+{
+var228 = ((val* (*)(val*))(var225->class->vft[COLOR_string__Object__to_s]))(var225) /* to_s on <var225:Array[Object]>*/;
+}
+{
+abstract_compiler__CodeWriter__add_decl(var212, var228); /* Direct call abstract_compiler#CodeWriter#add_decl on <var212:CodeWriter>*/
+}
+{
+array__ArrayIterator__next(var_124); /* Direct call array#ArrayIterator#next on <var_124:ArrayIterator[String]>*/
+}
+} else {
+goto BREAK_label;
+}
+}
+BREAK_label: (void)0;
+{
+{ /* Inline abstract_collection#Iterator#finish (var_124) on <var_124:ArrayIterator[String]> */
+RET_LABEL229:(void)0;
+}
+}
+} else {
+}
+{
+{ /* Inline abstract_compiler#AbstractCompiler#modelbuilder (self) on <self:AbstractCompiler> */
+var232 = self->attrs[COLOR_abstract_compiler__AbstractCompiler___modelbuilder].val; /* _modelbuilder on <self:AbstractCompiler> */
+if (unlikely(var232 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _modelbuilder");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 470);
+show_backtrace(1);
+}
+var230 = var232;
+RET_LABEL231:(void)0;
+}
+}
+{
+{ /* Inline modelbuilder#ModelBuilder#toolcontext (var230) on <var230:ModelBuilder> */
+var235 = var230->attrs[COLOR_modelbuilder__ModelBuilder___toolcontext].val; /* _toolcontext on <var230:ModelBuilder> */
+if (unlikely(var235 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _toolcontext");
+PRINT_ERROR(" (%s:%d)\n", "modelbuilder.nit", 106);
+show_backtrace(1);
+}
+var233 = var235;
+RET_LABEL234:(void)0;
+}
+}
+{
+{ /* Inline abstract_compiler#ToolContext#opt_invocation_metrics (var233) on <var233:ToolContext> */
+var238 = var233->attrs[COLOR_abstract_compiler__ToolContext___opt_invocation_metrics].val; /* _opt_invocation_metrics on <var233:ToolContext> */
+if (unlikely(var238 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _opt_invocation_metrics");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 63);
+show_backtrace(1);
+}
+var236 = var238;
+RET_LABEL237:(void)0;
+}
+}
+{
+{ /* Inline opts#Option#value (var236) on <var236:OptionBool> */
+var241 = var236->attrs[COLOR_opts__Option___value].val; /* _value on <var236:OptionBool> */
+var239 = var241;
+RET_LABEL240:(void)0;
+}
+}
+var242 = ((struct instance_kernel__Bool*)var239)->value; /* autounbox from nullable Object to Bool */;
+if (var242){
+if (varonce243) {
+var244 = varonce243;
+} else {
+var245 = "long count_invoke_by_tables;";
+var246 = 28;
+var247 = string__NativeString__to_s_with_length(var245, var246);
+var244 = var247;
+varonce243 = var244;
+}
+{
+abstract_compiler__AbstractCompilerVisitor__add_decl(var_v, var244); /* Direct call abstract_compiler#AbstractCompilerVisitor#add_decl on <var_v:AbstractCompilerVisitor>*/
+}
+if (varonce248) {
+var249 = varonce248;
+} else {
+var250 = "long count_invoke_by_direct;";
+var251 = 28;
+var252 = string__NativeString__to_s_with_length(var250, var251);
+var249 = var252;
+varonce248 = var249;
+}
+{
+abstract_compiler__AbstractCompilerVisitor__add_decl(var_v, var249); /* Direct call abstract_compiler#AbstractCompilerVisitor#add_decl on <var_v:AbstractCompilerVisitor>*/
+}
+if (varonce253) {
+var254 = varonce253;
+} else {
+var255 = "long count_invoke_by_inline;";
+var256 = 28;
+var257 = string__NativeString__to_s_with_length(var255, var256);
+var254 = var257;
+varonce253 = var254;
+}
+{
+abstract_compiler__AbstractCompilerVisitor__add_decl(var_v, var254); /* Direct call abstract_compiler#AbstractCompilerVisitor#add_decl on <var_v:AbstractCompilerVisitor>*/
+}
+{
+{ /* Inline abstract_compiler#AbstractCompilerVisitor#compiler (var_v) on <var_v:AbstractCompilerVisitor> */
+var260 = var_v->attrs[COLOR_abstract_compiler__AbstractCompilerVisitor___compiler].val; /* _compiler on <var_v:AbstractCompilerVisitor> */
+if (unlikely(var260 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _compiler");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 1041);
+show_backtrace(1);
+}
+var258 = var260;
+RET_LABEL259:(void)0;
+}
+}
+{
+{ /* Inline abstract_compiler#AbstractCompiler#header (var258) on <var258:AbstractCompiler> */
+var263 = var258->attrs[COLOR_abstract_compiler__AbstractCompiler___header].val; /* _header on <var258:AbstractCompiler> */
+if (unlikely(var263 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _header");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 506);
+show_backtrace(1);
+}
+var261 = var263;
+RET_LABEL262:(void)0;
+}
+}
+if (varonce264) {
+var265 = varonce264;
+} else {
+var266 = "extern long count_invoke_by_tables;";
+var267 = 35;
+var268 = string__NativeString__to_s_with_length(var266, var267);
+var265 = var268;
+varonce264 = var265;
+}
+{
+abstract_compiler__CodeWriter__add_decl(var261, var265); /* Direct call abstract_compiler#CodeWriter#add_decl on <var261:CodeWriter>*/
+}
+{
+{ /* Inline abstract_compiler#AbstractCompilerVisitor#compiler (var_v) on <var_v:AbstractCompilerVisitor> */
+var271 = var_v->attrs[COLOR_abstract_compiler__AbstractCompilerVisitor___compiler].val; /* _compiler on <var_v:AbstractCompilerVisitor> */
+if (unlikely(var271 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _compiler");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 1041);
+show_backtrace(1);
+}
+var269 = var271;
+RET_LABEL270:(void)0;
+}
+}
+{
+{ /* Inline abstract_compiler#AbstractCompiler#header (var269) on <var269:AbstractCompiler> */
+var274 = var269->attrs[COLOR_abstract_compiler__AbstractCompiler___header].val; /* _header on <var269:AbstractCompiler> */
+if (unlikely(var274 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _header");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 506);
+show_backtrace(1);
+}
+var272 = var274;
+RET_LABEL273:(void)0;
+}
+}
+if (varonce275) {
+var276 = varonce275;
+} else {
+var277 = "extern long count_invoke_by_direct;";
+var278 = 35;
+var279 = string__NativeString__to_s_with_length(var277, var278);
+var276 = var279;
+varonce275 = var276;
+}
+{
+abstract_compiler__CodeWriter__add_decl(var272, var276); /* Direct call abstract_compiler#CodeWriter#add_decl on <var272:CodeWriter>*/
+}
+{
+{ /* Inline abstract_compiler#AbstractCompilerVisitor#compiler (var_v) on <var_v:AbstractCompilerVisitor> */
+var282 = var_v->attrs[COLOR_abstract_compiler__AbstractCompilerVisitor___compiler].val; /* _compiler on <var_v:AbstractCompilerVisitor> */
+if (unlikely(var282 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _compiler");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 1041);
+show_backtrace(1);
+}
+var280 = var282;
+RET_LABEL281:(void)0;
+}
+}
+{
+{ /* Inline abstract_compiler#AbstractCompiler#header (var280) on <var280:AbstractCompiler> */
+var285 = var280->attrs[COLOR_abstract_compiler__AbstractCompiler___header].val; /* _header on <var280:AbstractCompiler> */
+if (unlikely(var285 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _header");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 506);
+show_backtrace(1);
+}
+var283 = var285;
+RET_LABEL284:(void)0;
+}
+}
+if (varonce286) {
+var287 = varonce286;
+} else {
+var288 = "extern long count_invoke_by_inline;";
+var289 = 35;
+var290 = string__NativeString__to_s_with_length(var288, var289);
+var287 = var290;
+varonce286 = var287;
+}
+{
+abstract_compiler__CodeWriter__add_decl(var283, var287); /* Direct call abstract_compiler#CodeWriter#add_decl on <var283:CodeWriter>*/
+}
+} else {
+}
+{
+{ /* Inline abstract_compiler#AbstractCompiler#modelbuilder (self) on <self:AbstractCompiler> */
+var293 = self->attrs[COLOR_abstract_compiler__AbstractCompiler___modelbuilder].val; /* _modelbuilder on <self:AbstractCompiler> */
+if (unlikely(var293 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _modelbuilder");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 470);
+show_backtrace(1);
+}
+var291 = var293;
+RET_LABEL292:(void)0;
+}
+}
+{
+{ /* Inline modelbuilder#ModelBuilder#toolcontext (var291) on <var291:ModelBuilder> */
+var296 = var291->attrs[COLOR_modelbuilder__ModelBuilder___toolcontext].val; /* _toolcontext on <var291:ModelBuilder> */
+if (unlikely(var296 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _toolcontext");
+PRINT_ERROR(" (%s:%d)\n", "modelbuilder.nit", 106);
+show_backtrace(1);
+}
+var294 = var296;
+RET_LABEL295:(void)0;
+}
+}
+{
+{ /* Inline abstract_compiler#ToolContext#opt_isset_checks_metrics (var294) on <var294:ToolContext> */
+var299 = var294->attrs[COLOR_abstract_compiler__ToolContext___opt_isset_checks_metrics].val; /* _opt_isset_checks_metrics on <var294:ToolContext> */
+if (unlikely(var299 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _opt_isset_checks_metrics");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 65);
+show_backtrace(1);
+}
+var297 = var299;
+RET_LABEL298:(void)0;
+}
+}
+{
+{ /* Inline opts#Option#value (var297) on <var297:OptionBool> */
+var302 = var297->attrs[COLOR_opts__Option___value].val; /* _value on <var297:OptionBool> */
+var300 = var302;
+RET_LABEL301:(void)0;
+}
+}
+var303 = ((struct instance_kernel__Bool*)var300)->value; /* autounbox from nullable Object to Bool */;
+if (var303){
+if (varonce304) {
+var305 = varonce304;
+} else {
+var306 = "long count_attr_reads = 0;";
+var307 = 26;
+var308 = string__NativeString__to_s_with_length(var306, var307);
+var305 = var308;
+varonce304 = var305;
+}
+{
+abstract_compiler__AbstractCompilerVisitor__add_decl(var_v, var305); /* Direct call abstract_compiler#AbstractCompilerVisitor#add_decl on <var_v:AbstractCompilerVisitor>*/
+}
+if (varonce309) {
+var310 = varonce309;
+} else {
+var311 = "long count_isset_checks = 0;";
+var312 = 28;
+var313 = string__NativeString__to_s_with_length(var311, var312);
+var310 = var313;
+varonce309 = var310;
+}
+{
+abstract_compiler__AbstractCompilerVisitor__add_decl(var_v, var310); /* Direct call abstract_compiler#AbstractCompilerVisitor#add_decl on <var_v:AbstractCompilerVisitor>*/
+}
+{
+{ /* Inline abstract_compiler#AbstractCompilerVisitor#compiler (var_v) on <var_v:AbstractCompilerVisitor> */
+var316 = var_v->attrs[COLOR_abstract_compiler__AbstractCompilerVisitor___compiler].val; /* _compiler on <var_v:AbstractCompilerVisitor> */
+if (unlikely(var316 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _compiler");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 1041);
+show_backtrace(1);
+}
+var314 = var316;
+RET_LABEL315:(void)0;
+}
+}
+{
+{ /* Inline abstract_compiler#AbstractCompiler#header (var314) on <var314:AbstractCompiler> */
+var319 = var314->attrs[COLOR_abstract_compiler__AbstractCompiler___header].val; /* _header on <var314:AbstractCompiler> */
+if (unlikely(var319 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _header");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 506);
+show_backtrace(1);
+}
+var317 = var319;
+RET_LABEL318:(void)0;
+}
+}
+if (varonce320) {
+var321 = varonce320;
+} else {
+var322 = "extern long count_attr_reads;";
+var323 = 29;
+var324 = string__NativeString__to_s_with_length(var322, var323);
+var321 = var324;
+varonce320 = var321;
+}
+{
+abstract_compiler__CodeWriter__add_decl(var317, var321); /* Direct call abstract_compiler#CodeWriter#add_decl on <var317:CodeWriter>*/
+}
+{
+{ /* Inline abstract_compiler#AbstractCompilerVisitor#compiler (var_v) on <var_v:AbstractCompilerVisitor> */
+var327 = var_v->attrs[COLOR_abstract_compiler__AbstractCompilerVisitor___compiler].val; /* _compiler on <var_v:AbstractCompilerVisitor> */
+if (unlikely(var327 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _compiler");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 1041);
+show_backtrace(1);
+}
+var325 = var327;
+RET_LABEL326:(void)0;
+}
+}
+{
+{ /* Inline abstract_compiler#AbstractCompiler#header (var325) on <var325:AbstractCompiler> */
+var330 = var325->attrs[COLOR_abstract_compiler__AbstractCompiler___header].val; /* _header on <var325:AbstractCompiler> */
+if (unlikely(var330 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _header");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 506);
+show_backtrace(1);
+}
+var328 = var330;
+RET_LABEL329:(void)0;
+}
+}
+if (varonce331) {
+var332 = varonce331;
+} else {
+var333 = "extern long count_isset_checks;";
+var334 = 31;
+var335 = string__NativeString__to_s_with_length(var333, var334);
+var332 = var335;
+varonce331 = var332;
+}
+{
+abstract_compiler__CodeWriter__add_decl(var328, var332); /* Direct call abstract_compiler#CodeWriter#add_decl on <var328:CodeWriter>*/
+}
+} else {
+}
+if (varonce336) {
+var337 = varonce336;
+} else {
+var338 = "void sig_handler(int signo){";
+var339 = 28;
+var340 = string__NativeString__to_s_with_length(var338, var339);
+var337 = var340;
+varonce336 = var337;
+}
+{
+abstract_compiler__AbstractCompilerVisitor__add_decl(var_v, var337); /* Direct call abstract_compiler#AbstractCompilerVisitor#add_decl on <var_v:AbstractCompilerVisitor>*/
+}
+if (varonce341) {
+var342 = varonce341;
+} else {
+var343 = "PRINT_ERROR(\"Caught signal : %s\\n\", strsignal(signo));";
+var344 = 54;
+var345 = string__NativeString__to_s_with_length(var343, var344);
+var342 = var345;
+varonce341 = var342;
+}
+{
+abstract_compiler__AbstractCompilerVisitor__add_decl(var_v, var342); /* Direct call abstract_compiler#AbstractCompilerVisitor#add_decl on <var_v:AbstractCompilerVisitor>*/
+}
+if (varonce346) {
+var347 = varonce346;
+} else {
+var348 = "show_backtrace(signo);";
+var349 = 22;
+var350 = string__NativeString__to_s_with_length(var348, var349);
+var347 = var350;
+varonce346 = var347;
+}
+{
+abstract_compiler__AbstractCompilerVisitor__add_decl(var_v, var347); /* Direct call abstract_compiler#AbstractCompilerVisitor#add_decl on <var_v:AbstractCompilerVisitor>*/
+}
+if (varonce351) {
+var352 = varonce351;
+} else {
+var353 = "}";
+var354 = 1;
+var355 = string__NativeString__to_s_with_length(var353, var354);
+var352 = var355;
+varonce351 = var352;
+}
+{
+abstract_compiler__AbstractCompilerVisitor__add_decl(var_v, var352); /* Direct call abstract_compiler#AbstractCompilerVisitor#add_decl on <var_v:AbstractCompilerVisitor>*/
+}
+if (varonce356) {
+var357 = varonce356;
+} else {
+var358 = "void show_backtrace (int signo) {";
+var359 = 33;
+var360 = string__NativeString__to_s_with_length(var358, var359);
+var357 = var360;
+varonce356 = var357;
+}
+{
+abstract_compiler__AbstractCompilerVisitor__add_decl(var_v, var357); /* Direct call abstract_compiler#AbstractCompilerVisitor#add_decl on <var_v:AbstractCompilerVisitor>*/
+}
+if (varonce362) {
+var363 = varonce362;
+} else {
+var364 = "nitstack";
+var365 = 8;
+var366 = string__NativeString__to_s_with_length(var364, var365);
+var363 = var366;
+varonce362 = var363;
+}
+if (var_ost == NULL) {
+var367 = 0; /* <var363:String> cannot be null */
+} else {
+var368 = string__FlatString___61d_61d(var_ost, var363);
+var367 = var368;
+}
+var_369 = var367;
+if (var367){
+var361 = var_369;
+} else {
+if (varonce370) {
+var371 = varonce370;
+} else {
+var372 = "libunwind";
+var373 = 9;
+var374 = string__NativeString__to_s_with_length(var372, var373);
+var371 = var374;
+varonce370 = var371;
+}
+if (var_ost == NULL) {
+var375 = 0; /* <var371:String> cannot be null */
+} else {
+var376 = string__FlatString___61d_61d(var_ost, var371);
+var375 = var376;
+}
+var361 = var375;
+}
+if (var361){
+if (varonce377) {
+var378 = varonce377;
+} else {
+var379 = "char* opt = getenv(\"NIT_NO_STACK\");";
+var380 = 35;
+var381 = string__NativeString__to_s_with_length(var379, var380);
+var378 = var381;
+varonce377 = var378;
+}
+{
+abstract_compiler__AbstractCompilerVisitor__add_decl(var_v, var378); /* Direct call abstract_compiler#AbstractCompilerVisitor#add_decl on <var_v:AbstractCompilerVisitor>*/
+}
+if (varonce382) {
+var383 = varonce382;
+} else {
+var384 = "unw_cursor_t cursor;";
+var385 = 20;
+var386 = string__NativeString__to_s_with_length(var384, var385);
+var383 = var386;
+varonce382 = var383;
+}
+{
+abstract_compiler__AbstractCompilerVisitor__add_decl(var_v, var383); /* Direct call abstract_compiler#AbstractCompilerVisitor#add_decl on <var_v:AbstractCompilerVisitor>*/
+}
+if (varonce387) {
+var388 = varonce387;
+} else {
+var389 = "if(opt==NULL){";
+var390 = 14;
+var391 = string__NativeString__to_s_with_length(var389, var390);
+var388 = var391;
+varonce387 = var388;
+}
+{
+abstract_compiler__AbstractCompilerVisitor__add_decl(var_v, var388); /* Direct call abstract_compiler#AbstractCompilerVisitor#add_decl on <var_v:AbstractCompilerVisitor>*/
+}
+if (varonce392) {
+var393 = varonce392;
+} else {
+var394 = "unw_context_t uc;";
+var395 = 17;
+var396 = string__NativeString__to_s_with_length(var394, var395);
+var393 = var396;
+varonce392 = var393;
+}
+{
+abstract_compiler__AbstractCompilerVisitor__add_decl(var_v, var393); /* Direct call abstract_compiler#AbstractCompilerVisitor#add_decl on <var_v:AbstractCompilerVisitor>*/
+}
+if (varonce397) {
+var398 = varonce397;
+} else {
+var399 = "unw_word_t ip;";
+var400 = 14;
+var401 = string__NativeString__to_s_with_length(var399, var400);
+var398 = var401;
+varonce397 = var398;
+}
+{
+abstract_compiler__AbstractCompilerVisitor__add_decl(var_v, var398); /* Direct call abstract_compiler#AbstractCompilerVisitor#add_decl on <var_v:AbstractCompilerVisitor>*/
+}
+if (varonce402) {
+var403 = varonce402;
+} else {
+var404 = "char* procname = malloc(sizeof(char) * 100);";
+var405 = 44;
+var406 = string__NativeString__to_s_with_length(var404, var405);
+var403 = var406;
+varonce402 = var403;
+}
+{
+abstract_compiler__AbstractCompilerVisitor__add_decl(var_v, var403); /* Direct call abstract_compiler#AbstractCompilerVisitor#add_decl on <var_v:AbstractCompilerVisitor>*/
+}
+if (varonce407) {
+var408 = varonce407;
+} else {
+var409 = "unw_getcontext(&uc);";
+var410 = 20;
+var411 = string__NativeString__to_s_with_length(var409, var410);
+var408 = var411;
+varonce407 = var408;
+}
+{
+abstract_compiler__AbstractCompilerVisitor__add_decl(var_v, var408); /* Direct call abstract_compiler#AbstractCompilerVisitor#add_decl on <var_v:AbstractCompilerVisitor>*/
+}
+if (varonce412) {
+var413 = varonce412;
+} else {
+var414 = "unw_init_local(&cursor, &uc);";
+var415 = 29;
+var416 = string__NativeString__to_s_with_length(var414, var415);
+var413 = var416;
+varonce412 = var413;
+}
+{
+abstract_compiler__AbstractCompilerVisitor__add_decl(var_v, var413); /* Direct call abstract_compiler#AbstractCompilerVisitor#add_decl on <var_v:AbstractCompilerVisitor>*/
+}
+if (varonce417) {
+var418 = varonce417;
+} else {
+var419 = "PRINT_ERROR(\"-------------------------------------------------\\n\");";
+var420 = 67;
+var421 = string__NativeString__to_s_with_length(var419, var420);
+var418 = var421;
+varonce417 = var418;
+}
+{
+abstract_compiler__AbstractCompilerVisitor__add_decl(var_v, var418); /* Direct call abstract_compiler#AbstractCompilerVisitor#add_decl on <var_v:AbstractCompilerVisitor>*/
+}
+if (varonce422) {
+var423 = varonce422;
+} else {
+var424 = "PRINT_ERROR(\"--   Stack Trace   ------------------------------\\n\");";
+var425 = 67;
+var426 = string__NativeString__to_s_with_length(var424, var425);
+var423 = var426;
+varonce422 = var423;
+}
+{
+abstract_compiler__AbstractCompilerVisitor__add_decl(var_v, var423); /* Direct call abstract_compiler#AbstractCompilerVisitor#add_decl on <var_v:AbstractCompilerVisitor>*/
+}
+if (varonce427) {
+var428 = varonce427;
+} else {
+var429 = "PRINT_ERROR(\"-------------------------------------------------\\n\");";
+var430 = 67;
+var431 = string__NativeString__to_s_with_length(var429, var430);
+var428 = var431;
+varonce427 = var428;
+}
+{
+abstract_compiler__AbstractCompilerVisitor__add_decl(var_v, var428); /* Direct call abstract_compiler#AbstractCompilerVisitor#add_decl on <var_v:AbstractCompilerVisitor>*/
+}
+if (varonce432) {
+var433 = varonce432;
+} else {
+var434 = "while (unw_step(&cursor) > 0) {";
+var435 = 31;
+var436 = string__NativeString__to_s_with_length(var434, var435);
+var433 = var436;
+varonce432 = var433;
+}
+{
+abstract_compiler__AbstractCompilerVisitor__add_decl(var_v, var433); /* Direct call abstract_compiler#AbstractCompilerVisitor#add_decl on <var_v:AbstractCompilerVisitor>*/
+}
+if (varonce437) {
+var438 = varonce437;
+} else {
+var439 = "\11unw_get_proc_name(&cursor, procname, 100, &ip);";
+var440 = 48;
+var441 = string__NativeString__to_s_with_length(var439, var440);
+var438 = var441;
+varonce437 = var438;
+}
+{
+abstract_compiler__AbstractCompilerVisitor__add_decl(var_v, var438); /* Direct call abstract_compiler#AbstractCompilerVisitor#add_decl on <var_v:AbstractCompilerVisitor>*/
+}
+if (varonce442) {
+var443 = varonce442;
+} else {
+var444 = "nitstack";
+var445 = 8;
+var446 = string__NativeString__to_s_with_length(var444, var445);
+var443 = var446;
+varonce442 = var443;
+}
+if (var_ost == NULL) {
+var447 = 0; /* <var443:String> cannot be null */
+} else {
+var448 = string__FlatString___61d_61d(var_ost, var443);
+var447 = var448;
+}
+if (var447){
+if (varonce449) {
+var450 = varonce449;
+} else {
+var451 = "\11const char* recv = get_nit_name(procname, strlen(procname));";
+var452 = 61;
+var453 = string__NativeString__to_s_with_length(var451, var452);
+var450 = var453;
+varonce449 = var450;
+}
+{
+abstract_compiler__AbstractCompilerVisitor__add_decl(var_v, var450); /* Direct call abstract_compiler#AbstractCompilerVisitor#add_decl on <var_v:AbstractCompilerVisitor>*/
+}
+if (varonce454) {
+var455 = varonce454;
+} else {
+var456 = "\11if (recv != NULL){";
+var457 = 19;
+var458 = string__NativeString__to_s_with_length(var456, var457);
+var455 = var458;
+varonce454 = var455;
+}
+{
+abstract_compiler__AbstractCompilerVisitor__add_decl(var_v, var455); /* Direct call abstract_compiler#AbstractCompilerVisitor#add_decl on <var_v:AbstractCompilerVisitor>*/
+}
+if (varonce459) {
+var460 = varonce459;
+} else {
+var461 = "\11\11PRINT_ERROR(\"` %s\\n\", recv);";
+var462 = 30;
+var463 = string__NativeString__to_s_with_length(var461, var462);
+var460 = var463;
+varonce459 = var460;
+}
+{
+abstract_compiler__AbstractCompilerVisitor__add_decl(var_v, var460); /* Direct call abstract_compiler#AbstractCompilerVisitor#add_decl on <var_v:AbstractCompilerVisitor>*/
+}
+if (varonce464) {
+var465 = varonce464;
+} else {
+var466 = "\11}else{";
+var467 = 7;
+var468 = string__NativeString__to_s_with_length(var466, var467);
+var465 = var468;
+varonce464 = var465;
+}
+{
+abstract_compiler__AbstractCompilerVisitor__add_decl(var_v, var465); /* Direct call abstract_compiler#AbstractCompilerVisitor#add_decl on <var_v:AbstractCompilerVisitor>*/
+}
+if (varonce469) {
+var470 = varonce469;
+} else {
+var471 = "\11\11PRINT_ERROR(\"` %s\\n\", procname);";
+var472 = 34;
+var473 = string__NativeString__to_s_with_length(var471, var472);
+var470 = var473;
+varonce469 = var470;
+}
+{
+abstract_compiler__AbstractCompilerVisitor__add_decl(var_v, var470); /* Direct call abstract_compiler#AbstractCompilerVisitor#add_decl on <var_v:AbstractCompilerVisitor>*/
+}
+if (varonce474) {
+var475 = varonce474;
+} else {
+var476 = "\11}";
+var477 = 2;
+var478 = string__NativeString__to_s_with_length(var476, var477);
+var475 = var478;
+varonce474 = var475;
+}
+{
+abstract_compiler__AbstractCompilerVisitor__add_decl(var_v, var475); /* Direct call abstract_compiler#AbstractCompilerVisitor#add_decl on <var_v:AbstractCompilerVisitor>*/
+}
+} else {
+if (varonce479) {
+var480 = varonce479;
+} else {
+var481 = "\11PRINT_ERROR(\"` %s \\n\",procname);";
+var482 = 33;
+var483 = string__NativeString__to_s_with_length(var481, var482);
+var480 = var483;
+varonce479 = var480;
+}
+{
+abstract_compiler__AbstractCompilerVisitor__add_decl(var_v, var480); /* Direct call abstract_compiler#AbstractCompilerVisitor#add_decl on <var_v:AbstractCompilerVisitor>*/
+}
+}
+if (varonce484) {
+var485 = varonce484;
+} else {
+var486 = "}";
+var487 = 1;
+var488 = string__NativeString__to_s_with_length(var486, var487);
+var485 = var488;
+varonce484 = var485;
+}
+{
+abstract_compiler__AbstractCompilerVisitor__add_decl(var_v, var485); /* Direct call abstract_compiler#AbstractCompilerVisitor#add_decl on <var_v:AbstractCompilerVisitor>*/
+}
+if (varonce489) {
+var490 = varonce489;
+} else {
+var491 = "PRINT_ERROR(\"-------------------------------------------------\\n\");";
+var492 = 67;
+var493 = string__NativeString__to_s_with_length(var491, var492);
+var490 = var493;
+varonce489 = var490;
+}
+{
+abstract_compiler__AbstractCompilerVisitor__add_decl(var_v, var490); /* Direct call abstract_compiler#AbstractCompilerVisitor#add_decl on <var_v:AbstractCompilerVisitor>*/
+}
+if (varonce494) {
+var495 = varonce494;
+} else {
+var496 = "free(procname);";
+var497 = 15;
+var498 = string__NativeString__to_s_with_length(var496, var497);
+var495 = var498;
+varonce494 = var495;
+}
+{
+abstract_compiler__AbstractCompilerVisitor__add_decl(var_v, var495); /* Direct call abstract_compiler#AbstractCompilerVisitor#add_decl on <var_v:AbstractCompilerVisitor>*/
+}
+if (varonce499) {
+var500 = varonce499;
+} else {
+var501 = "}";
+var502 = 1;
+var503 = string__NativeString__to_s_with_length(var501, var502);
+var500 = var503;
+varonce499 = var500;
+}
+{
+abstract_compiler__AbstractCompilerVisitor__add_decl(var_v, var500); /* Direct call abstract_compiler#AbstractCompilerVisitor#add_decl on <var_v:AbstractCompilerVisitor>*/
+}
+} else {
+}
+if (varonce504) {
+var505 = varonce504;
+} else {
+var506 = "exit(signo);";
+var507 = 12;
+var508 = string__NativeString__to_s_with_length(var506, var507);
+var505 = var508;
+varonce504 = var505;
+}
+{
+abstract_compiler__AbstractCompilerVisitor__add_decl(var_v, var505); /* Direct call abstract_compiler#AbstractCompilerVisitor#add_decl on <var_v:AbstractCompilerVisitor>*/
+}
+if (varonce509) {
+var510 = varonce509;
+} else {
+var511 = "}";
+var512 = 1;
+var513 = string__NativeString__to_s_with_length(var511, var512);
+var510 = var513;
+varonce509 = var510;
+}
+{
+abstract_compiler__AbstractCompilerVisitor__add_decl(var_v, var510); /* Direct call abstract_compiler#AbstractCompilerVisitor#add_decl on <var_v:AbstractCompilerVisitor>*/
+}
+if (var_no_main){
+if (varonce514) {
+var515 = varonce514;
+} else {
+var516 = "int nit_main(int argc, char** argv) {";
+var517 = 37;
+var518 = string__NativeString__to_s_with_length(var516, var517);
+var515 = var518;
+varonce514 = var515;
+}
+{
+abstract_compiler__AbstractCompilerVisitor__add_decl(var_v, var515); /* Direct call abstract_compiler#AbstractCompilerVisitor#add_decl on <var_v:AbstractCompilerVisitor>*/
+}
+} else {
+if (varonce519) {
+var520 = varonce519;
 } else {
-var2 = 0; /* arg is null but recv is not */
+var521 = "int main(int argc, char** argv) {";
+var522 = 33;
+var523 = string__NativeString__to_s_with_length(var521, var522);
+var520 = var523;
+varonce519 = var520;
 }
-if (var2){
-if (varonce) {
-var3 = varonce;
+{
+abstract_compiler__AbstractCompilerVisitor__add_decl(var_v, var520); /* Direct call abstract_compiler#AbstractCompilerVisitor#add_decl on <var_v:AbstractCompilerVisitor>*/
+}
+}
+if (varonce524) {
+var525 = varonce524;
 } else {
-var4 = "?: ";
-var5 = 3;
-var6 = string__NativeString__to_s_with_length(var4, var5);
-var3 = var6;
-varonce = var3;
+var526 = "signal(SIGABRT, sig_handler);";
+var527 = 29;
+var528 = string__NativeString__to_s_with_length(var526, var527);
+var525 = var528;
+varonce524 = var525;
 }
-var7 = NEW_array__Array(&type_array__Arraykernel__Object);
-{ /* var7 = array_instance Array[Object] */
-var8 = 2;
-var9 = NEW_array__NativeArray(var8, &type_array__NativeArraykernel__Object);
-((struct instance_array__NativeArray*)var9)->values[0] = (val*) var3;
-((struct instance_array__NativeArray*)var9)->values[1] = (val*) var_message;
-((void (*)(val*, val*, long))(var7->class->vft[COLOR_array__Array__with_native]))(var7, var9, var8) /* with_native on <var7:Array[Object]>*/;
-CHECK_NEW_array__Array(var7);
+{
+abstract_compiler__AbstractCompilerVisitor__add(var_v, var525); /* Direct call abstract_compiler#AbstractCompilerVisitor#add on <var_v:AbstractCompilerVisitor>*/
 }
-var10 = ((val* (*)(val*))(var7->class->vft[COLOR_string__Object__to_s]))(var7) /* to_s on <var7:Array[Object]>*/;
-((void (*)(val*, val*))(self->class->vft[COLOR_file__Object__print]))(self, var10) /* print on <self:AbstractCompilerVisitor>*/;
+if (varonce529) {
+var530 = varonce529;
 } else {
-((void (*)(val*, val*))(var_node->class->vft[COLOR_parser_nodes__ANode__debug]))(var_node, var_message) /* debug on <var_node:nullable ANode(ANode)>*/;
+var531 = "signal(SIGFPE, sig_handler);";
+var532 = 28;
+var533 = string__NativeString__to_s_with_length(var531, var532);
+var530 = var533;
+varonce529 = var530;
 }
-if (varonce11) {
-var12 = varonce11;
+{
+abstract_compiler__AbstractCompilerVisitor__add(var_v, var530); /* Direct call abstract_compiler#AbstractCompilerVisitor#add on <var_v:AbstractCompilerVisitor>*/
+}
+if (varonce534) {
+var535 = varonce534;
 } else {
-var13 = "/* DEBUG: ";
-var14 = 10;
-var15 = string__NativeString__to_s_with_length(var13, var14);
-var12 = var15;
-varonce11 = var12;
+var536 = "signal(SIGILL, sig_handler);";
+var537 = 28;
+var538 = string__NativeString__to_s_with_length(var536, var537);
+var535 = var538;
+varonce534 = var535;
 }
-if (varonce16) {
-var17 = varonce16;
+{
+abstract_compiler__AbstractCompilerVisitor__add(var_v, var535); /* Direct call abstract_compiler#AbstractCompilerVisitor#add on <var_v:AbstractCompilerVisitor>*/
+}
+if (varonce539) {
+var540 = varonce539;
 } else {
-var18 = " */";
-var19 = 3;
-var20 = string__NativeString__to_s_with_length(var18, var19);
-var17 = var20;
-varonce16 = var17;
+var541 = "signal(SIGINT, sig_handler);";
+var542 = 28;
+var543 = string__NativeString__to_s_with_length(var541, var542);
+var540 = var543;
+varonce539 = var540;
 }
-var21 = NEW_array__Array(&type_array__Arraykernel__Object);
-{ /* var21 = array_instance Array[Object] */
-var22 = 3;
-var23 = NEW_array__NativeArray(var22, &type_array__NativeArraykernel__Object);
-((struct instance_array__NativeArray*)var23)->values[0] = (val*) var12;
-((struct instance_array__NativeArray*)var23)->values[1] = (val*) var_message;
-((struct instance_array__NativeArray*)var23)->values[2] = (val*) var17;
-((void (*)(val*, val*, long))(var21->class->vft[COLOR_array__Array__with_native]))(var21, var23, var22) /* with_native on <var21:Array[Object]>*/;
-CHECK_NEW_array__Array(var21);
+{
+abstract_compiler__AbstractCompilerVisitor__add(var_v, var540); /* Direct call abstract_compiler#AbstractCompilerVisitor#add on <var_v:AbstractCompilerVisitor>*/
 }
-var24 = ((val* (*)(val*))(var21->class->vft[COLOR_string__Object__to_s]))(var21) /* to_s on <var21:Array[Object]>*/;
-((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(self, var24) /* add on <self:AbstractCompilerVisitor>*/;
-RET_LABEL:;
+if (varonce544) {
+var545 = varonce544;
+} else {
+var546 = "signal(SIGTERM, sig_handler);";
+var547 = 29;
+var548 = string__NativeString__to_s_with_length(var546, var547);
+var545 = var548;
+varonce544 = var545;
 }
-/* method abstract_compiler#AbstractCompilerVisitor#debug for (self: Object, String) */
-void VIRTUAL_abstract_compiler__AbstractCompilerVisitor__debug(val* self, val* p0) {
-abstract_compiler__AbstractCompilerVisitor__debug(self, p0);
-RET_LABEL:;
+{
+abstract_compiler__AbstractCompilerVisitor__add(var_v, var545); /* Direct call abstract_compiler#AbstractCompilerVisitor#add on <var_v:AbstractCompilerVisitor>*/
 }
-/* method abstract_compiler#AbstractRuntimeFunction#mmethoddef for (self: AbstractRuntimeFunction): MMethodDef */
-val* abstract_compiler__AbstractRuntimeFunction__mmethoddef(val* self) {
-val* var /* : MMethodDef */;
-val* var1 /* : MMethodDef */;
-var1 = self->attrs[COLOR_abstract_compiler__AbstractRuntimeFunction___64dmmethoddef].val; /* @mmethoddef on <self:AbstractRuntimeFunction> */
-if (var1 == NULL) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Uninitialized attribute @mmethoddef", "src/abstract_compiler.nit", 969);
-exit(1);
+if (varonce549) {
+var550 = varonce549;
+} else {
+var551 = "signal(SIGSEGV, sig_handler);";
+var552 = 29;
+var553 = string__NativeString__to_s_with_length(var551, var552);
+var550 = var553;
+varonce549 = var550;
 }
-var = var1;
-RET_LABEL:;
-return var;
+{
+abstract_compiler__AbstractCompilerVisitor__add(var_v, var550); /* Direct call abstract_compiler#AbstractCompilerVisitor#add on <var_v:AbstractCompilerVisitor>*/
 }
-/* method abstract_compiler#AbstractRuntimeFunction#mmethoddef for (self: Object): MMethodDef */
-val* VIRTUAL_abstract_compiler__AbstractRuntimeFunction__mmethoddef(val* self) {
-val* var /* : MMethodDef */;
-val* var1 /* : MMethodDef */;
-var1 = abstract_compiler__AbstractRuntimeFunction__mmethoddef(self);
-var = var1;
-RET_LABEL:;
-return var;
+if (varonce554) {
+var555 = varonce554;
+} else {
+var556 = "signal(SIGPIPE, sig_handler);";
+var557 = 29;
+var558 = string__NativeString__to_s_with_length(var556, var557);
+var555 = var558;
+varonce554 = var555;
 }
-/* method abstract_compiler#AbstractRuntimeFunction#mmethoddef= for (self: AbstractRuntimeFunction, MMethodDef) */
-void abstract_compiler__AbstractRuntimeFunction__mmethoddef_61d(val* self, val* p0) {
-self->attrs[COLOR_abstract_compiler__AbstractRuntimeFunction___64dmmethoddef].val = p0; /* @mmethoddef on <self:AbstractRuntimeFunction> */
-RET_LABEL:;
+{
+abstract_compiler__AbstractCompilerVisitor__add(var_v, var555); /* Direct call abstract_compiler#AbstractCompilerVisitor#add on <var_v:AbstractCompilerVisitor>*/
 }
-/* method abstract_compiler#AbstractRuntimeFunction#mmethoddef= for (self: Object, MMethodDef) */
-void VIRTUAL_abstract_compiler__AbstractRuntimeFunction__mmethoddef_61d(val* self, val* p0) {
-abstract_compiler__AbstractRuntimeFunction__mmethoddef_61d(self, p0);
-RET_LABEL:;
+if (varonce559) {
+var560 = varonce559;
+} else {
+var561 = "glob_argc = argc; glob_argv = argv;";
+var562 = 35;
+var563 = string__NativeString__to_s_with_length(var561, var562);
+var560 = var563;
+varonce559 = var560;
 }
-/* method abstract_compiler#AbstractRuntimeFunction#c_name for (self: AbstractRuntimeFunction): String */
-val* abstract_compiler__AbstractRuntimeFunction__c_name(val* self) {
-val* var /* : String */;
-val* var1 /* : nullable String */;
-val* var_res /* var res: nullable String */;
-val* var2 /* : null */;
-short int var3 /* : Bool */;
-val* var4 /* : String */;
-var1 = ((val* (*)(val*))(self->class->vft[COLOR_abstract_compiler__AbstractRuntimeFunction__c_name_cache]))(self) /* c_name_cache on <self:AbstractRuntimeFunction>*/;
-var_res = var1;
-var2 = NULL;
-if (var_res == NULL) {
-var3 = 0; /* is null */
+{
+abstract_compiler__AbstractCompilerVisitor__add(var_v, var560); /* Direct call abstract_compiler#AbstractCompilerVisitor#add on <var_v:AbstractCompilerVisitor>*/
+}
+if (varonce564) {
+var565 = varonce564;
 } else {
-var3 = 1; /* arg is null and recv is not */
+var566 = "initialize_gc_option();";
+var567 = 23;
+var568 = string__NativeString__to_s_with_length(var566, var567);
+var565 = var568;
+varonce564 = var565;
 }
-if (var3){
-var = var_res;
-goto RET_LABEL;
+{
+abstract_compiler__AbstractCompilerVisitor__add(var_v, var565); /* Direct call abstract_compiler#AbstractCompilerVisitor#add on <var_v:AbstractCompilerVisitor>*/
+}
+if (varonce569) {
+var570 = varonce569;
 } else {
+var571 = "initialize_nitni_global_refs();";
+var572 = 31;
+var573 = string__NativeString__to_s_with_length(var571, var572);
+var570 = var573;
+varonce569 = var570;
 }
-var4 = ((val* (*)(val*))(self->class->vft[COLOR_abstract_compiler__AbstractRuntimeFunction__build_c_name]))(self) /* build_c_name on <self:AbstractRuntimeFunction>*/;
-var_res = var4;
-((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AbstractRuntimeFunction__c_name_cache_61d]))(self, var_res) /* c_name_cache= on <self:AbstractRuntimeFunction>*/;
-var = var_res;
-goto RET_LABEL;
-RET_LABEL:;
-return var;
+{
+abstract_compiler__AbstractCompilerVisitor__add(var_v, var570); /* Direct call abstract_compiler#AbstractCompilerVisitor#add on <var_v:AbstractCompilerVisitor>*/
 }
-/* method abstract_compiler#AbstractRuntimeFunction#c_name for (self: Object): String */
-val* VIRTUAL_abstract_compiler__AbstractRuntimeFunction__c_name(val* self) {
-val* var /* : String */;
-val* var1 /* : String */;
-var1 = abstract_compiler__AbstractRuntimeFunction__c_name(self);
-var = var1;
-RET_LABEL:;
-return var;
+{
+{ /* Inline abstract_compiler#AbstractCompiler#mainmodule (self) on <self:AbstractCompiler> */
+var576 = self->attrs[COLOR_abstract_compiler__AbstractCompiler___mainmodule].val; /* _mainmodule on <self:AbstractCompiler> */
+if (unlikely(var576 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _mainmodule");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 463);
+show_backtrace(1);
+}
+var574 = var576;
+RET_LABEL575:(void)0;
 }
-/* method abstract_compiler#AbstractRuntimeFunction#build_c_name for (self: AbstractRuntimeFunction): String */
-val* abstract_compiler__AbstractRuntimeFunction__build_c_name(val* self) {
-val* var /* : String */;
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Deferred method called", "src/abstract_compiler.nit", 983);
-exit(1);
-RET_LABEL:;
-return var;
 }
-/* method abstract_compiler#AbstractRuntimeFunction#build_c_name for (self: Object): String */
-val* VIRTUAL_abstract_compiler__AbstractRuntimeFunction__build_c_name(val* self) {
-val* var /* : String */;
-val* var1 /* : String */;
-var1 = abstract_compiler__AbstractRuntimeFunction__build_c_name(self);
-var = var1;
-RET_LABEL:;
-return var;
+{
+var577 = model__MModule__sys_type(var574);
+}
+var_main_type = var577;
+var578 = NULL;
+if (var_main_type == NULL) {
+var579 = 0; /* is null */
+} else {
+var579 = 1; /* arg is null and recv is not */
+}
+if (0) {
+{ /* Inline kernel#Object#!= (var_main_type,var578) on <var_main_type:nullable MClassType> */
+var_other = var578;
+{
+var583 = ((short int (*)(val*, val*))(var_main_type->class->vft[COLOR_kernel__Object___61d_61d]))(var_main_type, var_other) /* == on <var_main_type:nullable MClassType(MClassType)>*/;
+var582 = var583;
+}
+var584 = !var582;
+var580 = var584;
+goto RET_LABEL581;
+RET_LABEL581:(void)0;
+}
+var579 = var580;
+}
+if (var579){
+{
+{ /* Inline abstract_compiler#AbstractCompilerVisitor#compiler (var_v) on <var_v:AbstractCompilerVisitor> */
+var587 = var_v->attrs[COLOR_abstract_compiler__AbstractCompilerVisitor___compiler].val; /* _compiler on <var_v:AbstractCompilerVisitor> */
+if (unlikely(var587 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _compiler");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 1041);
+show_backtrace(1);
+}
+var585 = var587;
+RET_LABEL586:(void)0;
+}
+}
+{
+{ /* Inline abstract_compiler#AbstractCompiler#mainmodule (var585) on <var585:AbstractCompiler> */
+var590 = var585->attrs[COLOR_abstract_compiler__AbstractCompiler___mainmodule].val; /* _mainmodule on <var585:AbstractCompiler> */
+if (unlikely(var590 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _mainmodule");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 463);
+show_backtrace(1);
+}
+var588 = var590;
+RET_LABEL589:(void)0;
+}
+}
+var_mainmodule = var588;
+{
+var591 = ((val* (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__init_instance]))(var_v, var_main_type) /* init_instance on <var_v:AbstractCompilerVisitor>*/;
+}
+var_glob_sys = var591;
+if (varonce592) {
+var593 = varonce592;
+} else {
+var594 = "glob_sys = ";
+var595 = 11;
+var596 = string__NativeString__to_s_with_length(var594, var595);
+var593 = var596;
+varonce592 = var593;
+}
+if (varonce597) {
+var598 = varonce597;
+} else {
+var599 = ";";
+var600 = 1;
+var601 = string__NativeString__to_s_with_length(var599, var600);
+var598 = var601;
+varonce597 = var598;
+}
+var602 = NEW_array__Array(&type_array__Arraykernel__Object);
+{ /* var602 = array_instance Array[Object] */
+var603 = 3;
+var604 = NEW_array__NativeArray(var603, &type_array__NativeArraykernel__Object);
+((struct instance_array__NativeArray*)var604)->values[0] = (val*) var593;
+((struct instance_array__NativeArray*)var604)->values[1] = (val*) var_glob_sys;
+((struct instance_array__NativeArray*)var604)->values[2] = (val*) var598;
+{
+((void (*)(val*, val*, long))(var602->class->vft[COLOR_array__Array__with_native]))(var602, var604, var603) /* with_native on <var602:Array[Object]>*/;
+}
+}
+{
+var605 = ((val* (*)(val*))(var602->class->vft[COLOR_string__Object__to_s]))(var602) /* to_s on <var602:Array[Object]>*/;
+}
+{
+abstract_compiler__AbstractCompilerVisitor__add(var_v, var605); /* Direct call abstract_compiler#AbstractCompilerVisitor#add on <var_v:AbstractCompilerVisitor>*/
+}
+if (varonce606) {
+var607 = varonce606;
+} else {
+var608 = "init";
+var609 = 4;
+var610 = string__NativeString__to_s_with_length(var608, var609);
+var607 = var610;
+varonce606 = var607;
+}
+{
+{ /* Inline model#MClassType#mclass (var_main_type) on <var_main_type:nullable MClassType(MClassType)> */
+var613 = var_main_type->attrs[COLOR_model__MClassType___mclass].val; /* _mclass on <var_main_type:nullable MClassType(MClassType)> */
+if (unlikely(var613 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _mclass");
+PRINT_ERROR(" (%s:%d)\n", "model/model.nit", 986);
+show_backtrace(1);
+}
+var611 = var613;
+RET_LABEL612:(void)0;
+}
+}
+{
+var614 = model__MModule__try_get_primitive_method(var_mainmodule, var607, var611);
+}
+var_main_init = var614;
+var615 = NULL;
+if (var_main_init == NULL) {
+var616 = 0; /* is null */
+} else {
+var616 = 1; /* arg is null and recv is not */
+}
+if (0) {
+{ /* Inline kernel#Object#!= (var_main_init,var615) on <var_main_init:nullable MMethod> */
+var_other = var615;
+{
+var620 = ((short int (*)(val*, val*))(var_main_init->class->vft[COLOR_kernel__Object___61d_61d]))(var_main_init, var_other) /* == on <var_main_init:nullable MMethod(MMethod)>*/;
+var619 = var620;
+}
+var621 = !var619;
+var617 = var621;
+goto RET_LABEL618;
+RET_LABEL618:(void)0;
+}
+var616 = var617;
+}
+if (var616){
+var622 = NEW_array__Array(&type_array__Arrayabstract_compiler__RuntimeVariable);
+var623 = 1;
+{
+array__Array__with_capacity(var622, var623); /* Direct call array#Array#with_capacity on <var622:Array[RuntimeVariable]>*/
+}
+var_624 = var622;
+{
+array__AbstractArray__push(var_624, var_glob_sys); /* Direct call array#AbstractArray#push on <var_624:Array[RuntimeVariable]>*/
+}
+{
+var625 = separate_compiler__SeparateCompilerVisitor__send(var_v, var_main_init, var_624);
+}
+} else {
+}
+if (varonce627) {
+var628 = varonce627;
+} else {
+var629 = "run";
+var630 = 3;
+var631 = string__NativeString__to_s_with_length(var629, var630);
+var628 = var631;
+varonce627 = var628;
+}
+{
+{ /* Inline model#MClassType#mclass (var_main_type) on <var_main_type:nullable MClassType(MClassType)> */
+var634 = var_main_type->attrs[COLOR_model__MClassType___mclass].val; /* _mclass on <var_main_type:nullable MClassType(MClassType)> */
+if (unlikely(var634 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _mclass");
+PRINT_ERROR(" (%s:%d)\n", "model/model.nit", 986);
+show_backtrace(1);
+}
+var632 = var634;
+RET_LABEL633:(void)0;
+}
+}
+{
+var635 = model__MModule__try_get_primitive_method(var_mainmodule, var628, var632);
+}
+if (var635!=NULL) {
+var626 = var635;
+} else {
+if (varonce636) {
+var637 = varonce636;
+} else {
+var638 = "main";
+var639 = 4;
+var640 = string__NativeString__to_s_with_length(var638, var639);
+var637 = var640;
+varonce636 = var637;
+}
+{
+{ /* Inline model#MClassType#mclass (var_main_type) on <var_main_type:nullable MClassType(MClassType)> */
+var643 = var_main_type->attrs[COLOR_model__MClassType___mclass].val; /* _mclass on <var_main_type:nullable MClassType(MClassType)> */
+if (unlikely(var643 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _mclass");
+PRINT_ERROR(" (%s:%d)\n", "model/model.nit", 986);
+show_backtrace(1);
+}
+var641 = var643;
+RET_LABEL642:(void)0;
+}
+}
+{
+var644 = model__MModule__try_get_primitive_method(var_mainmodule, var637, var641);
+}
+var626 = var644;
+}
+var_main_method = var626;
+var645 = NULL;
+if (var_main_method == NULL) {
+var646 = 0; /* is null */
+} else {
+var646 = 1; /* arg is null and recv is not */
+}
+if (0) {
+{ /* Inline kernel#Object#!= (var_main_method,var645) on <var_main_method:nullable MMethod> */
+var_other = var645;
+{
+var650 = ((short int (*)(val*, val*))(var_main_method->class->vft[COLOR_kernel__Object___61d_61d]))(var_main_method, var_other) /* == on <var_main_method:nullable MMethod(MMethod)>*/;
+var649 = var650;
+}
+var651 = !var649;
+var647 = var651;
+goto RET_LABEL648;
+RET_LABEL648:(void)0;
+}
+var646 = var647;
+}
+if (var646){
+var652 = NEW_array__Array(&type_array__Arrayabstract_compiler__RuntimeVariable);
+var653 = 1;
+{
+array__Array__with_capacity(var652, var653); /* Direct call array#Array#with_capacity on <var652:Array[RuntimeVariable]>*/
+}
+var_654 = var652;
+{
+array__AbstractArray__push(var_654, var_glob_sys); /* Direct call array#AbstractArray#push on <var_654:Array[RuntimeVariable]>*/
+}
+{
+var655 = separate_compiler__SeparateCompilerVisitor__send(var_v, var_main_method, var_654);
+}
+} else {
+}
+} else {
+}
+{
+{ /* Inline abstract_compiler#AbstractCompiler#modelbuilder (self) on <self:AbstractCompiler> */
+var658 = self->attrs[COLOR_abstract_compiler__AbstractCompiler___modelbuilder].val; /* _modelbuilder on <self:AbstractCompiler> */
+if (unlikely(var658 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _modelbuilder");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 470);
+show_backtrace(1);
+}
+var656 = var658;
+RET_LABEL657:(void)0;
+}
+}
+{
+{ /* Inline modelbuilder#ModelBuilder#toolcontext (var656) on <var656:ModelBuilder> */
+var661 = var656->attrs[COLOR_modelbuilder__ModelBuilder___toolcontext].val; /* _toolcontext on <var656:ModelBuilder> */
+if (unlikely(var661 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _toolcontext");
+PRINT_ERROR(" (%s:%d)\n", "modelbuilder.nit", 106);
+show_backtrace(1);
+}
+var659 = var661;
+RET_LABEL660:(void)0;
+}
+}
+{
+{ /* Inline abstract_compiler#ToolContext#opt_typing_test_metrics (var659) on <var659:ToolContext> */
+var664 = var659->attrs[COLOR_abstract_compiler__ToolContext___opt_typing_test_metrics].val; /* _opt_typing_test_metrics on <var659:ToolContext> */
+if (unlikely(var664 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _opt_typing_test_metrics");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 61);
+show_backtrace(1);
+}
+var662 = var664;
+RET_LABEL663:(void)0;
+}
+}
+{
+{ /* Inline opts#Option#value (var662) on <var662:OptionBool> */
+var667 = var662->attrs[COLOR_opts__Option___value].val; /* _value on <var662:OptionBool> */
+var665 = var667;
+RET_LABEL666:(void)0;
+}
+}
+var668 = ((struct instance_kernel__Bool*)var665)->value; /* autounbox from nullable Object to Bool */;
+if (var668){
+if (varonce669) {
+var670 = varonce669;
+} else {
+var671 = "long count_type_test_resolved_total = 0;";
+var672 = 40;
+var673 = string__NativeString__to_s_with_length(var671, var672);
+var670 = var673;
+varonce669 = var670;
+}
+{
+abstract_compiler__AbstractCompilerVisitor__add_decl(var_v, var670); /* Direct call abstract_compiler#AbstractCompilerVisitor#add_decl on <var_v:AbstractCompilerVisitor>*/
+}
+if (varonce674) {
+var675 = varonce674;
+} else {
+var676 = "long count_type_test_unresolved_total = 0;";
+var677 = 42;
+var678 = string__NativeString__to_s_with_length(var676, var677);
+var675 = var678;
+varonce674 = var675;
+}
+{
+abstract_compiler__AbstractCompilerVisitor__add_decl(var_v, var675); /* Direct call abstract_compiler#AbstractCompilerVisitor#add_decl on <var_v:AbstractCompilerVisitor>*/
+}
+if (varonce679) {
+var680 = varonce679;
+} else {
+var681 = "long count_type_test_skipped_total = 0;";
+var682 = 39;
+var683 = string__NativeString__to_s_with_length(var681, var682);
+var680 = var683;
+varonce679 = var680;
+}
+{
+abstract_compiler__AbstractCompilerVisitor__add_decl(var_v, var680); /* Direct call abstract_compiler#AbstractCompilerVisitor#add_decl on <var_v:AbstractCompilerVisitor>*/
+}
+if (varonce684) {
+var685 = varonce684;
+} else {
+var686 = "long count_type_test_total_total = 0;";
+var687 = 37;
+var688 = string__NativeString__to_s_with_length(var686, var687);
+var685 = var688;
+varonce684 = var685;
+}
+{
+abstract_compiler__AbstractCompilerVisitor__add_decl(var_v, var685); /* Direct call abstract_compiler#AbstractCompilerVisitor#add_decl on <var_v:AbstractCompilerVisitor>*/
+}
+{
+{ /* Inline abstract_compiler#AbstractCompiler#count_type_test_tags (self) on <self:AbstractCompiler> */
+var691 = self->attrs[COLOR_abstract_compiler__AbstractCompiler___count_type_test_tags].val; /* _count_type_test_tags on <self:AbstractCompiler> */
+if (unlikely(var691 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _count_type_test_tags");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 944);
+show_backtrace(1);
+}
+var689 = var691;
+RET_LABEL690:(void)0;
+}
+}
+var_692 = var689;
+{
+var693 = array__AbstractArrayRead__iterator(var_692);
+}
+var_694 = var693;
+for(;;) {
+{
+var695 = array__ArrayIterator__is_ok(var_694);
+}
+if (var695){
+{
+var696 = array__ArrayIterator__item(var_694);
+}
+var_tag697 = var696;
+if (varonce698) {
+var699 = varonce698;
+} else {
+var700 = "long count_type_test_total_";
+var701 = 27;
+var702 = string__NativeString__to_s_with_length(var700, var701);
+var699 = var702;
+varonce698 = var699;
+}
+if (varonce703) {
+var704 = varonce703;
+} else {
+var705 = ";";
+var706 = 1;
+var707 = string__NativeString__to_s_with_length(var705, var706);
+var704 = var707;
+varonce703 = var704;
+}
+var708 = NEW_array__Array(&type_array__Arraykernel__Object);
+{ /* var708 = array_instance Array[Object] */
+var709 = 3;
+var710 = NEW_array__NativeArray(var709, &type_array__NativeArraykernel__Object);
+((struct instance_array__NativeArray*)var710)->values[0] = (val*) var699;
+((struct instance_array__NativeArray*)var710)->values[1] = (val*) var_tag697;
+((struct instance_array__NativeArray*)var710)->values[2] = (val*) var704;
+{
+((void (*)(val*, val*, long))(var708->class->vft[COLOR_array__Array__with_native]))(var708, var710, var709) /* with_native on <var708:Array[Object]>*/;
+}
+}
+{
+var711 = ((val* (*)(val*))(var708->class->vft[COLOR_string__Object__to_s]))(var708) /* to_s on <var708:Array[Object]>*/;
+}
+{
+abstract_compiler__AbstractCompilerVisitor__add_decl(var_v, var711); /* Direct call abstract_compiler#AbstractCompilerVisitor#add_decl on <var_v:AbstractCompilerVisitor>*/
+}
+if (varonce712) {
+var713 = varonce712;
+} else {
+var714 = "count_type_test_total_";
+var715 = 22;
+var716 = string__NativeString__to_s_with_length(var714, var715);
+var713 = var716;
+varonce712 = var713;
+}
+if (varonce717) {
+var718 = varonce717;
+} else {
+var719 = " = count_type_test_resolved_";
+var720 = 28;
+var721 = string__NativeString__to_s_with_length(var719, var720);
+var718 = var721;
+varonce717 = var718;
+}
+if (varonce722) {
+var723 = varonce722;
+} else {
+var724 = " + count_type_test_unresolved_";
+var725 = 30;
+var726 = string__NativeString__to_s_with_length(var724, var725);
+var723 = var726;
+varonce722 = var723;
+}
+if (varonce727) {
+var728 = varonce727;
+} else {
+var729 = " + count_type_test_skipped_";
+var730 = 27;
+var731 = string__NativeString__to_s_with_length(var729, var730);
+var728 = var731;
+varonce727 = var728;
+}
+if (varonce732) {
+var733 = varonce732;
+} else {
+var734 = ";";
+var735 = 1;
+var736 = string__NativeString__to_s_with_length(var734, var735);
+var733 = var736;
+varonce732 = var733;
+}
+var737 = NEW_array__Array(&type_array__Arraykernel__Object);
+{ /* var737 = array_instance Array[Object] */
+var738 = 9;
+var739 = NEW_array__NativeArray(var738, &type_array__NativeArraykernel__Object);
+((struct instance_array__NativeArray*)var739)->values[0] = (val*) var713;
+((struct instance_array__NativeArray*)var739)->values[1] = (val*) var_tag697;
+((struct instance_array__NativeArray*)var739)->values[2] = (val*) var718;
+((struct instance_array__NativeArray*)var739)->values[3] = (val*) var_tag697;
+((struct instance_array__NativeArray*)var739)->values[4] = (val*) var723;
+((struct instance_array__NativeArray*)var739)->values[5] = (val*) var_tag697;
+((struct instance_array__NativeArray*)var739)->values[6] = (val*) var728;
+((struct instance_array__NativeArray*)var739)->values[7] = (val*) var_tag697;
+((struct instance_array__NativeArray*)var739)->values[8] = (val*) var733;
+{
+((void (*)(val*, val*, long))(var737->class->vft[COLOR_array__Array__with_native]))(var737, var739, var738) /* with_native on <var737:Array[Object]>*/;
+}
+}
+{
+var740 = ((val* (*)(val*))(var737->class->vft[COLOR_string__Object__to_s]))(var737) /* to_s on <var737:Array[Object]>*/;
+}
+{
+abstract_compiler__AbstractCompilerVisitor__add(var_v, var740); /* Direct call abstract_compiler#AbstractCompilerVisitor#add on <var_v:AbstractCompilerVisitor>*/
+}
+if (varonce741) {
+var742 = varonce741;
+} else {
+var743 = "count_type_test_resolved_total += count_type_test_resolved_";
+var744 = 59;
+var745 = string__NativeString__to_s_with_length(var743, var744);
+var742 = var745;
+varonce741 = var742;
+}
+if (varonce746) {
+var747 = varonce746;
+} else {
+var748 = ";";
+var749 = 1;
+var750 = string__NativeString__to_s_with_length(var748, var749);
+var747 = var750;
+varonce746 = var747;
+}
+var751 = NEW_array__Array(&type_array__Arraykernel__Object);
+{ /* var751 = array_instance Array[Object] */
+var752 = 3;
+var753 = NEW_array__NativeArray(var752, &type_array__NativeArraykernel__Object);
+((struct instance_array__NativeArray*)var753)->values[0] = (val*) var742;
+((struct instance_array__NativeArray*)var753)->values[1] = (val*) var_tag697;
+((struct instance_array__NativeArray*)var753)->values[2] = (val*) var747;
+{
+((void (*)(val*, val*, long))(var751->class->vft[COLOR_array__Array__with_native]))(var751, var753, var752) /* with_native on <var751:Array[Object]>*/;
+}
+}
+{
+var754 = ((val* (*)(val*))(var751->class->vft[COLOR_string__Object__to_s]))(var751) /* to_s on <var751:Array[Object]>*/;
+}
+{
+abstract_compiler__AbstractCompilerVisitor__add(var_v, var754); /* Direct call abstract_compiler#AbstractCompilerVisitor#add on <var_v:AbstractCompilerVisitor>*/
+}
+if (varonce755) {
+var756 = varonce755;
+} else {
+var757 = "count_type_test_unresolved_total += count_type_test_unresolved_";
+var758 = 63;
+var759 = string__NativeString__to_s_with_length(var757, var758);
+var756 = var759;
+varonce755 = var756;
+}
+if (varonce760) {
+var761 = varonce760;
+} else {
+var762 = ";";
+var763 = 1;
+var764 = string__NativeString__to_s_with_length(var762, var763);
+var761 = var764;
+varonce760 = var761;
+}
+var765 = NEW_array__Array(&type_array__Arraykernel__Object);
+{ /* var765 = array_instance Array[Object] */
+var766 = 3;
+var767 = NEW_array__NativeArray(var766, &type_array__NativeArraykernel__Object);
+((struct instance_array__NativeArray*)var767)->values[0] = (val*) var756;
+((struct instance_array__NativeArray*)var767)->values[1] = (val*) var_tag697;
+((struct instance_array__NativeArray*)var767)->values[2] = (val*) var761;
+{
+((void (*)(val*, val*, long))(var765->class->vft[COLOR_array__Array__with_native]))(var765, var767, var766) /* with_native on <var765:Array[Object]>*/;
+}
+}
+{
+var768 = ((val* (*)(val*))(var765->class->vft[COLOR_string__Object__to_s]))(var765) /* to_s on <var765:Array[Object]>*/;
+}
+{
+abstract_compiler__AbstractCompilerVisitor__add(var_v, var768); /* Direct call abstract_compiler#AbstractCompilerVisitor#add on <var_v:AbstractCompilerVisitor>*/
+}
+if (varonce769) {
+var770 = varonce769;
+} else {
+var771 = "count_type_test_skipped_total += count_type_test_skipped_";
+var772 = 57;
+var773 = string__NativeString__to_s_with_length(var771, var772);
+var770 = var773;
+varonce769 = var770;
+}
+if (varonce774) {
+var775 = varonce774;
+} else {
+var776 = ";";
+var777 = 1;
+var778 = string__NativeString__to_s_with_length(var776, var777);
+var775 = var778;
+varonce774 = var775;
+}
+var779 = NEW_array__Array(&type_array__Arraykernel__Object);
+{ /* var779 = array_instance Array[Object] */
+var780 = 3;
+var781 = NEW_array__NativeArray(var780, &type_array__NativeArraykernel__Object);
+((struct instance_array__NativeArray*)var781)->values[0] = (val*) var770;
+((struct instance_array__NativeArray*)var781)->values[1] = (val*) var_tag697;
+((struct instance_array__NativeArray*)var781)->values[2] = (val*) var775;
+{
+((void (*)(val*, val*, long))(var779->class->vft[COLOR_array__Array__with_native]))(var779, var781, var780) /* with_native on <var779:Array[Object]>*/;
+}
+}
+{
+var782 = ((val* (*)(val*))(var779->class->vft[COLOR_string__Object__to_s]))(var779) /* to_s on <var779:Array[Object]>*/;
+}
+{
+abstract_compiler__AbstractCompilerVisitor__add(var_v, var782); /* Direct call abstract_compiler#AbstractCompilerVisitor#add on <var_v:AbstractCompilerVisitor>*/
+}
+if (varonce783) {
+var784 = varonce783;
+} else {
+var785 = "count_type_test_total_total += count_type_test_total_";
+var786 = 53;
+var787 = string__NativeString__to_s_with_length(var785, var786);
+var784 = var787;
+varonce783 = var784;
+}
+if (varonce788) {
+var789 = varonce788;
+} else {
+var790 = ";";
+var791 = 1;
+var792 = string__NativeString__to_s_with_length(var790, var791);
+var789 = var792;
+varonce788 = var789;
+}
+var793 = NEW_array__Array(&type_array__Arraykernel__Object);
+{ /* var793 = array_instance Array[Object] */
+var794 = 3;
+var795 = NEW_array__NativeArray(var794, &type_array__NativeArraykernel__Object);
+((struct instance_array__NativeArray*)var795)->values[0] = (val*) var784;
+((struct instance_array__NativeArray*)var795)->values[1] = (val*) var_tag697;
+((struct instance_array__NativeArray*)var795)->values[2] = (val*) var789;
+{
+((void (*)(val*, val*, long))(var793->class->vft[COLOR_array__Array__with_native]))(var793, var795, var794) /* with_native on <var793:Array[Object]>*/;
+}
+}
+{
+var796 = ((val* (*)(val*))(var793->class->vft[COLOR_string__Object__to_s]))(var793) /* to_s on <var793:Array[Object]>*/;
+}
+{
+abstract_compiler__AbstractCompilerVisitor__add(var_v, var796); /* Direct call abstract_compiler#AbstractCompilerVisitor#add on <var_v:AbstractCompilerVisitor>*/
+}
+{
+array__ArrayIterator__next(var_694); /* Direct call array#ArrayIterator#next on <var_694:ArrayIterator[String]>*/
+}
+} else {
+goto BREAK_label797;
+}
+}
+BREAK_label797: (void)0;
+{
+{ /* Inline abstract_collection#Iterator#finish (var_694) on <var_694:ArrayIterator[String]> */
+RET_LABEL798:(void)0;
+}
+}
+if (varonce799) {
+var800 = varonce799;
+} else {
+var801 = "printf(\"# dynamic count_type_test: total %l\\n\");";
+var802 = 48;
+var803 = string__NativeString__to_s_with_length(var801, var802);
+var800 = var803;
+varonce799 = var800;
+}
+{
+abstract_compiler__AbstractCompilerVisitor__add(var_v, var800); /* Direct call abstract_compiler#AbstractCompilerVisitor#add on <var_v:AbstractCompilerVisitor>*/
+}
+if (varonce804) {
+var805 = varonce804;
+} else {
+var806 = "printf(\"\\tresolved\\tunresolved\\tskipped\\ttotal\\n\");";
+var807 = 51;
+var808 = string__NativeString__to_s_with_length(var806, var807);
+var805 = var808;
+varonce804 = var805;
+}
+{
+abstract_compiler__AbstractCompilerVisitor__add(var_v, var805); /* Direct call abstract_compiler#AbstractCompilerVisitor#add on <var_v:AbstractCompilerVisitor>*/
+}
+{
+{ /* Inline abstract_compiler#AbstractCompiler#count_type_test_tags (self) on <self:AbstractCompiler> */
+var811 = self->attrs[COLOR_abstract_compiler__AbstractCompiler___count_type_test_tags].val; /* _count_type_test_tags on <self:AbstractCompiler> */
+if (unlikely(var811 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _count_type_test_tags");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 944);
+show_backtrace(1);
+}
+var809 = var811;
+RET_LABEL810:(void)0;
+}
+}
+{
+var812 = array__Collection__to_a(var809);
+}
+var_tags = var812;
+if (varonce813) {
+var814 = varonce813;
+} else {
+var815 = "total";
+var816 = 5;
+var817 = string__NativeString__to_s_with_length(var815, var816);
+var814 = var817;
+varonce813 = var814;
+}
+{
+array__Array__add(var_tags, var814); /* Direct call array#Array#add on <var_tags:Array[String]>*/
+}
+var_818 = var_tags;
+{
+var819 = array__AbstractArrayRead__iterator(var_818);
+}
+var_820 = var819;
+for(;;) {
+{
+var821 = array__ArrayIterator__is_ok(var_820);
+}
+if (var821){
+{
+var822 = array__ArrayIterator__item(var_820);
+}
+var_tag823 = var822;
+if (varonce824) {
+var825 = varonce824;
+} else {
+var826 = "printf(\"";
+var827 = 8;
+var828 = string__NativeString__to_s_with_length(var826, var827);
+var825 = var828;
+varonce824 = var825;
 }
-/* method abstract_compiler#AbstractRuntimeFunction#c_name_cache for (self: AbstractRuntimeFunction): nullable String */
-val* abstract_compiler__AbstractRuntimeFunction__c_name_cache(val* self) {
-val* var /* : nullable String */;
-val* var1 /* : nullable String */;
-var1 = self->attrs[COLOR_abstract_compiler__AbstractRuntimeFunction___64dc_name_cache].val; /* @c_name_cache on <self:AbstractRuntimeFunction> */
-var = var1;
-RET_LABEL:;
-return var;
+if (varonce829) {
+var830 = varonce829;
+} else {
+var831 = "\");";
+var832 = 3;
+var833 = string__NativeString__to_s_with_length(var831, var832);
+var830 = var833;
+varonce829 = var830;
+}
+var834 = NEW_array__Array(&type_array__Arraykernel__Object);
+{ /* var834 = array_instance Array[Object] */
+var835 = 3;
+var836 = NEW_array__NativeArray(var835, &type_array__NativeArraykernel__Object);
+((struct instance_array__NativeArray*)var836)->values[0] = (val*) var825;
+((struct instance_array__NativeArray*)var836)->values[1] = (val*) var_tag823;
+((struct instance_array__NativeArray*)var836)->values[2] = (val*) var830;
+{
+((void (*)(val*, val*, long))(var834->class->vft[COLOR_array__Array__with_native]))(var834, var836, var835) /* with_native on <var834:Array[Object]>*/;
+}
+}
+{
+var837 = ((val* (*)(val*))(var834->class->vft[COLOR_string__Object__to_s]))(var834) /* to_s on <var834:Array[Object]>*/;
+}
+{
+abstract_compiler__AbstractCompilerVisitor__add(var_v, var837); /* Direct call abstract_compiler#AbstractCompilerVisitor#add on <var_v:AbstractCompilerVisitor>*/
+}
+if (varonce838) {
+var839 = varonce838;
+} else {
+var840 = "printf(\"\\t%ld (%.2f%%)\", count_type_test_resolved_";
+var841 = 50;
+var842 = string__NativeString__to_s_with_length(var840, var841);
+var839 = var842;
+varonce838 = var839;
+}
+if (varonce843) {
+var844 = varonce843;
+} else {
+var845 = ", 100.0*count_type_test_resolved_";
+var846 = 33;
+var847 = string__NativeString__to_s_with_length(var845, var846);
+var844 = var847;
+varonce843 = var844;
+}
+if (varonce848) {
+var849 = varonce848;
+} else {
+var850 = "/count_type_test_total_total);";
+var851 = 30;
+var852 = string__NativeString__to_s_with_length(var850, var851);
+var849 = var852;
+varonce848 = var849;
+}
+var853 = NEW_array__Array(&type_array__Arraykernel__Object);
+{ /* var853 = array_instance Array[Object] */
+var854 = 5;
+var855 = NEW_array__NativeArray(var854, &type_array__NativeArraykernel__Object);
+((struct instance_array__NativeArray*)var855)->values[0] = (val*) var839;
+((struct instance_array__NativeArray*)var855)->values[1] = (val*) var_tag823;
+((struct instance_array__NativeArray*)var855)->values[2] = (val*) var844;
+((struct instance_array__NativeArray*)var855)->values[3] = (val*) var_tag823;
+((struct instance_array__NativeArray*)var855)->values[4] = (val*) var849;
+{
+((void (*)(val*, val*, long))(var853->class->vft[COLOR_array__Array__with_native]))(var853, var855, var854) /* with_native on <var853:Array[Object]>*/;
+}
+}
+{
+var856 = ((val* (*)(val*))(var853->class->vft[COLOR_string__Object__to_s]))(var853) /* to_s on <var853:Array[Object]>*/;
+}
+{
+abstract_compiler__AbstractCompilerVisitor__add(var_v, var856); /* Direct call abstract_compiler#AbstractCompilerVisitor#add on <var_v:AbstractCompilerVisitor>*/
+}
+if (varonce857) {
+var858 = varonce857;
+} else {
+var859 = "printf(\"\\t%ld (%.2f%%)\", count_type_test_unresolved_";
+var860 = 52;
+var861 = string__NativeString__to_s_with_length(var859, var860);
+var858 = var861;
+varonce857 = var858;
+}
+if (varonce862) {
+var863 = varonce862;
+} else {
+var864 = ", 100.0*count_type_test_unresolved_";
+var865 = 35;
+var866 = string__NativeString__to_s_with_length(var864, var865);
+var863 = var866;
+varonce862 = var863;
+}
+if (varonce867) {
+var868 = varonce867;
+} else {
+var869 = "/count_type_test_total_total);";
+var870 = 30;
+var871 = string__NativeString__to_s_with_length(var869, var870);
+var868 = var871;
+varonce867 = var868;
+}
+var872 = NEW_array__Array(&type_array__Arraykernel__Object);
+{ /* var872 = array_instance Array[Object] */
+var873 = 5;
+var874 = NEW_array__NativeArray(var873, &type_array__NativeArraykernel__Object);
+((struct instance_array__NativeArray*)var874)->values[0] = (val*) var858;
+((struct instance_array__NativeArray*)var874)->values[1] = (val*) var_tag823;
+((struct instance_array__NativeArray*)var874)->values[2] = (val*) var863;
+((struct instance_array__NativeArray*)var874)->values[3] = (val*) var_tag823;
+((struct instance_array__NativeArray*)var874)->values[4] = (val*) var868;
+{
+((void (*)(val*, val*, long))(var872->class->vft[COLOR_array__Array__with_native]))(var872, var874, var873) /* with_native on <var872:Array[Object]>*/;
+}
+}
+{
+var875 = ((val* (*)(val*))(var872->class->vft[COLOR_string__Object__to_s]))(var872) /* to_s on <var872:Array[Object]>*/;
+}
+{
+abstract_compiler__AbstractCompilerVisitor__add(var_v, var875); /* Direct call abstract_compiler#AbstractCompilerVisitor#add on <var_v:AbstractCompilerVisitor>*/
+}
+if (varonce876) {
+var877 = varonce876;
+} else {
+var878 = "printf(\"\\t%ld (%.2f%%)\", count_type_test_skipped_";
+var879 = 49;
+var880 = string__NativeString__to_s_with_length(var878, var879);
+var877 = var880;
+varonce876 = var877;
+}
+if (varonce881) {
+var882 = varonce881;
+} else {
+var883 = ", 100.0*count_type_test_skipped_";
+var884 = 32;
+var885 = string__NativeString__to_s_with_length(var883, var884);
+var882 = var885;
+varonce881 = var882;
 }
-/* method abstract_compiler#AbstractRuntimeFunction#c_name_cache for (self: Object): nullable String */
-val* VIRTUAL_abstract_compiler__AbstractRuntimeFunction__c_name_cache(val* self) {
-val* var /* : nullable String */;
-val* var1 /* : nullable String */;
-var1 = abstract_compiler__AbstractRuntimeFunction__c_name_cache(self);
-var = var1;
-RET_LABEL:;
-return var;
+if (varonce886) {
+var887 = varonce886;
+} else {
+var888 = "/count_type_test_total_total);";
+var889 = 30;
+var890 = string__NativeString__to_s_with_length(var888, var889);
+var887 = var890;
+varonce886 = var887;
 }
-/* method abstract_compiler#AbstractRuntimeFunction#c_name_cache= for (self: AbstractRuntimeFunction, nullable String) */
-void abstract_compiler__AbstractRuntimeFunction__c_name_cache_61d(val* self, val* p0) {
-self->attrs[COLOR_abstract_compiler__AbstractRuntimeFunction___64dc_name_cache].val = p0; /* @c_name_cache on <self:AbstractRuntimeFunction> */
-RET_LABEL:;
+var891 = NEW_array__Array(&type_array__Arraykernel__Object);
+{ /* var891 = array_instance Array[Object] */
+var892 = 5;
+var893 = NEW_array__NativeArray(var892, &type_array__NativeArraykernel__Object);
+((struct instance_array__NativeArray*)var893)->values[0] = (val*) var877;
+((struct instance_array__NativeArray*)var893)->values[1] = (val*) var_tag823;
+((struct instance_array__NativeArray*)var893)->values[2] = (val*) var882;
+((struct instance_array__NativeArray*)var893)->values[3] = (val*) var_tag823;
+((struct instance_array__NativeArray*)var893)->values[4] = (val*) var887;
+{
+((void (*)(val*, val*, long))(var891->class->vft[COLOR_array__Array__with_native]))(var891, var893, var892) /* with_native on <var891:Array[Object]>*/;
 }
-/* method abstract_compiler#AbstractRuntimeFunction#c_name_cache= for (self: Object, nullable String) */
-void VIRTUAL_abstract_compiler__AbstractRuntimeFunction__c_name_cache_61d(val* self, val* p0) {
-abstract_compiler__AbstractRuntimeFunction__c_name_cache_61d(self, p0);
-RET_LABEL:;
 }
-/* method abstract_compiler#AbstractRuntimeFunction#call for (self: AbstractRuntimeFunction, AbstractCompilerVisitor, Array[RuntimeVariable]): nullable RuntimeVariable */
-val* abstract_compiler__AbstractRuntimeFunction__call(val* self, val* p0, val* p1) {
-val* var /* : nullable RuntimeVariable */;
-short int var1 /* : Bool */;
-int cltype;
-int idtype;
-const struct type* type_struct;
-/* Covariant cast for argument 0 (v) <p0:AbstractCompilerVisitor> isa VISITOR */
-/* <p0:AbstractCompilerVisitor> isa VISITOR */
-type_struct = self->type->resolution_table->types[COLOR_abstract_compiler__AbstractRuntimeFunction_VTVISITOR];
-cltype = type_struct->color;
-idtype = type_struct->id;
-if(cltype >= p0->type->table_size) {
-var1 = 0;
-} else {
-var1 = p0->type->type_table[cltype] == idtype;
+{
+var894 = ((val* (*)(val*))(var891->class->vft[COLOR_string__Object__to_s]))(var891) /* to_s on <var891:Array[Object]>*/;
 }
-if (!var1) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "src/abstract_compiler.nit", 988);
-exit(1);
+{
+abstract_compiler__AbstractCompilerVisitor__add(var_v, var894); /* Direct call abstract_compiler#AbstractCompilerVisitor#add on <var_v:AbstractCompilerVisitor>*/
 }
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Deferred method called", "src/abstract_compiler.nit", 988);
-exit(1);
-RET_LABEL:;
-return var;
+if (varonce895) {
+var896 = varonce895;
+} else {
+var897 = "printf(\"\\t%ld (%.2f%%)\\n\", count_type_test_total_";
+var898 = 49;
+var899 = string__NativeString__to_s_with_length(var897, var898);
+var896 = var899;
+varonce895 = var896;
 }
-/* method abstract_compiler#AbstractRuntimeFunction#call for (self: Object, AbstractCompilerVisitor, Array[RuntimeVariable]): nullable RuntimeVariable */
-val* VIRTUAL_abstract_compiler__AbstractRuntimeFunction__call(val* self, val* p0, val* p1) {
-val* var /* : nullable RuntimeVariable */;
-val* var1 /* : nullable RuntimeVariable */;
-var1 = abstract_compiler__AbstractRuntimeFunction__call(self, p0, p1);
-var = var1;
-RET_LABEL:;
-return var;
+if (varonce900) {
+var901 = varonce900;
+} else {
+var902 = ", 100.0*count_type_test_total_";
+var903 = 30;
+var904 = string__NativeString__to_s_with_length(var902, var903);
+var901 = var904;
+varonce900 = var901;
 }
-/* method abstract_compiler#AbstractRuntimeFunction#compile_to_c for (self: AbstractRuntimeFunction, AbstractCompiler) */
-void abstract_compiler__AbstractRuntimeFunction__compile_to_c(val* self, val* p0) {
-short int var /* : Bool */;
-int cltype;
-int idtype;
-const struct type* type_struct;
-/* Covariant cast for argument 0 (compiler) <p0:AbstractCompiler> isa COMPILER */
-/* <p0:AbstractCompiler> isa COMPILER */
-type_struct = self->type->resolution_table->types[COLOR_abstract_compiler__AbstractRuntimeFunction_VTCOMPILER];
-cltype = type_struct->color;
-idtype = type_struct->id;
-if(cltype >= p0->type->table_size) {
-var = 0;
+if (varonce905) {
+var906 = varonce905;
 } else {
-var = p0->type->type_table[cltype] == idtype;
+var907 = "/count_type_test_total_total);";
+var908 = 30;
+var909 = string__NativeString__to_s_with_length(var907, var908);
+var906 = var909;
+varonce905 = var906;
 }
-if (!var) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "src/abstract_compiler.nit", 992);
-exit(1);
+var910 = NEW_array__Array(&type_array__Arraykernel__Object);
+{ /* var910 = array_instance Array[Object] */
+var911 = 5;
+var912 = NEW_array__NativeArray(var911, &type_array__NativeArraykernel__Object);
+((struct instance_array__NativeArray*)var912)->values[0] = (val*) var896;
+((struct instance_array__NativeArray*)var912)->values[1] = (val*) var_tag823;
+((struct instance_array__NativeArray*)var912)->values[2] = (val*) var901;
+((struct instance_array__NativeArray*)var912)->values[3] = (val*) var_tag823;
+((struct instance_array__NativeArray*)var912)->values[4] = (val*) var906;
+{
+((void (*)(val*, val*, long))(var910->class->vft[COLOR_array__Array__with_native]))(var910, var912, var911) /* with_native on <var910:Array[Object]>*/;
 }
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Deferred method called", "src/abstract_compiler.nit", 992);
-exit(1);
-RET_LABEL:;
 }
-/* method abstract_compiler#AbstractRuntimeFunction#compile_to_c for (self: Object, AbstractCompiler) */
-void VIRTUAL_abstract_compiler__AbstractRuntimeFunction__compile_to_c(val* self, val* p0) {
-abstract_compiler__AbstractRuntimeFunction__compile_to_c(self, p0);
-RET_LABEL:;
+{
+var913 = ((val* (*)(val*))(var910->class->vft[COLOR_string__Object__to_s]))(var910) /* to_s on <var910:Array[Object]>*/;
 }
-/* method abstract_compiler#AbstractRuntimeFunction#init for (self: AbstractRuntimeFunction, MMethodDef) */
-void abstract_compiler__AbstractRuntimeFunction__init(val* self, val* p0) {
-self->attrs[COLOR_abstract_compiler__AbstractRuntimeFunction___64dmmethoddef].val = p0; /* @mmethoddef on <self:AbstractRuntimeFunction> */
-RET_LABEL:;
+{
+abstract_compiler__AbstractCompilerVisitor__add(var_v, var913); /* Direct call abstract_compiler#AbstractCompilerVisitor#add on <var_v:AbstractCompilerVisitor>*/
 }
-/* method abstract_compiler#AbstractRuntimeFunction#init for (self: Object, MMethodDef) */
-void VIRTUAL_abstract_compiler__AbstractRuntimeFunction__init(val* self, val* p0) {
-abstract_compiler__AbstractRuntimeFunction__init(self, p0);
-RET_LABEL:;
+{
+array__ArrayIterator__next(var_820); /* Direct call array#ArrayIterator#next on <var_820:ArrayIterator[String]>*/
 }
-/* method abstract_compiler#RuntimeVariable#name for (self: RuntimeVariable): String */
-val* abstract_compiler__RuntimeVariable__name(val* self) {
-val* var /* : String */;
-val* var1 /* : String */;
-var1 = self->attrs[COLOR_abstract_compiler__RuntimeVariable___64dname].val; /* @name on <self:RuntimeVariable> */
-if (var1 == NULL) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Uninitialized attribute @name", "src/abstract_compiler.nit", 1002);
-exit(1);
+} else {
+goto BREAK_label914;
 }
-var = var1;
-RET_LABEL:;
-return var;
 }
-/* method abstract_compiler#RuntimeVariable#name for (self: Object): String */
-val* VIRTUAL_abstract_compiler__RuntimeVariable__name(val* self) {
-val* var /* : String */;
-val* var1 /* : String */;
-var1 = abstract_compiler__RuntimeVariable__name(self);
-var = var1;
-RET_LABEL:;
-return var;
+BREAK_label914: (void)0;
+{
+{ /* Inline abstract_collection#Iterator#finish (var_820) on <var_820:ArrayIterator[String]> */
+RET_LABEL915:(void)0;
 }
-/* method abstract_compiler#RuntimeVariable#name= for (self: RuntimeVariable, String) */
-void abstract_compiler__RuntimeVariable__name_61d(val* self, val* p0) {
-self->attrs[COLOR_abstract_compiler__RuntimeVariable___64dname].val = p0; /* @name on <self:RuntimeVariable> */
-RET_LABEL:;
 }
-/* method abstract_compiler#RuntimeVariable#name= for (self: Object, String) */
-void VIRTUAL_abstract_compiler__RuntimeVariable__name_61d(val* self, val* p0) {
-abstract_compiler__RuntimeVariable__name_61d(self, p0);
-RET_LABEL:;
+} else {
 }
-/* method abstract_compiler#RuntimeVariable#mtype for (self: RuntimeVariable): MType */
-val* abstract_compiler__RuntimeVariable__mtype(val* self) {
-val* var /* : MType */;
-val* var1 /* : MType */;
-var1 = self->attrs[COLOR_abstract_compiler__RuntimeVariable___64dmtype].val; /* @mtype on <self:RuntimeVariable> */
-if (var1 == NULL) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Uninitialized attribute @mtype", "src/abstract_compiler.nit", 1005);
-exit(1);
+{
+{ /* Inline abstract_compiler#AbstractCompiler#modelbuilder (self) on <self:AbstractCompiler> */
+var918 = self->attrs[COLOR_abstract_compiler__AbstractCompiler___modelbuilder].val; /* _modelbuilder on <self:AbstractCompiler> */
+if (unlikely(var918 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _modelbuilder");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 470);
+show_backtrace(1);
 }
-var = var1;
-RET_LABEL:;
-return var;
+var916 = var918;
+RET_LABEL917:(void)0;
 }
-/* method abstract_compiler#RuntimeVariable#mtype for (self: Object): MType */
-val* VIRTUAL_abstract_compiler__RuntimeVariable__mtype(val* self) {
-val* var /* : MType */;
-val* var1 /* : MType */;
-var1 = abstract_compiler__RuntimeVariable__mtype(self);
-var = var1;
-RET_LABEL:;
-return var;
 }
-/* method abstract_compiler#RuntimeVariable#mtype= for (self: RuntimeVariable, MType) */
-void abstract_compiler__RuntimeVariable__mtype_61d(val* self, val* p0) {
-self->attrs[COLOR_abstract_compiler__RuntimeVariable___64dmtype].val = p0; /* @mtype on <self:RuntimeVariable> */
-RET_LABEL:;
+{
+{ /* Inline modelbuilder#ModelBuilder#toolcontext (var916) on <var916:ModelBuilder> */
+var921 = var916->attrs[COLOR_modelbuilder__ModelBuilder___toolcontext].val; /* _toolcontext on <var916:ModelBuilder> */
+if (unlikely(var921 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _toolcontext");
+PRINT_ERROR(" (%s:%d)\n", "modelbuilder.nit", 106);
+show_backtrace(1);
 }
-/* method abstract_compiler#RuntimeVariable#mtype= for (self: Object, MType) */
-void VIRTUAL_abstract_compiler__RuntimeVariable__mtype_61d(val* self, val* p0) {
-abstract_compiler__RuntimeVariable__mtype_61d(self, p0);
-RET_LABEL:;
+var919 = var921;
+RET_LABEL920:(void)0;
 }
-/* method abstract_compiler#RuntimeVariable#mcasttype for (self: RuntimeVariable): MType */
-val* abstract_compiler__RuntimeVariable__mcasttype(val* self) {
-val* var /* : MType */;
-val* var1 /* : MType */;
-var1 = self->attrs[COLOR_abstract_compiler__RuntimeVariable___64dmcasttype].val; /* @mcasttype on <self:RuntimeVariable> */
-if (var1 == NULL) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Uninitialized attribute @mcasttype", "src/abstract_compiler.nit", 1008);
-exit(1);
 }
-var = var1;
-RET_LABEL:;
-return var;
+{
+{ /* Inline abstract_compiler#ToolContext#opt_invocation_metrics (var919) on <var919:ToolContext> */
+var924 = var919->attrs[COLOR_abstract_compiler__ToolContext___opt_invocation_metrics].val; /* _opt_invocation_metrics on <var919:ToolContext> */
+if (unlikely(var924 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _opt_invocation_metrics");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 63);
+show_backtrace(1);
 }
-/* method abstract_compiler#RuntimeVariable#mcasttype for (self: Object): MType */
-val* VIRTUAL_abstract_compiler__RuntimeVariable__mcasttype(val* self) {
-val* var /* : MType */;
-val* var1 /* : MType */;
-var1 = abstract_compiler__RuntimeVariable__mcasttype(self);
-var = var1;
-RET_LABEL:;
-return var;
+var922 = var924;
+RET_LABEL923:(void)0;
 }
-/* method abstract_compiler#RuntimeVariable#mcasttype= for (self: RuntimeVariable, MType) */
-void abstract_compiler__RuntimeVariable__mcasttype_61d(val* self, val* p0) {
-self->attrs[COLOR_abstract_compiler__RuntimeVariable___64dmcasttype].val = p0; /* @mcasttype on <self:RuntimeVariable> */
-RET_LABEL:;
 }
-/* method abstract_compiler#RuntimeVariable#mcasttype= for (self: Object, MType) */
-void VIRTUAL_abstract_compiler__RuntimeVariable__mcasttype_61d(val* self, val* p0) {
-abstract_compiler__RuntimeVariable__mcasttype_61d(self, p0);
-RET_LABEL:;
+{
+{ /* Inline opts#Option#value (var922) on <var922:OptionBool> */
+var927 = var922->attrs[COLOR_opts__Option___value].val; /* _value on <var922:OptionBool> */
+var925 = var927;
+RET_LABEL926:(void)0;
 }
-/* method abstract_compiler#RuntimeVariable#is_exact for (self: RuntimeVariable): Bool */
-short int abstract_compiler__RuntimeVariable__is_exact(val* self) {
-short int var /* : Bool */;
-short int var1 /* : Bool */;
-var1 = self->attrs[COLOR_abstract_compiler__RuntimeVariable___64dis_exact].s; /* @is_exact on <self:RuntimeVariable> */
-var = var1;
-RET_LABEL:;
-return var;
 }
-/* method abstract_compiler#RuntimeVariable#is_exact for (self: Object): Bool */
-short int VIRTUAL_abstract_compiler__RuntimeVariable__is_exact(val* self) {
-short int var /* : Bool */;
-short int var1 /* : Bool */;
-var1 = abstract_compiler__RuntimeVariable__is_exact(self);
-var = var1;
-RET_LABEL:;
-return var;
+var928 = ((struct instance_kernel__Bool*)var925)->value; /* autounbox from nullable Object to Bool */;
+if (var928){
+if (varonce929) {
+var930 = varonce929;
+} else {
+var931 = "long count_invoke_total;";
+var932 = 24;
+var933 = string__NativeString__to_s_with_length(var931, var932);
+var930 = var933;
+varonce929 = var930;
 }
-/* method abstract_compiler#RuntimeVariable#is_exact= for (self: RuntimeVariable, Bool) */
-void abstract_compiler__RuntimeVariable__is_exact_61d(val* self, short int p0) {
-self->attrs[COLOR_abstract_compiler__RuntimeVariable___64dis_exact].s = p0; /* @is_exact on <self:RuntimeVariable> */
-RET_LABEL:;
+{
+abstract_compiler__AbstractCompilerVisitor__add_decl(var_v, var930); /* Direct call abstract_compiler#AbstractCompilerVisitor#add_decl on <var_v:AbstractCompilerVisitor>*/
 }
-/* method abstract_compiler#RuntimeVariable#is_exact= for (self: Object, Bool) */
-void VIRTUAL_abstract_compiler__RuntimeVariable__is_exact_61d(val* self, short int p0) {
-abstract_compiler__RuntimeVariable__is_exact_61d(self, p0);
-RET_LABEL:;
+if (varonce934) {
+var935 = varonce934;
+} else {
+var936 = "count_invoke_total = count_invoke_by_tables + count_invoke_by_direct + count_invoke_by_inline;";
+var937 = 94;
+var938 = string__NativeString__to_s_with_length(var936, var937);
+var935 = var938;
+varonce934 = var935;
 }
-/* method abstract_compiler#RuntimeVariable#init for (self: RuntimeVariable, String, MType, MType) */
-void abstract_compiler__RuntimeVariable__init(val* self, val* p0, val* p1, val* p2) {
-val* var_name /* var name: String */;
-val* var_mtype /* var mtype: MType */;
-val* var_mcasttype /* var mcasttype: MType */;
-short int var /* : Bool */;
-short int var1 /* : Bool */;
-short int var2 /* : Bool */;
-short int var3 /* : Bool */;
-var_name = p0;
-var_mtype = p1;
-var_mcasttype = p2;
-((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__RuntimeVariable__name_61d]))(self, var_name) /* name= on <self:RuntimeVariable>*/;
-((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__RuntimeVariable__mtype_61d]))(self, var_mtype) /* mtype= on <self:RuntimeVariable>*/;
-((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__RuntimeVariable__mcasttype_61d]))(self, var_mcasttype) /* mcasttype= on <self:RuntimeVariable>*/;
-var = ((short int (*)(val*))(var_mtype->class->vft[COLOR_model__MType__need_anchor]))(var_mtype) /* need_anchor on <var_mtype:MType>*/;
-var1 = !var;
-if (!var1) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Assert failed", "src/abstract_compiler.nit", 1020);
-exit(1);
-}
-var2 = ((short int (*)(val*))(var_mcasttype->class->vft[COLOR_model__MType__need_anchor]))(var_mcasttype) /* need_anchor on <var_mcasttype:MType>*/;
-var3 = !var2;
-if (!var3) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Assert failed", "src/abstract_compiler.nit", 1021);
-exit(1);
+{
+abstract_compiler__AbstractCompilerVisitor__add(var_v, var935); /* Direct call abstract_compiler#AbstractCompilerVisitor#add on <var_v:AbstractCompilerVisitor>*/
 }
-RET_LABEL:;
+if (varonce939) {
+var940 = varonce939;
+} else {
+var941 = "printf(\"# dynamic count_invocation: total %ld\\n\", count_invoke_total);";
+var942 = 70;
+var943 = string__NativeString__to_s_with_length(var941, var942);
+var940 = var943;
+varonce939 = var940;
 }
-/* method abstract_compiler#RuntimeVariable#init for (self: Object, String, MType, MType) */
-void VIRTUAL_abstract_compiler__RuntimeVariable__init(val* self, val* p0, val* p1, val* p2) {
-abstract_compiler__RuntimeVariable__init(self, p0, p1, p2);
-RET_LABEL:;
+{
+abstract_compiler__AbstractCompilerVisitor__add(var_v, var940); /* Direct call abstract_compiler#AbstractCompilerVisitor#add on <var_v:AbstractCompilerVisitor>*/
 }
-/* method abstract_compiler#RuntimeVariable#to_s for (self: RuntimeVariable): String */
-val* abstract_compiler__RuntimeVariable__to_s(val* self) {
-val* var /* : String */;
-val* var1 /* : String */;
-var1 = ((val* (*)(val*))(self->class->vft[COLOR_abstract_compiler__RuntimeVariable__name]))(self) /* name on <self:RuntimeVariable>*/;
-var = var1;
-goto RET_LABEL;
-RET_LABEL:;
-return var;
+if (varonce944) {
+var945 = varonce944;
+} else {
+var946 = "printf(\"by table: %ld (%.2f%%)\\n\", count_invoke_by_tables, 100.0*count_invoke_by_tables/count_invoke_total);";
+var947 = 108;
+var948 = string__NativeString__to_s_with_length(var946, var947);
+var945 = var948;
+varonce944 = var945;
 }
-/* method abstract_compiler#RuntimeVariable#to_s for (self: Object): String */
-val* VIRTUAL_abstract_compiler__RuntimeVariable__to_s(val* self) {
-val* var /* : String */;
-val* var1 /* : String */;
-var1 = abstract_compiler__RuntimeVariable__to_s(self);
-var = var1;
-RET_LABEL:;
-return var;
+{
+abstract_compiler__AbstractCompilerVisitor__add(var_v, var945); /* Direct call abstract_compiler#AbstractCompilerVisitor#add on <var_v:AbstractCompilerVisitor>*/
 }
-/* method abstract_compiler#RuntimeVariable#inspect for (self: RuntimeVariable): String */
-val* abstract_compiler__RuntimeVariable__inspect(val* self) {
-val* var /* : String */;
-short int var1 /* : Bool */;
-static val* varonce;
-val* var2 /* : String */;
-char* var3 /* : NativeString */;
-long var4 /* : Int */;
-val* var5 /* : String */;
-val* var_exact_str /* var exact_str: nullable Object */;
-static val* varonce6;
-val* var7 /* : String */;
-char* var8 /* : NativeString */;
-long var9 /* : Int */;
-val* var10 /* : String */;
-val* var11 /* : MType */;
-val* var12 /* : MType */;
-short int var13 /* : Bool */;
-val* var14 /* : MType */;
-val* var15 /* : Array[Object] */;
-long var16 /* : Int */;
-val* var17 /* : NativeArray[Object] */;
-val* var18 /* : String */;
-val* var_type_str /* var type_str: nullable Object */;
-val* var19 /* : MType */;
-static val* varonce20;
-val* var21 /* : String */;
-char* var22 /* : NativeString */;
-long var23 /* : Int */;
-val* var24 /* : String */;
-val* var25 /* : MType */;
-static val* varonce26;
-val* var27 /* : String */;
-char* var28 /* : NativeString */;
-long var29 /* : Int */;
-val* var30 /* : String */;
-val* var31 /* : Array[Object] */;
-long var32 /* : Int */;
-val* var33 /* : NativeArray[Object] */;
-val* var34 /* : String */;
-val* var35 /* : Array[Object] */;
-long var36 /* : Int */;
-val* var_ /* var : Array[Object] */;
-static val* varonce37;
-val* var38 /* : String */;
-char* var39 /* : NativeString */;
-long var40 /* : Int */;
-val* var41 /* : String */;
-val* var42 /* : String */;
-static val* varonce43;
-val* var44 /* : String */;
-char* var45 /* : NativeString */;
-long var46 /* : Int */;
-val* var47 /* : String */;
-static val* varonce48;
-val* var49 /* : String */;
-char* var50 /* : NativeString */;
-long var51 /* : Int */;
-val* var52 /* : String */;
-val* var53 /* : String */;
-var1 = ((short int (*)(val*))(self->class->vft[COLOR_abstract_compiler__RuntimeVariable__is_exact]))(self) /* is_exact on <self:RuntimeVariable>*/;
-if (var1){
-if (varonce) {
-var2 = varonce;
+if (varonce949) {
+var950 = varonce949;
 } else {
-var3 = " exact";
-var4 = 6;
-var5 = string__NativeString__to_s_with_length(var3, var4);
-var2 = var5;
-varonce = var2;
+var951 = "printf(\"direct:   %ld (%.2f%%)\\n\", count_invoke_by_direct, 100.0*count_invoke_by_direct/count_invoke_total);";
+var952 = 108;
+var953 = string__NativeString__to_s_with_length(var951, var952);
+var950 = var953;
+varonce949 = var950;
+}
+{
+abstract_compiler__AbstractCompilerVisitor__add(var_v, var950); /* Direct call abstract_compiler#AbstractCompilerVisitor#add on <var_v:AbstractCompilerVisitor>*/
 }
-var_exact_str = var2;
+if (varonce954) {
+var955 = varonce954;
 } else {
-if (varonce6) {
-var7 = varonce6;
+var956 = "printf(\"inlined:  %ld (%.2f%%)\\n\", count_invoke_by_inline, 100.0*count_invoke_by_inline/count_invoke_total);";
+var957 = 108;
+var958 = string__NativeString__to_s_with_length(var956, var957);
+var955 = var958;
+varonce954 = var955;
+}
+{
+abstract_compiler__AbstractCompilerVisitor__add(var_v, var955); /* Direct call abstract_compiler#AbstractCompilerVisitor#add on <var_v:AbstractCompilerVisitor>*/
+}
 } else {
-var8 = "";
-var9 = 0;
-var10 = string__NativeString__to_s_with_length(var8, var9);
-var7 = var10;
-varonce6 = var7;
 }
-var_exact_str = var7;
+{
+{ /* Inline abstract_compiler#AbstractCompiler#modelbuilder (self) on <self:AbstractCompiler> */
+var961 = self->attrs[COLOR_abstract_compiler__AbstractCompiler___modelbuilder].val; /* _modelbuilder on <self:AbstractCompiler> */
+if (unlikely(var961 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _modelbuilder");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 470);
+show_backtrace(1);
 }
-var11 = ((val* (*)(val*))(self->class->vft[COLOR_abstract_compiler__RuntimeVariable__mtype]))(self) /* mtype on <self:RuntimeVariable>*/;
-var12 = ((val* (*)(val*))(self->class->vft[COLOR_abstract_compiler__RuntimeVariable__mcasttype]))(self) /* mcasttype on <self:RuntimeVariable>*/;
-var13 = ((short int (*)(val*, val*))(var11->class->vft[COLOR_kernel__Object___61d_61d]))(var11, var12) /* == on <var11:MType>*/;
-if (var13){
-var14 = ((val* (*)(val*))(self->class->vft[COLOR_abstract_compiler__RuntimeVariable__mtype]))(self) /* mtype on <self:RuntimeVariable>*/;
-var15 = NEW_array__Array(&type_array__Arraykernel__Object);
-{ /* var15 = array_instance Array[Object] */
-var16 = 2;
-var17 = NEW_array__NativeArray(var16, &type_array__NativeArraykernel__Object);
-((struct instance_array__NativeArray*)var17)->values[0] = (val*) var14;
-((struct instance_array__NativeArray*)var17)->values[1] = (val*) var_exact_str;
-((void (*)(val*, val*, long))(var15->class->vft[COLOR_array__Array__with_native]))(var15, var17, var16) /* with_native on <var15:Array[Object]>*/;
-CHECK_NEW_array__Array(var15);
+var959 = var961;
+RET_LABEL960:(void)0;
 }
-var18 = ((val* (*)(val*))(var15->class->vft[COLOR_string__Object__to_s]))(var15) /* to_s on <var15:Array[Object]>*/;
-var_type_str = var18;
-} else {
-var19 = ((val* (*)(val*))(self->class->vft[COLOR_abstract_compiler__RuntimeVariable__mtype]))(self) /* mtype on <self:RuntimeVariable>*/;
-if (varonce20) {
-var21 = varonce20;
-} else {
-var22 = "(";
-var23 = 1;
-var24 = string__NativeString__to_s_with_length(var22, var23);
-var21 = var24;
-varonce20 = var21;
 }
-var25 = ((val* (*)(val*))(self->class->vft[COLOR_abstract_compiler__RuntimeVariable__mcasttype]))(self) /* mcasttype on <self:RuntimeVariable>*/;
-if (varonce26) {
-var27 = varonce26;
-} else {
-var28 = ")";
-var29 = 1;
-var30 = string__NativeString__to_s_with_length(var28, var29);
-var27 = var30;
-varonce26 = var27;
+{
+{ /* Inline modelbuilder#ModelBuilder#toolcontext (var959) on <var959:ModelBuilder> */
+var964 = var959->attrs[COLOR_modelbuilder__ModelBuilder___toolcontext].val; /* _toolcontext on <var959:ModelBuilder> */
+if (unlikely(var964 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _toolcontext");
+PRINT_ERROR(" (%s:%d)\n", "modelbuilder.nit", 106);
+show_backtrace(1);
 }
-var31 = NEW_array__Array(&type_array__Arraykernel__Object);
-{ /* var31 = array_instance Array[Object] */
-var32 = 5;
-var33 = NEW_array__NativeArray(var32, &type_array__NativeArraykernel__Object);
-((struct instance_array__NativeArray*)var33)->values[0] = (val*) var19;
-((struct instance_array__NativeArray*)var33)->values[1] = (val*) var21;
-((struct instance_array__NativeArray*)var33)->values[2] = (val*) var25;
-((struct instance_array__NativeArray*)var33)->values[3] = (val*) var_exact_str;
-((struct instance_array__NativeArray*)var33)->values[4] = (val*) var27;
-((void (*)(val*, val*, long))(var31->class->vft[COLOR_array__Array__with_native]))(var31, var33, var32) /* with_native on <var31:Array[Object]>*/;
-CHECK_NEW_array__Array(var31);
-}
-var34 = ((val* (*)(val*))(var31->class->vft[COLOR_string__Object__to_s]))(var31) /* to_s on <var31:Array[Object]>*/;
-var_type_str = var34;
-}
-var35 = NEW_array__Array(&type_array__Arraykernel__Object);
-var36 = 5;
-((void (*)(val*, long))(var35->class->vft[COLOR_array__Array__with_capacity]))(var35, var36) /* with_capacity on <var35:Array[Object]>*/;
-CHECK_NEW_array__Array(var35);
-var_ = var35;
-if (varonce37) {
-var38 = varonce37;
-} else {
-var39 = "<";
-var40 = 1;
-var41 = string__NativeString__to_s_with_length(var39, var40);
-var38 = var41;
-varonce37 = var38;
+var962 = var964;
+RET_LABEL963:(void)0;
 }
-((void (*)(val*, val*))(var_->class->vft[COLOR_abstract_collection__SimpleCollection__add]))(var_, var38) /* add on <var_:Array[Object]>*/;
-var42 = ((val* (*)(val*))(self->class->vft[COLOR_abstract_compiler__RuntimeVariable__name]))(self) /* name on <self:RuntimeVariable>*/;
-((void (*)(val*, val*))(var_->class->vft[COLOR_abstract_collection__SimpleCollection__add]))(var_, var42) /* add on <var_:Array[Object]>*/;
-if (varonce43) {
-var44 = varonce43;
-} else {
-var45 = ":";
-var46 = 1;
-var47 = string__NativeString__to_s_with_length(var45, var46);
-var44 = var47;
-varonce43 = var44;
-}
-((void (*)(val*, val*))(var_->class->vft[COLOR_abstract_collection__SimpleCollection__add]))(var_, var44) /* add on <var_:Array[Object]>*/;
-((void (*)(val*, val*))(var_->class->vft[COLOR_abstract_collection__SimpleCollection__add]))(var_, var_type_str) /* add on <var_:Array[Object]>*/;
-if (varonce48) {
-var49 = varonce48;
-} else {
-var50 = ">";
-var51 = 1;
-var52 = string__NativeString__to_s_with_length(var50, var51);
-var49 = var52;
-varonce48 = var49;
-}
-((void (*)(val*, val*))(var_->class->vft[COLOR_abstract_collection__SimpleCollection__add]))(var_, var49) /* add on <var_:Array[Object]>*/;
-var53 = ((val* (*)(val*))(var_->class->vft[COLOR_string__Object__to_s]))(var_) /* to_s on <var_:Array[Object]>*/;
-var = var53;
-goto RET_LABEL;
-RET_LABEL:;
-return var;
 }
-/* method abstract_compiler#RuntimeVariable#inspect for (self: Object): String */
-val* VIRTUAL_abstract_compiler__RuntimeVariable__inspect(val* self) {
-val* var /* : String */;
-val* var1 /* : String */;
-var1 = abstract_compiler__RuntimeVariable__inspect(self);
-var = var1;
-RET_LABEL:;
-return var;
+{
+{ /* Inline abstract_compiler#ToolContext#opt_isset_checks_metrics (var962) on <var962:ToolContext> */
+var967 = var962->attrs[COLOR_abstract_compiler__ToolContext___opt_isset_checks_metrics].val; /* _opt_isset_checks_metrics on <var962:ToolContext> */
+if (unlikely(var967 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _opt_isset_checks_metrics");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 65);
+show_backtrace(1);
 }
-/* method abstract_compiler#Frame#visitor for (self: Frame): AbstractCompilerVisitor */
-val* abstract_compiler__Frame__visitor(val* self) {
-val* var /* : AbstractCompilerVisitor */;
-val* var1 /* : AbstractCompilerVisitor */;
-var1 = self->attrs[COLOR_abstract_compiler__Frame___64dvisitor].val; /* @visitor on <self:Frame> */
-if (var1 == NULL) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Uninitialized attribute @visitor", "src/abstract_compiler.nit", 1049);
-exit(1);
+var965 = var967;
+RET_LABEL966:(void)0;
 }
-var = var1;
-RET_LABEL:;
-return var;
 }
-/* method abstract_compiler#Frame#visitor for (self: Object): AbstractCompilerVisitor */
-val* VIRTUAL_abstract_compiler__Frame__visitor(val* self) {
-val* var /* : AbstractCompilerVisitor */;
-val* var1 /* : AbstractCompilerVisitor */;
-var1 = abstract_compiler__Frame__visitor(self);
-var = var1;
-RET_LABEL:;
-return var;
+{
+{ /* Inline opts#Option#value (var965) on <var965:OptionBool> */
+var970 = var965->attrs[COLOR_opts__Option___value].val; /* _value on <var965:OptionBool> */
+var968 = var970;
+RET_LABEL969:(void)0;
 }
-/* method abstract_compiler#Frame#visitor= for (self: Frame, AbstractCompilerVisitor) */
-void abstract_compiler__Frame__visitor_61d(val* self, val* p0) {
-short int var /* : Bool */;
-int cltype;
-int idtype;
-const struct type* type_struct;
-/* Covariant cast for argument 0 (visitor) <p0:AbstractCompilerVisitor> isa VISITOR */
-/* <p0:AbstractCompilerVisitor> isa VISITOR */
-type_struct = self->type->resolution_table->types[COLOR_abstract_compiler__Frame_VTVISITOR];
-cltype = type_struct->color;
-idtype = type_struct->id;
-if(cltype >= p0->type->table_size) {
-var = 0;
-} else {
-var = p0->type->type_table[cltype] == idtype;
 }
-if (!var) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "src/abstract_compiler.nit", 1049);
-exit(1);
+var971 = ((struct instance_kernel__Bool*)var968)->value; /* autounbox from nullable Object to Bool */;
+if (var971){
+if (varonce972) {
+var973 = varonce972;
+} else {
+var974 = "printf(\"# dynamic attribute reads: %ld\\n\", count_attr_reads);";
+var975 = 61;
+var976 = string__NativeString__to_s_with_length(var974, var975);
+var973 = var976;
+varonce972 = var973;
 }
-self->attrs[COLOR_abstract_compiler__Frame___64dvisitor].val = p0; /* @visitor on <self:Frame> */
-RET_LABEL:;
+{
+abstract_compiler__AbstractCompilerVisitor__add(var_v, var973); /* Direct call abstract_compiler#AbstractCompilerVisitor#add on <var_v:AbstractCompilerVisitor>*/
 }
-/* method abstract_compiler#Frame#visitor= for (self: Object, AbstractCompilerVisitor) */
-void VIRTUAL_abstract_compiler__Frame__visitor_61d(val* self, val* p0) {
-abstract_compiler__Frame__visitor_61d(self, p0);
-RET_LABEL:;
+if (varonce977) {
+var978 = varonce977;
+} else {
+var979 = "printf(\"# dynamic isset checks: %ld\\n\", count_isset_checks);";
+var980 = 60;
+var981 = string__NativeString__to_s_with_length(var979, var980);
+var978 = var981;
+varonce977 = var978;
 }
-/* method abstract_compiler#Frame#mpropdef for (self: Frame): MPropDef */
-val* abstract_compiler__Frame__mpropdef(val* self) {
-val* var /* : MPropDef */;
-val* var1 /* : MPropDef */;
-var1 = self->attrs[COLOR_abstract_compiler__Frame___64dmpropdef].val; /* @mpropdef on <self:Frame> */
-if (var1 == NULL) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Uninitialized attribute @mpropdef", "src/abstract_compiler.nit", 1052);
-exit(1);
+{
+abstract_compiler__AbstractCompilerVisitor__add(var_v, var978); /* Direct call abstract_compiler#AbstractCompilerVisitor#add on <var_v:AbstractCompilerVisitor>*/
 }
-var = var1;
-RET_LABEL:;
-return var;
+} else {
 }
-/* method abstract_compiler#Frame#mpropdef for (self: Object): MPropDef */
-val* VIRTUAL_abstract_compiler__Frame__mpropdef(val* self) {
-val* var /* : MPropDef */;
-val* var1 /* : MPropDef */;
-var1 = abstract_compiler__Frame__mpropdef(self);
-var = var1;
-RET_LABEL:;
-return var;
+if (varonce982) {
+var983 = varonce982;
+} else {
+var984 = "return 0;";
+var985 = 9;
+var986 = string__NativeString__to_s_with_length(var984, var985);
+var983 = var986;
+varonce982 = var983;
 }
-/* method abstract_compiler#Frame#mpropdef= for (self: Frame, MPropDef) */
-void abstract_compiler__Frame__mpropdef_61d(val* self, val* p0) {
-self->attrs[COLOR_abstract_compiler__Frame___64dmpropdef].val = p0; /* @mpropdef on <self:Frame> */
-RET_LABEL:;
+{
+abstract_compiler__AbstractCompilerVisitor__add(var_v, var983); /* Direct call abstract_compiler#AbstractCompilerVisitor#add on <var_v:AbstractCompilerVisitor>*/
 }
-/* method abstract_compiler#Frame#mpropdef= for (self: Object, MPropDef) */
-void VIRTUAL_abstract_compiler__Frame__mpropdef_61d(val* self, val* p0) {
-abstract_compiler__Frame__mpropdef_61d(self, p0);
-RET_LABEL:;
+if (varonce987) {
+var988 = varonce987;
+} else {
+var989 = "}";
+var990 = 1;
+var991 = string__NativeString__to_s_with_length(var989, var990);
+var988 = var991;
+varonce987 = var988;
 }
-/* method abstract_compiler#Frame#receiver for (self: Frame): MClassType */
-val* abstract_compiler__Frame__receiver(val* self) {
-val* var /* : MClassType */;
-val* var1 /* : MClassType */;
-var1 = self->attrs[COLOR_abstract_compiler__Frame___64dreceiver].val; /* @receiver on <self:Frame> */
-if (var1 == NULL) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Uninitialized attribute @receiver", "src/abstract_compiler.nit", 1056);
-exit(1);
+{
+abstract_compiler__AbstractCompilerVisitor__add(var_v, var988); /* Direct call abstract_compiler#AbstractCompilerVisitor#add on <var_v:AbstractCompilerVisitor>*/
 }
-var = var1;
 RET_LABEL:;
-return var;
 }
-/* method abstract_compiler#Frame#receiver for (self: Object): MClassType */
-val* VIRTUAL_abstract_compiler__Frame__receiver(val* self) {
-val* var /* : MClassType */;
-val* var1 /* : MClassType */;
-var1 = abstract_compiler__Frame__receiver(self);
-var = var1;
+/* method abstract_compiler#AbstractCompiler#compile_main_function for (self: Object) */
+void VIRTUAL_abstract_compiler__AbstractCompiler__compile_main_function(val* self) {
+abstract_compiler__AbstractCompiler__compile_main_function(self); /* Direct call abstract_compiler#AbstractCompiler#compile_main_function on <self:Object(AbstractCompiler)>*/
 RET_LABEL:;
-return var;
 }
-/* method abstract_compiler#Frame#receiver= for (self: Frame, MClassType) */
-void abstract_compiler__Frame__receiver_61d(val* self, val* p0) {
-self->attrs[COLOR_abstract_compiler__Frame___64dreceiver].val = p0; /* @receiver on <self:Frame> */
+/* method abstract_compiler#AbstractCompiler#compile_nitni_global_ref_functions for (self: AbstractCompiler) */
+void abstract_compiler__AbstractCompiler__compile_nitni_global_ref_functions(val* self) {
+val* var /* : AbstractCompilerVisitor */;
+val* var_v /* var v: AbstractCompilerVisitor */;
+static val* varonce;
+val* var1 /* : String */;
+char* var2 /* : NativeString */;
+long var3 /* : Int */;
+val* var4 /* : FlatString */;
+{
+var = ((val* (*)(val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompiler__new_visitor]))(self) /* new_visitor on <self:AbstractCompiler>*/;
+}
+var_v = var;
+if (varonce) {
+var1 = varonce;
+} else {
+var2 = "struct nitni_global_ref_list_t *nitni_global_ref_list;\nvoid initialize_nitni_global_refs() {\n\11nitni_global_ref_list = (struct nitni_global_ref_list_t*)nit_alloc(sizeof(struct nitni_global_ref_list_t));\n\11nitni_global_ref_list->head = NULL;\n\11nitni_global_ref_list->tail = NULL;\n}\n\nvoid nitni_global_ref_add( struct nitni_ref *ref ) {\n\11if ( nitni_global_ref_list->head == NULL ) {\n\11\11nitni_global_ref_list->head = ref;\n\11\11ref->prev = NULL;\n\11} else {\n\11\11nitni_global_ref_list->tail->next = ref;\n\11\11ref->prev = nitni_global_ref_list->tail;\n\11}\n\11nitni_global_ref_list->tail = ref;\n\n\11ref->next = NULL;\n}\n\nvoid nitni_global_ref_remove( struct nitni_ref *ref ) {\n\11if ( ref->prev == NULL ) {\n\11\11nitni_global_ref_list->head = ref->next;\n\11} else {\n\11\11ref->prev->next = ref->next;\n\11}\n\n\11if ( ref->next == NULL ) {\n\11\11nitni_global_ref_list->tail = ref->prev;\n\11} else {\n\11\11ref->next->prev = ref->prev;\n\11}\n}\n\nextern void nitni_global_ref_incr( struct nitni_ref *ref ) {\n\11if ( ref->count == 0 ) /* not registered */\n\11{\n\11\11/* add to list */\n\11\11nitni_global_ref_add( ref );\n\11}\n\n\11ref->count ++;\n}\n\nextern void nitni_global_ref_decr( struct nitni_ref *ref ) {\n\11if ( ref->count == 1 ) /* was last reference */\n\11{\n\11\11/* remove from list */\n\11\11nitni_global_ref_remove( ref );\n\11}\n\n\11ref->count --;\n}\n";
+var3 = 1260;
+var4 = string__NativeString__to_s_with_length(var2, var3);
+var1 = var4;
+varonce = var1;
+}
+{
+abstract_compiler__AbstractCompilerVisitor__add(var_v, var1); /* Direct call abstract_compiler#AbstractCompilerVisitor#add on <var_v:AbstractCompilerVisitor>*/
+}
 RET_LABEL:;
 }
-/* method abstract_compiler#Frame#receiver= for (self: Object, MClassType) */
-void VIRTUAL_abstract_compiler__Frame__receiver_61d(val* self, val* p0) {
-abstract_compiler__Frame__receiver_61d(self, p0);
+/* method abstract_compiler#AbstractCompiler#compile_nitni_global_ref_functions for (self: Object) */
+void VIRTUAL_abstract_compiler__AbstractCompiler__compile_nitni_global_ref_functions(val* self) {
+abstract_compiler__AbstractCompiler__compile_nitni_global_ref_functions(self); /* Direct call abstract_compiler#AbstractCompiler#compile_nitni_global_ref_functions on <self:Object(AbstractCompiler)>*/
 RET_LABEL:;
 }
-/* method abstract_compiler#Frame#arguments for (self: Frame): Array[RuntimeVariable] */
-val* abstract_compiler__Frame__arguments(val* self) {
-val* var /* : Array[RuntimeVariable] */;
-val* var1 /* : Array[RuntimeVariable] */;
-var1 = self->attrs[COLOR_abstract_compiler__Frame___64darguments].val; /* @arguments on <self:Frame> */
-if (var1 == NULL) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Uninitialized attribute @arguments", "src/abstract_compiler.nit", 1059);
-exit(1);
+/* method abstract_compiler#AbstractCompiler#extern_bodies for (self: AbstractCompiler): Array[ExternFile] */
+val* abstract_compiler__AbstractCompiler__extern_bodies(val* self) {
+val* var /* : Array[ExternFile] */;
+val* var1 /* : Array[ExternFile] */;
+var1 = self->attrs[COLOR_abstract_compiler__AbstractCompiler___extern_bodies].val; /* _extern_bodies on <self:AbstractCompiler> */
+if (unlikely(var1 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _extern_bodies");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 901);
+show_backtrace(1);
 }
 var = var1;
 RET_LABEL:;
 return var;
 }
-/* method abstract_compiler#Frame#arguments for (self: Object): Array[RuntimeVariable] */
-val* VIRTUAL_abstract_compiler__Frame__arguments(val* self) {
-val* var /* : Array[RuntimeVariable] */;
-val* var1 /* : Array[RuntimeVariable] */;
-var1 = abstract_compiler__Frame__arguments(self);
+/* method abstract_compiler#AbstractCompiler#extern_bodies for (self: Object): Array[ExternFile] */
+val* VIRTUAL_abstract_compiler__AbstractCompiler__extern_bodies(val* self) {
+val* var /* : Array[ExternFile] */;
+val* var1 /* : Array[ExternFile] */;
+val* var3 /* : Array[ExternFile] */;
+{ /* Inline abstract_compiler#AbstractCompiler#extern_bodies (self) on <self:Object(AbstractCompiler)> */
+var3 = self->attrs[COLOR_abstract_compiler__AbstractCompiler___extern_bodies].val; /* _extern_bodies on <self:Object(AbstractCompiler)> */
+if (unlikely(var3 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _extern_bodies");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 901);
+show_backtrace(1);
+}
+var1 = var3;
+RET_LABEL2:(void)0;
+}
 var = var1;
 RET_LABEL:;
 return var;
 }
-/* method abstract_compiler#Frame#arguments= for (self: Frame, Array[RuntimeVariable]) */
-void abstract_compiler__Frame__arguments_61d(val* self, val* p0) {
-self->attrs[COLOR_abstract_compiler__Frame___64darguments].val = p0; /* @arguments on <self:Frame> */
-RET_LABEL:;
-}
-/* method abstract_compiler#Frame#arguments= for (self: Object, Array[RuntimeVariable]) */
-void VIRTUAL_abstract_compiler__Frame__arguments_61d(val* self, val* p0) {
-abstract_compiler__Frame__arguments_61d(self, p0);
-RET_LABEL:;
+/* method abstract_compiler#AbstractCompiler#files_to_copy for (self: AbstractCompiler): Array[String] */
+val* abstract_compiler__AbstractCompiler__files_to_copy(val* self) {
+val* var /* : Array[String] */;
+val* var1 /* : Array[String] */;
+var1 = self->attrs[COLOR_abstract_compiler__AbstractCompiler___files_to_copy].val; /* _files_to_copy on <self:AbstractCompiler> */
+if (unlikely(var1 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _files_to_copy");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 904);
+show_backtrace(1);
 }
-/* method abstract_compiler#Frame#returnvar for (self: Frame): nullable RuntimeVariable */
-val* abstract_compiler__Frame__returnvar(val* self) {
-val* var /* : nullable RuntimeVariable */;
-val* var1 /* : nullable RuntimeVariable */;
-var1 = self->attrs[COLOR_abstract_compiler__Frame___64dreturnvar].val; /* @returnvar on <self:Frame> */
 var = var1;
 RET_LABEL:;
 return var;
 }
-/* method abstract_compiler#Frame#returnvar for (self: Object): nullable RuntimeVariable */
-val* VIRTUAL_abstract_compiler__Frame__returnvar(val* self) {
-val* var /* : nullable RuntimeVariable */;
-val* var1 /* : nullable RuntimeVariable */;
-var1 = abstract_compiler__Frame__returnvar(self);
+/* method abstract_compiler#AbstractCompiler#files_to_copy for (self: Object): Array[String] */
+val* VIRTUAL_abstract_compiler__AbstractCompiler__files_to_copy(val* self) {
+val* var /* : Array[String] */;
+val* var1 /* : Array[String] */;
+val* var3 /* : Array[String] */;
+{ /* Inline abstract_compiler#AbstractCompiler#files_to_copy (self) on <self:Object(AbstractCompiler)> */
+var3 = self->attrs[COLOR_abstract_compiler__AbstractCompiler___files_to_copy].val; /* _files_to_copy on <self:Object(AbstractCompiler)> */
+if (unlikely(var3 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _files_to_copy");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 904);
+show_backtrace(1);
+}
+var1 = var3;
+RET_LABEL2:(void)0;
+}
 var = var1;
 RET_LABEL:;
 return var;
 }
-/* method abstract_compiler#Frame#returnvar= for (self: Frame, nullable RuntimeVariable) */
-void abstract_compiler__Frame__returnvar_61d(val* self, val* p0) {
-self->attrs[COLOR_abstract_compiler__Frame___64dreturnvar].val = p0; /* @returnvar on <self:Frame> */
-RET_LABEL:;
-}
-/* method abstract_compiler#Frame#returnvar= for (self: Object, nullable RuntimeVariable) */
-void VIRTUAL_abstract_compiler__Frame__returnvar_61d(val* self, val* p0) {
-abstract_compiler__Frame__returnvar_61d(self, p0);
-RET_LABEL:;
+/* method abstract_compiler#AbstractCompiler#seen_extern for (self: AbstractCompiler): ArraySet[String] */
+val* abstract_compiler__AbstractCompiler__seen_extern(val* self) {
+val* var /* : ArraySet[String] */;
+val* var1 /* : ArraySet[String] */;
+var1 = self->attrs[COLOR_abstract_compiler__AbstractCompiler___seen_extern].val; /* _seen_extern on <self:AbstractCompiler> */
+if (unlikely(var1 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _seen_extern");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 907);
+show_backtrace(1);
 }
-/* method abstract_compiler#Frame#returnlabel for (self: Frame): nullable String */
-val* abstract_compiler__Frame__returnlabel(val* self) {
-val* var /* : nullable String */;
-val* var1 /* : nullable String */;
-var1 = self->attrs[COLOR_abstract_compiler__Frame___64dreturnlabel].val; /* @returnlabel on <self:Frame> */
 var = var1;
 RET_LABEL:;
 return var;
 }
-/* method abstract_compiler#Frame#returnlabel for (self: Object): nullable String */
-val* VIRTUAL_abstract_compiler__Frame__returnlabel(val* self) {
-val* var /* : nullable String */;
-val* var1 /* : nullable String */;
-var1 = abstract_compiler__Frame__returnlabel(self);
+/* method abstract_compiler#AbstractCompiler#seen_extern for (self: Object): ArraySet[String] */
+val* VIRTUAL_abstract_compiler__AbstractCompiler__seen_extern(val* self) {
+val* var /* : ArraySet[String] */;
+val* var1 /* : ArraySet[String] */;
+val* var3 /* : ArraySet[String] */;
+{ /* Inline abstract_compiler#AbstractCompiler#seen_extern (self) on <self:Object(AbstractCompiler)> */
+var3 = self->attrs[COLOR_abstract_compiler__AbstractCompiler___seen_extern].val; /* _seen_extern on <self:Object(AbstractCompiler)> */
+if (unlikely(var3 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _seen_extern");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 907);
+show_backtrace(1);
+}
+var1 = var3;
+RET_LABEL2:(void)0;
+}
 var = var1;
 RET_LABEL:;
 return var;
 }
-/* method abstract_compiler#Frame#returnlabel= for (self: Frame, nullable String) */
-void abstract_compiler__Frame__returnlabel_61d(val* self, val* p0) {
-self->attrs[COLOR_abstract_compiler__Frame___64dreturnlabel].val = p0; /* @returnlabel on <self:Frame> */
-RET_LABEL:;
-}
-/* method abstract_compiler#Frame#returnlabel= for (self: Object, nullable String) */
-void VIRTUAL_abstract_compiler__Frame__returnlabel_61d(val* self, val* p0) {
-abstract_compiler__Frame__returnlabel_61d(self, p0);
-RET_LABEL:;
-}
-/* method abstract_compiler#Frame#init for (self: Frame, AbstractCompilerVisitor, MPropDef, MClassType, Array[RuntimeVariable]) */
-void abstract_compiler__Frame__init(val* self, val* p0, val* p1, val* p2, val* p3) {
+/* method abstract_compiler#AbstractCompiler#generate_init_attr for (self: AbstractCompiler, AbstractCompilerVisitor, RuntimeVariable, MClassType) */
+void abstract_compiler__AbstractCompiler__generate_init_attr(val* self, val* p0, val* p1, val* p2) {
 short int var /* : Bool */;
 int cltype;
 int idtype;
 const struct type* type_struct;
-/* Covariant cast for argument 0 (visitor) <p0:AbstractCompilerVisitor> isa VISITOR */
+const char* var_class_name;
+val* var_v /* var v: AbstractCompilerVisitor */;
+val* var_recv /* var recv: RuntimeVariable */;
+val* var_mtype /* var mtype: MClassType */;
+val* var1 /* : MModule */;
+val* var3 /* : MModule */;
+val* var4 /* : Set[MClassDef] */;
+val* var5 /* : Array[nullable Object] */;
+val* var_cds /* var cds: Array[MClassDef] */;
+val* var6 /* : MModule */;
+val* var8 /* : MModule */;
+val* var_ /* var : Array[MClassDef] */;
+val* var9 /* : ArrayIterator[nullable Object] */;
+val* var_10 /* var : ArrayIterator[MClassDef] */;
+short int var11 /* : Bool */;
+val* var12 /* : nullable Object */;
+val* var_cd /* var cd: MClassDef */;
+val* var13 /* : ModelBuilder */;
+val* var15 /* : ModelBuilder */;
+val* var16 /* : HashMap[MClassDef, AClassdef] */;
+val* var18 /* : HashMap[MClassDef, AClassdef] */;
+short int var19 /* : Bool */;
+short int var20 /* : Bool */;
+val* var21 /* : ModelBuilder */;
+val* var23 /* : ModelBuilder */;
+val* var24 /* : HashMap[MClassDef, AClassdef] */;
+val* var26 /* : HashMap[MClassDef, AClassdef] */;
+val* var27 /* : nullable Object */;
+val* var_n /* var n: AClassdef */;
+val* var28 /* : ANodes[APropdef] */;
+val* var30 /* : ANodes[APropdef] */;
+val* var_31 /* var : ANodes[APropdef] */;
+val* var32 /* : Iterator[ANode] */;
+val* var_33 /* var : Iterator[APropdef] */;
+short int var34 /* : Bool */;
+val* var35 /* : nullable Object */;
+val* var_npropdef /* var npropdef: APropdef */;
+short int var36 /* : Bool */;
+int cltype37;
+int idtype38;
+/* Covariant cast for argument 0 (v) <p0:AbstractCompilerVisitor> isa VISITOR */
 /* <p0:AbstractCompilerVisitor> isa VISITOR */
-type_struct = self->type->resolution_table->types[COLOR_abstract_compiler__Frame_VTVISITOR];
+type_struct = self->type->resolution_table->types[COLOR_abstract_compiler__AbstractCompiler_VTVISITOR];
 cltype = type_struct->color;
 idtype = type_struct->id;
 if(cltype >= p0->type->table_size) {
@@ -872,9064 +3862,6023 @@ var = 0;
 } else {
 var = p0->type->type_table[cltype] == idtype;
 }
-if (!var) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "src/abstract_compiler.nit", 1044);
-exit(1);
+if (unlikely(!var)) {
+var_class_name = p0 == NULL ? "null" : p0->type->name;
+PRINT_ERROR("Runtime error: Cast failed. Expected `%s`, got `%s`", "VISITOR", var_class_name);
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 910);
+show_backtrace(1);
+}
+var_v = p0;
+var_recv = p1;
+var_mtype = p2;
+{
+{ /* Inline abstract_compiler#AbstractCompiler#mainmodule (self) on <self:AbstractCompiler> */
+var3 = self->attrs[COLOR_abstract_compiler__AbstractCompiler___mainmodule].val; /* _mainmodule on <self:AbstractCompiler> */
+if (unlikely(var3 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _mainmodule");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 463);
+show_backtrace(1);
+}
+var1 = var3;
+RET_LABEL2:(void)0;
+}
+}
+{
+var4 = model__MClassType__collect_mclassdefs(var_mtype, var1);
+}
+{
+var5 = array__Collection__to_a(var4);
+}
+var_cds = var5;
+{
+{ /* Inline abstract_compiler#AbstractCompiler#mainmodule (self) on <self:AbstractCompiler> */
+var8 = self->attrs[COLOR_abstract_compiler__AbstractCompiler___mainmodule].val; /* _mainmodule on <self:AbstractCompiler> */
+if (unlikely(var8 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _mainmodule");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 463);
+show_backtrace(1);
+}
+var6 = var8;
+RET_LABEL7:(void)0;
+}
+}
+{
+model__MModule__linearize_mclassdefs(var6, var_cds); /* Direct call model#MModule#linearize_mclassdefs on <var6:MModule>*/
+}
+var_ = var_cds;
+{
+var9 = array__AbstractArrayRead__iterator(var_);
+}
+var_10 = var9;
+for(;;) {
+{
+var11 = array__ArrayIterator__is_ok(var_10);
+}
+if (var11){
+{
+var12 = array__ArrayIterator__item(var_10);
+}
+var_cd = var12;
+{
+{ /* Inline abstract_compiler#AbstractCompiler#modelbuilder (self) on <self:AbstractCompiler> */
+var15 = self->attrs[COLOR_abstract_compiler__AbstractCompiler___modelbuilder].val; /* _modelbuilder on <self:AbstractCompiler> */
+if (unlikely(var15 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _modelbuilder");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 470);
+show_backtrace(1);
+}
+var13 = var15;
+RET_LABEL14:(void)0;
+}
+}
+{
+{ /* Inline modelize_class#ModelBuilder#mclassdef2nclassdef (var13) on <var13:ModelBuilder> */
+var18 = var13->attrs[COLOR_modelize_class__ModelBuilder___mclassdef2nclassdef].val; /* _mclassdef2nclassdef on <var13:ModelBuilder> */
+if (unlikely(var18 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _mclassdef2nclassdef");
+PRINT_ERROR(" (%s:%d)\n", "modelize/modelize_class.nit", 410);
+show_backtrace(1);
+}
+var16 = var18;
+RET_LABEL17:(void)0;
+}
+}
+{
+var19 = abstract_collection__MapRead__has_key(var16, var_cd);
+}
+var20 = !var19;
+if (var20){
+goto BREAK_label;
+} else {
+}
+{
+{ /* Inline abstract_compiler#AbstractCompiler#modelbuilder (self) on <self:AbstractCompiler> */
+var23 = self->attrs[COLOR_abstract_compiler__AbstractCompiler___modelbuilder].val; /* _modelbuilder on <self:AbstractCompiler> */
+if (unlikely(var23 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _modelbuilder");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 470);
+show_backtrace(1);
+}
+var21 = var23;
+RET_LABEL22:(void)0;
+}
+}
+{
+{ /* Inline modelize_class#ModelBuilder#mclassdef2nclassdef (var21) on <var21:ModelBuilder> */
+var26 = var21->attrs[COLOR_modelize_class__ModelBuilder___mclassdef2nclassdef].val; /* _mclassdef2nclassdef on <var21:ModelBuilder> */
+if (unlikely(var26 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _mclassdef2nclassdef");
+PRINT_ERROR(" (%s:%d)\n", "modelize/modelize_class.nit", 410);
+show_backtrace(1);
+}
+var24 = var26;
+RET_LABEL25:(void)0;
+}
+}
+{
+var27 = hash_collection__HashMap___91d_93d(var24, var_cd);
+}
+var_n = var27;
+{
+{ /* Inline parser_nodes#AClassdef#n_propdefs (var_n) on <var_n:AClassdef> */
+var30 = var_n->attrs[COLOR_parser_nodes__AClassdef___n_propdefs].val; /* _n_propdefs on <var_n:AClassdef> */
+if (unlikely(var30 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _n_propdefs");
+PRINT_ERROR(" (%s:%d)\n", "parser/parser_nodes.nit", 929);
+show_backtrace(1);
+}
+var28 = var30;
+RET_LABEL29:(void)0;
+}
+}
+var_31 = var28;
+{
+var32 = parser_nodes__ANodes__iterator(var_31);
+}
+var_33 = var32;
+for(;;) {
+{
+var34 = ((short int (*)(val*))(var_33->class->vft[COLOR_abstract_collection__Iterator__is_ok]))(var_33) /* is_ok on <var_33:Iterator[APropdef]>*/;
+}
+if (var34){
+{
+var35 = ((val* (*)(val*))(var_33->class->vft[COLOR_abstract_collection__Iterator__item]))(var_33) /* item on <var_33:Iterator[APropdef]>*/;
+}
+var_npropdef = var35;
+/* <var_npropdef:APropdef> isa AAttrPropdef */
+cltype37 = type_parser_nodes__AAttrPropdef.color;
+idtype38 = type_parser_nodes__AAttrPropdef.id;
+if(cltype37 >= var_npropdef->type->table_size) {
+var36 = 0;
+} else {
+var36 = var_npropdef->type->type_table[cltype37] == idtype38;
+}
+if (var36){
+{
+abstract_compiler__AAttrPropdef__init_expr(var_npropdef, var_v, var_recv); /* Direct call abstract_compiler#AAttrPropdef#init_expr on <var_npropdef:APropdef(AAttrPropdef)>*/
+}
+} else {
+}
+{
+((void (*)(val*))(var_33->class->vft[COLOR_abstract_collection__Iterator__next]))(var_33) /* next on <var_33:Iterator[APropdef]>*/;
+}
+} else {
+goto BREAK_label39;
+}
+}
+BREAK_label39: (void)0;
+{
+{ /* Inline abstract_collection#Iterator#finish (var_33) on <var_33:Iterator[APropdef]> */
+RET_LABEL40:(void)0;
+}
+}
+BREAK_label: (void)0;
+{
+array__ArrayIterator__next(var_10); /* Direct call array#ArrayIterator#next on <var_10:ArrayIterator[MClassDef]>*/
+}
+} else {
+goto BREAK_label41;
+}
+}
+BREAK_label41: (void)0;
+{
+{ /* Inline abstract_collection#Iterator#finish (var_10) on <var_10:ArrayIterator[MClassDef]> */
+RET_LABEL42:(void)0;
+}
 }
-self->attrs[COLOR_abstract_compiler__Frame___64dvisitor].val = p0; /* @visitor on <self:Frame> */
-self->attrs[COLOR_abstract_compiler__Frame___64dmpropdef].val = p1; /* @mpropdef on <self:Frame> */
-self->attrs[COLOR_abstract_compiler__Frame___64dreceiver].val = p2; /* @receiver on <self:Frame> */
-self->attrs[COLOR_abstract_compiler__Frame___64darguments].val = p3; /* @arguments on <self:Frame> */
 RET_LABEL:;
 }
-/* method abstract_compiler#Frame#init for (self: Object, AbstractCompilerVisitor, MPropDef, MClassType, Array[RuntimeVariable]) */
-void VIRTUAL_abstract_compiler__Frame__init(val* self, val* p0, val* p1, val* p2, val* p3) {
-abstract_compiler__Frame__init(self, p0, p1, p2, p3);
+/* method abstract_compiler#AbstractCompiler#generate_init_attr for (self: Object, AbstractCompilerVisitor, RuntimeVariable, MClassType) */
+void VIRTUAL_abstract_compiler__AbstractCompiler__generate_init_attr(val* self, val* p0, val* p1, val* p2) {
+abstract_compiler__AbstractCompiler__generate_init_attr(self, p0, p1, p2); /* Direct call abstract_compiler#AbstractCompiler#generate_init_attr on <self:Object(AbstractCompiler)>*/
 RET_LABEL:;
 }
-/* method abstract_compiler#ExternCFile#filename for (self: ExternCFile): String */
-val* abstract_compiler__ExternCFile__filename(val* self) {
-val* var /* : String */;
-val* var1 /* : String */;
-var1 = self->attrs[COLOR_abstract_compiler__ExternCFile___64dfilename].val; /* @filename on <self:ExternCFile> */
-if (var1 == NULL) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Uninitialized attribute @filename", "src/abstract_compiler.nit", 1071);
-exit(1);
+/* method abstract_compiler#AbstractCompiler#count_type_test_tags for (self: AbstractCompiler): Array[String] */
+val* abstract_compiler__AbstractCompiler__count_type_test_tags(val* self) {
+val* var /* : Array[String] */;
+val* var1 /* : Array[String] */;
+var1 = self->attrs[COLOR_abstract_compiler__AbstractCompiler___count_type_test_tags].val; /* _count_type_test_tags on <self:AbstractCompiler> */
+if (unlikely(var1 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _count_type_test_tags");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 944);
+show_backtrace(1);
 }
 var = var1;
 RET_LABEL:;
 return var;
 }
-/* method abstract_compiler#ExternCFile#filename for (self: Object): String */
-val* VIRTUAL_abstract_compiler__ExternCFile__filename(val* self) {
-val* var /* : String */;
-val* var1 /* : String */;
-var1 = abstract_compiler__ExternCFile__filename(self);
+/* method abstract_compiler#AbstractCompiler#count_type_test_tags for (self: Object): Array[String] */
+val* VIRTUAL_abstract_compiler__AbstractCompiler__count_type_test_tags(val* self) {
+val* var /* : Array[String] */;
+val* var1 /* : Array[String] */;
+val* var3 /* : Array[String] */;
+{ /* Inline abstract_compiler#AbstractCompiler#count_type_test_tags (self) on <self:Object(AbstractCompiler)> */
+var3 = self->attrs[COLOR_abstract_compiler__AbstractCompiler___count_type_test_tags].val; /* _count_type_test_tags on <self:Object(AbstractCompiler)> */
+if (unlikely(var3 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _count_type_test_tags");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 944);
+show_backtrace(1);
+}
+var1 = var3;
+RET_LABEL2:(void)0;
+}
 var = var1;
 RET_LABEL:;
 return var;
 }
-/* method abstract_compiler#ExternCFile#filename= for (self: ExternCFile, String) */
-void abstract_compiler__ExternCFile__filename_61d(val* self, val* p0) {
-self->attrs[COLOR_abstract_compiler__ExternCFile___64dfilename].val = p0; /* @filename on <self:ExternCFile> */
-RET_LABEL:;
+/* method abstract_compiler#AbstractCompiler#count_type_test_resolved for (self: AbstractCompiler): HashMap[String, Int] */
+val* abstract_compiler__AbstractCompiler__count_type_test_resolved(val* self) {
+val* var /* : HashMap[String, Int] */;
+val* var1 /* : HashMap[String, Int] */;
+var1 = self->attrs[COLOR_abstract_compiler__AbstractCompiler___count_type_test_resolved].val; /* _count_type_test_resolved on <self:AbstractCompiler> */
+if (unlikely(var1 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _count_type_test_resolved");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 945);
+show_backtrace(1);
 }
-/* method abstract_compiler#ExternCFile#filename= for (self: Object, String) */
-void VIRTUAL_abstract_compiler__ExternCFile__filename_61d(val* self, val* p0) {
-abstract_compiler__ExternCFile__filename_61d(self, p0);
+var = var1;
 RET_LABEL:;
+return var;
 }
-/* method abstract_compiler#ExternCFile#cflags for (self: ExternCFile): String */
-val* abstract_compiler__ExternCFile__cflags(val* self) {
-val* var /* : String */;
-val* var1 /* : String */;
-var1 = self->attrs[COLOR_abstract_compiler__ExternCFile___64dcflags].val; /* @cflags on <self:ExternCFile> */
-if (var1 == NULL) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Uninitialized attribute @cflags", "src/abstract_compiler.nit", 1073);
-exit(1);
+/* method abstract_compiler#AbstractCompiler#count_type_test_resolved for (self: Object): HashMap[String, Int] */
+val* VIRTUAL_abstract_compiler__AbstractCompiler__count_type_test_resolved(val* self) {
+val* var /* : HashMap[String, Int] */;
+val* var1 /* : HashMap[String, Int] */;
+val* var3 /* : HashMap[String, Int] */;
+{ /* Inline abstract_compiler#AbstractCompiler#count_type_test_resolved (self) on <self:Object(AbstractCompiler)> */
+var3 = self->attrs[COLOR_abstract_compiler__AbstractCompiler___count_type_test_resolved].val; /* _count_type_test_resolved on <self:Object(AbstractCompiler)> */
+if (unlikely(var3 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _count_type_test_resolved");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 945);
+show_backtrace(1);
+}
+var1 = var3;
+RET_LABEL2:(void)0;
 }
 var = var1;
 RET_LABEL:;
 return var;
 }
-/* method abstract_compiler#ExternCFile#cflags for (self: Object): String */
-val* VIRTUAL_abstract_compiler__ExternCFile__cflags(val* self) {
-val* var /* : String */;
-val* var1 /* : String */;
-var1 = abstract_compiler__ExternCFile__cflags(self);
+/* method abstract_compiler#AbstractCompiler#count_type_test_unresolved for (self: AbstractCompiler): HashMap[String, Int] */
+val* abstract_compiler__AbstractCompiler__count_type_test_unresolved(val* self) {
+val* var /* : HashMap[String, Int] */;
+val* var1 /* : HashMap[String, Int] */;
+var1 = self->attrs[COLOR_abstract_compiler__AbstractCompiler___count_type_test_unresolved].val; /* _count_type_test_unresolved on <self:AbstractCompiler> */
+if (unlikely(var1 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _count_type_test_unresolved");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 946);
+show_backtrace(1);
+}
 var = var1;
 RET_LABEL:;
 return var;
 }
-/* method abstract_compiler#ExternCFile#cflags= for (self: ExternCFile, String) */
-void abstract_compiler__ExternCFile__cflags_61d(val* self, val* p0) {
-self->attrs[COLOR_abstract_compiler__ExternCFile___64dcflags].val = p0; /* @cflags on <self:ExternCFile> */
-RET_LABEL:;
+/* method abstract_compiler#AbstractCompiler#count_type_test_unresolved for (self: Object): HashMap[String, Int] */
+val* VIRTUAL_abstract_compiler__AbstractCompiler__count_type_test_unresolved(val* self) {
+val* var /* : HashMap[String, Int] */;
+val* var1 /* : HashMap[String, Int] */;
+val* var3 /* : HashMap[String, Int] */;
+{ /* Inline abstract_compiler#AbstractCompiler#count_type_test_unresolved (self) on <self:Object(AbstractCompiler)> */
+var3 = self->attrs[COLOR_abstract_compiler__AbstractCompiler___count_type_test_unresolved].val; /* _count_type_test_unresolved on <self:Object(AbstractCompiler)> */
+if (unlikely(var3 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _count_type_test_unresolved");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 946);
+show_backtrace(1);
+}
+var1 = var3;
+RET_LABEL2:(void)0;
 }
-/* method abstract_compiler#ExternCFile#cflags= for (self: Object, String) */
-void VIRTUAL_abstract_compiler__ExternCFile__cflags_61d(val* self, val* p0) {
-abstract_compiler__ExternCFile__cflags_61d(self, p0);
+var = var1;
 RET_LABEL:;
+return var;
 }
-/* method abstract_compiler#ExternCFile#init for (self: ExternCFile, String, String) */
-void abstract_compiler__ExternCFile__init(val* self, val* p0, val* p1) {
-self->attrs[COLOR_abstract_compiler__ExternCFile___64dfilename].val = p0; /* @filename on <self:ExternCFile> */
-self->attrs[COLOR_abstract_compiler__ExternCFile___64dcflags].val = p1; /* @cflags on <self:ExternCFile> */
+/* method abstract_compiler#AbstractCompiler#count_type_test_skipped for (self: AbstractCompiler): HashMap[String, Int] */
+val* abstract_compiler__AbstractCompiler__count_type_test_skipped(val* self) {
+val* var /* : HashMap[String, Int] */;
+val* var1 /* : HashMap[String, Int] */;
+var1 = self->attrs[COLOR_abstract_compiler__AbstractCompiler___count_type_test_skipped].val; /* _count_type_test_skipped on <self:AbstractCompiler> */
+if (unlikely(var1 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _count_type_test_skipped");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 947);
+show_backtrace(1);
+}
+var = var1;
 RET_LABEL:;
+return var;
+}
+/* method abstract_compiler#AbstractCompiler#count_type_test_skipped for (self: Object): HashMap[String, Int] */
+val* VIRTUAL_abstract_compiler__AbstractCompiler__count_type_test_skipped(val* self) {
+val* var /* : HashMap[String, Int] */;
+val* var1 /* : HashMap[String, Int] */;
+val* var3 /* : HashMap[String, Int] */;
+{ /* Inline abstract_compiler#AbstractCompiler#count_type_test_skipped (self) on <self:Object(AbstractCompiler)> */
+var3 = self->attrs[COLOR_abstract_compiler__AbstractCompiler___count_type_test_skipped].val; /* _count_type_test_skipped on <self:Object(AbstractCompiler)> */
+if (unlikely(var3 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _count_type_test_skipped");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 947);
+show_backtrace(1);
+}
+var1 = var3;
+RET_LABEL2:(void)0;
 }
-/* method abstract_compiler#ExternCFile#init for (self: Object, String, String) */
-void VIRTUAL_abstract_compiler__ExternCFile__init(val* self, val* p0, val* p1) {
-abstract_compiler__ExternCFile__init(self, p0, p1);
+var = var1;
 RET_LABEL:;
+return var;
+}
+/* method abstract_compiler#AbstractCompiler#init_count_type_test_tags for (self: AbstractCompiler): HashMap[String, Int] */
+val* abstract_compiler__AbstractCompiler__init_count_type_test_tags(val* self) {
+val* var /* : HashMap[String, Int] */;
+val* var1 /* : HashMap[String, Int] */;
+val* var_res /* var res: HashMap[String, Int] */;
+val* var2 /* : Array[String] */;
+val* var4 /* : Array[String] */;
+val* var_ /* var : Array[String] */;
+val* var5 /* : ArrayIterator[nullable Object] */;
+val* var_6 /* var : ArrayIterator[String] */;
+short int var7 /* : Bool */;
+val* var8 /* : nullable Object */;
+val* var_tag /* var tag: String */;
+long var9 /* : Int */;
+val* var10 /* : nullable Object */;
+var1 = NEW_hash_collection__HashMap(&type_hash_collection__HashMapstring__Stringkernel__Int);
+{
+((void (*)(val*))(var1->class->vft[COLOR_kernel__Object__init]))(var1) /* init on <var1:HashMap[String, Int]>*/;
+}
+var_res = var1;
+{
+{ /* Inline abstract_compiler#AbstractCompiler#count_type_test_tags (self) on <self:AbstractCompiler> */
+var4 = self->attrs[COLOR_abstract_compiler__AbstractCompiler___count_type_test_tags].val; /* _count_type_test_tags on <self:AbstractCompiler> */
+if (unlikely(var4 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _count_type_test_tags");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 944);
+show_backtrace(1);
+}
+var2 = var4;
+RET_LABEL3:(void)0;
+}
+}
+var_ = var2;
+{
+var5 = array__AbstractArrayRead__iterator(var_);
+}
+var_6 = var5;
+for(;;) {
+{
+var7 = array__ArrayIterator__is_ok(var_6);
+}
+if (var7){
+{
+var8 = array__ArrayIterator__item(var_6);
+}
+var_tag = var8;
+var9 = 0;
+{
+var10 = BOX_kernel__Int(var9); /* autobox from Int to nullable Object */
+hash_collection__HashMap___91d_93d_61d(var_res, var_tag, var10); /* Direct call hash_collection#HashMap#[]= on <var_res:HashMap[String, Int]>*/
+}
+{
+array__ArrayIterator__next(var_6); /* Direct call array#ArrayIterator#next on <var_6:ArrayIterator[String]>*/
 }
-/* method abstract_compiler#MType#ctype for (self: MType): String */
-val* abstract_compiler__MType__ctype(val* self) {
-val* var /* : String */;
-static val* varonce;
-val* var1 /* : String */;
-char* var2 /* : NativeString */;
-long var3 /* : Int */;
-val* var4 /* : String */;
-if (varonce) {
-var1 = varonce;
 } else {
-var2 = "val*";
-var3 = 4;
-var4 = string__NativeString__to_s_with_length(var2, var3);
-var1 = var4;
-varonce = var1;
+goto BREAK_label;
 }
-var = var1;
+}
+BREAK_label: (void)0;
+{
+{ /* Inline abstract_collection#Iterator#finish (var_6) on <var_6:ArrayIterator[String]> */
+RET_LABEL11:(void)0;
+}
+}
+var = var_res;
 goto RET_LABEL;
 RET_LABEL:;
 return var;
 }
-/* method abstract_compiler#MType#ctype for (self: Object): String */
-val* VIRTUAL_abstract_compiler__MType__ctype(val* self) {
-val* var /* : String */;
-val* var1 /* : String */;
-var1 = abstract_compiler__MType__ctype(self);
+/* method abstract_compiler#AbstractCompiler#init_count_type_test_tags for (self: Object): HashMap[String, Int] */
+val* VIRTUAL_abstract_compiler__AbstractCompiler__init_count_type_test_tags(val* self) {
+val* var /* : HashMap[String, Int] */;
+val* var1 /* : HashMap[String, Int] */;
+var1 = abstract_compiler__AbstractCompiler__init_count_type_test_tags(self);
 var = var1;
 RET_LABEL:;
 return var;
 }
-/* method abstract_compiler#MType#ctypename for (self: MType): String */
-val* abstract_compiler__MType__ctypename(val* self) {
-val* var /* : String */;
+/* method abstract_compiler#AbstractCompiler#display_stats for (self: AbstractCompiler) */
+void abstract_compiler__AbstractCompiler__display_stats(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 */;
 static val* varonce;
-val* var1 /* : String */;
-char* var2 /* : NativeString */;
-long var3 /* : Int */;
-val* var4 /* : String */;
+val* var13 /* : String */;
+char* var14 /* : NativeString */;
+long var15 /* : Int */;
+val* var16 /* : FlatString */;
+static val* varonce17;
+val* var18 /* : String */;
+char* var19 /* : NativeString */;
+long var20 /* : Int */;
+val* var21 /* : FlatString */;
+val* var22 /* : HashMap[String, Int] */;
+val* var_count_type_test_total /* var count_type_test_total: HashMap[String, Int] */;
+val* var23 /* : HashMap[String, Int] */;
+val* var25 /* : HashMap[String, Int] */;
+static val* varonce26;
+val* var27 /* : String */;
+char* var28 /* : NativeString */;
+long var29 /* : Int */;
+val* var30 /* : FlatString */;
+long var31 /* : Int */;
+val* var32 /* : nullable Object */;
+val* var33 /* : HashMap[String, Int] */;
+val* var35 /* : HashMap[String, Int] */;
+static val* varonce36;
+val* var37 /* : String */;
+char* var38 /* : NativeString */;
+long var39 /* : Int */;
+val* var40 /* : FlatString */;
+long var41 /* : Int */;
+val* var42 /* : nullable Object */;
+val* var43 /* : HashMap[String, Int] */;
+val* var45 /* : HashMap[String, Int] */;
+static val* varonce46;
+val* var47 /* : String */;
+char* var48 /* : NativeString */;
+long var49 /* : Int */;
+val* var50 /* : FlatString */;
+long var51 /* : Int */;
+val* var52 /* : nullable Object */;
+static val* varonce53;
+val* var54 /* : String */;
+char* var55 /* : NativeString */;
+long var56 /* : Int */;
+val* var57 /* : FlatString */;
+long var58 /* : Int */;
+val* var59 /* : nullable Object */;
+val* var60 /* : Array[String] */;
+val* var62 /* : Array[String] */;
+val* var_ /* var : Array[String] */;
+val* var63 /* : ArrayIterator[nullable Object] */;
+val* var_64 /* var : ArrayIterator[String] */;
+short int var65 /* : Bool */;
+val* var66 /* : nullable Object */;
+val* var_tag /* var tag: String */;
+val* var67 /* : HashMap[String, Int] */;
+val* var69 /* : HashMap[String, Int] */;
+val* var70 /* : nullable Object */;
+val* var71 /* : HashMap[String, Int] */;
+val* var73 /* : HashMap[String, Int] */;
+val* var74 /* : nullable Object */;
+long var75 /* : Int */;
+short int var77 /* : Bool */;
+int cltype;
+int idtype;
+const char* var_class_name;
+long var78 /* : Int */;
+long var79 /* : Int */;
+long var80 /* : Int */;
+val* var81 /* : HashMap[String, Int] */;
+val* var83 /* : HashMap[String, Int] */;
+val* var84 /* : nullable Object */;
+long var85 /* : Int */;
+short int var87 /* : Bool */;
+int cltype88;
+int idtype89;
+const char* var_class_name90;
+long var91 /* : Int */;
+long var92 /* : Int */;
+val* var93 /* : nullable Object */;
+val* var94 /* : HashMap[String, Int] */;
+val* var96 /* : HashMap[String, Int] */;
+val* var_97 /* var : HashMap[String, Int] */;
+static val* varonce98;
+val* var99 /* : String */;
+char* var100 /* : NativeString */;
+long var101 /* : Int */;
+val* var102 /* : FlatString */;
+val* var_103 /* var : String */;
+val* var104 /* : nullable Object */;
+val* var105 /* : HashMap[String, Int] */;
+val* var107 /* : HashMap[String, Int] */;
+val* var108 /* : nullable Object */;
+long var109 /* : Int */;
+short int var111 /* : Bool */;
+int cltype112;
+int idtype113;
+const char* var_class_name114;
+long var115 /* : Int */;
+long var116 /* : Int */;
+long var117 /* : Int */;
+val* var118 /* : nullable Object */;
+val* var119 /* : HashMap[String, Int] */;
+val* var121 /* : HashMap[String, Int] */;
+val* var_122 /* var : HashMap[String, Int] */;
+static val* varonce123;
+val* var124 /* : String */;
+char* var125 /* : NativeString */;
+long var126 /* : Int */;
+val* var127 /* : FlatString */;
+val* var_128 /* var : String */;
+val* var129 /* : nullable Object */;
+val* var130 /* : HashMap[String, Int] */;
+val* var132 /* : HashMap[String, Int] */;
+val* var133 /* : nullable Object */;
+long var134 /* : Int */;
+short int var136 /* : Bool */;
+int cltype137;
+int idtype138;
+const char* var_class_name139;
+long var140 /* : Int */;
+long var141 /* : Int */;
+long var142 /* : Int */;
+val* var143 /* : nullable Object */;
+val* var144 /* : HashMap[String, Int] */;
+val* var146 /* : HashMap[String, Int] */;
+val* var_147 /* var : HashMap[String, Int] */;
+static val* varonce148;
+val* var149 /* : String */;
+char* var150 /* : NativeString */;
+long var151 /* : Int */;
+val* var152 /* : FlatString */;
+val* var_153 /* var : String */;
+val* var154 /* : nullable Object */;
+val* var155 /* : HashMap[String, Int] */;
+val* var157 /* : HashMap[String, Int] */;
+val* var158 /* : nullable Object */;
+long var159 /* : Int */;
+short int var161 /* : Bool */;
+int cltype162;
+int idtype163;
+const char* var_class_name164;
+long var165 /* : Int */;
+long var166 /* : Int */;
+long var167 /* : Int */;
+val* var168 /* : nullable Object */;
+val* var_169 /* var : HashMap[String, Int] */;
+static val* varonce170;
+val* var171 /* : String */;
+char* var172 /* : NativeString */;
+long var173 /* : Int */;
+val* var174 /* : FlatString */;
+val* var_175 /* var : String */;
+val* var176 /* : nullable Object */;
+val* var177 /* : nullable Object */;
+long var178 /* : Int */;
+short int var180 /* : Bool */;
+int cltype181;
+int idtype182;
+const char* var_class_name183;
+long var184 /* : Int */;
+long var185 /* : Int */;
+long var186 /* : Int */;
+val* var187 /* : nullable Object */;
+static val* varonce189;
+val* var190 /* : String */;
+char* var191 /* : NativeString */;
+long var192 /* : Int */;
+val* var193 /* : FlatString */;
+val* var194 /* : nullable Object */;
+long var195 /* : Int */;
+long var_count_type_test /* var count_type_test: Int */;
+val* var196 /* : Array[String] */;
+val* var198 /* : Array[String] */;
+val* var199 /* : Array[nullable Object] */;
+val* var_tags /* var tags: Array[String] */;
+static val* varonce200;
+val* var201 /* : String */;
+char* var202 /* : NativeString */;
+long var203 /* : Int */;
+val* var204 /* : FlatString */;
+val* var_205 /* var : Array[String] */;
+val* var206 /* : ArrayIterator[nullable Object] */;
+val* var_207 /* var : ArrayIterator[String] */;
+short int var208 /* : Bool */;
+val* var209 /* : nullable Object */;
+val* var_tag210 /* var tag: String */;
+val* var211 /* : Array[Object] */;
+long var212 /* : Int */;
+val* var213 /* : NativeArray[Object] */;
+static val* varonce214;
+val* var215 /* : String */;
+char* var216 /* : NativeString */;
+long var217 /* : Int */;
+val* var218 /* : FlatString */;
+val* var219 /* : HashMap[String, Int] */;
+val* var221 /* : HashMap[String, Int] */;
+val* var222 /* : nullable Object */;
+static val* varonce223;
+val* var224 /* : String */;
+char* var225 /* : NativeString */;
+long var226 /* : Int */;
+val* var227 /* : FlatString */;
+val* var228 /* : HashMap[String, Int] */;
+val* var230 /* : HashMap[String, Int] */;
+val* var231 /* : nullable Object */;
+val* var232 /* : String */;
+long var233 /* : Int */;
+static val* varonce234;
+val* var235 /* : String */;
+char* var236 /* : NativeString */;
+long var237 /* : Int */;
+val* var238 /* : FlatString */;
+val* var239 /* : Array[Object] */;
+long var240 /* : Int */;
+val* var241 /* : NativeArray[Object] */;
+val* var242 /* : String */;
+val* var243 /* : Array[Object] */;
+long var244 /* : Int */;
+val* var245 /* : NativeArray[Object] */;
+static val* varonce246;
+val* var247 /* : String */;
+char* var248 /* : NativeString */;
+long var249 /* : Int */;
+val* var250 /* : FlatString */;
+val* var251 /* : HashMap[String, Int] */;
+val* var253 /* : HashMap[String, Int] */;
+val* var254 /* : nullable Object */;
+static val* varonce255;
+val* var256 /* : String */;
+char* var257 /* : NativeString */;
+long var258 /* : Int */;
+val* var259 /* : FlatString */;
+val* var260 /* : HashMap[String, Int] */;
+val* var262 /* : HashMap[String, Int] */;
+val* var263 /* : nullable Object */;
+val* var264 /* : String */;
+long var265 /* : Int */;
+static val* varonce266;
+val* var267 /* : String */;
+char* var268 /* : NativeString */;
+long var269 /* : Int */;
+val* var270 /* : FlatString */;
+val* var271 /* : Array[Object] */;
+long var272 /* : Int */;
+val* var273 /* : NativeArray[Object] */;
+val* var274 /* : String */;
+val* var275 /* : Array[Object] */;
+long var276 /* : Int */;
+val* var277 /* : NativeArray[Object] */;
+static val* varonce278;
+val* var279 /* : String */;
+char* var280 /* : NativeString */;
+long var281 /* : Int */;
+val* var282 /* : FlatString */;
+val* var283 /* : HashMap[String, Int] */;
+val* var285 /* : HashMap[String, Int] */;
+val* var286 /* : nullable Object */;
+static val* varonce287;
+val* var288 /* : String */;
+char* var289 /* : NativeString */;
+long var290 /* : Int */;
+val* var291 /* : FlatString */;
+val* var292 /* : HashMap[String, Int] */;
+val* var294 /* : HashMap[String, Int] */;
+val* var295 /* : nullable Object */;
+val* var296 /* : String */;
+long var297 /* : Int */;
+static val* varonce298;
+val* var299 /* : String */;
+char* var300 /* : NativeString */;
+long var301 /* : Int */;
+val* var302 /* : FlatString */;
+val* var303 /* : Array[Object] */;
+long var304 /* : Int */;
+val* var305 /* : NativeArray[Object] */;
+val* var306 /* : String */;
+val* var307 /* : Array[Object] */;
+long var308 /* : Int */;
+val* var309 /* : NativeArray[Object] */;
+static val* varonce310;
+val* var311 /* : String */;
+char* var312 /* : NativeString */;
+long var313 /* : Int */;
+val* var314 /* : FlatString */;
+val* var315 /* : nullable Object */;
+static val* varonce316;
+val* var317 /* : String */;
+char* var318 /* : NativeString */;
+long var319 /* : Int */;
+val* var320 /* : FlatString */;
+val* var321 /* : nullable Object */;
+val* var322 /* : String */;
+long var323 /* : Int */;
+static val* varonce324;
+val* var325 /* : String */;
+char* var326 /* : NativeString */;
+long var327 /* : Int */;
+val* var328 /* : FlatString */;
+val* var329 /* : Array[Object] */;
+long var330 /* : Int */;
+val* var331 /* : NativeArray[Object] */;
+val* var332 /* : String */;
+val* var333 /* : Array[Object] */;
+long var334 /* : Int */;
+val* var335 /* : NativeArray[Object] */;
+static val* varonce336;
+val* var337 /* : String */;
+char* var338 /* : NativeString */;
+long var339 /* : Int */;
+val* var340 /* : FlatString */;
+{
+{ /* Inline abstract_compiler#AbstractCompiler#modelbuilder (self) on <self:AbstractCompiler> */
+var2 = self->attrs[COLOR_abstract_compiler__AbstractCompiler___modelbuilder].val; /* _modelbuilder on <self:AbstractCompiler> */
+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 abstract_compiler#ToolContext#opt_typing_test_metrics (var3) on <var3:ToolContext> */
+var8 = var3->attrs[COLOR_abstract_compiler__ToolContext___opt_typing_test_metrics].val; /* _opt_typing_test_metrics on <var3:ToolContext> */
+if (unlikely(var8 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _opt_typing_test_metrics");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 61);
+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){
 if (varonce) {
-var1 = varonce;
+var13 = varonce;
 } else {
-var2 = "val";
-var3 = 3;
-var4 = string__NativeString__to_s_with_length(var2, var3);
-var1 = var4;
-varonce = var1;
+var14 = "# static count_type_test";
+var15 = 24;
+var16 = string__NativeString__to_s_with_length(var14, var15);
+var13 = var16;
+varonce = var13;
 }
-var = var1;
-goto RET_LABEL;
-RET_LABEL:;
-return var;
+{
+file__Object__print(self, var13); /* Direct call file#Object#print on <self:AbstractCompiler>*/
+}
+if (varonce17) {
+var18 = varonce17;
+} else {
+var19 = "\11resolved:\11unresolved\11skipped\11total";
+var20 = 35;
+var21 = string__NativeString__to_s_with_length(var19, var20);
+var18 = var21;
+varonce17 = var18;
+}
+{
+file__Object__print(self, var18); /* Direct call file#Object#print on <self:AbstractCompiler>*/
+}
+{
+var22 = abstract_compiler__AbstractCompiler__init_count_type_test_tags(self);
+}
+var_count_type_test_total = var22;
+{
+{ /* Inline abstract_compiler#AbstractCompiler#count_type_test_resolved (self) on <self:AbstractCompiler> */
+var25 = self->attrs[COLOR_abstract_compiler__AbstractCompiler___count_type_test_resolved].val; /* _count_type_test_resolved on <self:AbstractCompiler> */
+if (unlikely(var25 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _count_type_test_resolved");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 945);
+show_backtrace(1);
+}
+var23 = var25;
+RET_LABEL24:(void)0;
+}
+}
+if (varonce26) {
+var27 = varonce26;
+} else {
+var28 = "total";
+var29 = 5;
+var30 = string__NativeString__to_s_with_length(var28, var29);
+var27 = var30;
+varonce26 = var27;
+}
+var31 = 0;
+{
+var32 = BOX_kernel__Int(var31); /* autobox from Int to nullable Object */
+hash_collection__HashMap___91d_93d_61d(var23, var27, var32); /* Direct call hash_collection#HashMap#[]= on <var23:HashMap[String, Int]>*/
+}
+{
+{ /* Inline abstract_compiler#AbstractCompiler#count_type_test_unresolved (self) on <self:AbstractCompiler> */
+var35 = self->attrs[COLOR_abstract_compiler__AbstractCompiler___count_type_test_unresolved].val; /* _count_type_test_unresolved on <self:AbstractCompiler> */
+if (unlikely(var35 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _count_type_test_unresolved");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 946);
+show_backtrace(1);
 }
-/* method abstract_compiler#MType#ctypename for (self: Object): String */
-val* VIRTUAL_abstract_compiler__MType__ctypename(val* self) {
-val* var /* : String */;
-val* var1 /* : String */;
-var1 = abstract_compiler__MType__ctypename(self);
-var = var1;
-RET_LABEL:;
-return var;
+var33 = var35;
+RET_LABEL34:(void)0;
 }
-/* method abstract_compiler#MType#c_name for (self: MType): String */
-val* abstract_compiler__MType__c_name(val* self) {
-val* var /* : String */;
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Deferred method called", "src/abstract_compiler.nit", 1083);
-exit(1);
-RET_LABEL:;
-return var;
 }
-/* method abstract_compiler#MType#c_name for (self: Object): String */
-val* VIRTUAL_abstract_compiler__MType__c_name(val* self) {
-val* var /* : String */;
-val* var1 /* : String */;
-var1 = abstract_compiler__MType__c_name(self);
-var = var1;
-RET_LABEL:;
-return var;
+if (varonce36) {
+var37 = varonce36;
+} else {
+var38 = "total";
+var39 = 5;
+var40 = string__NativeString__to_s_with_length(var38, var39);
+var37 = var40;
+varonce36 = var37;
 }
-/* method abstract_compiler#MType#c_name_cache for (self: MType): nullable String */
-val* abstract_compiler__MType__c_name_cache(val* self) {
-val* var /* : nullable String */;
-val* var1 /* : nullable String */;
-var1 = self->attrs[COLOR_abstract_compiler__MType___64dc_name_cache].val; /* @c_name_cache on <self:MType> */
-var = var1;
-RET_LABEL:;
-return var;
+var41 = 0;
+{
+var42 = BOX_kernel__Int(var41); /* autobox from Int to nullable Object */
+hash_collection__HashMap___91d_93d_61d(var33, var37, var42); /* Direct call hash_collection#HashMap#[]= on <var33:HashMap[String, Int]>*/
 }
-/* method abstract_compiler#MType#c_name_cache for (self: Object): nullable String */
-val* VIRTUAL_abstract_compiler__MType__c_name_cache(val* self) {
-val* var /* : nullable String */;
-val* var1 /* : nullable String */;
-var1 = abstract_compiler__MType__c_name_cache(self);
-var = var1;
-RET_LABEL:;
-return var;
+{
+{ /* Inline abstract_compiler#AbstractCompiler#count_type_test_skipped (self) on <self:AbstractCompiler> */
+var45 = self->attrs[COLOR_abstract_compiler__AbstractCompiler___count_type_test_skipped].val; /* _count_type_test_skipped on <self:AbstractCompiler> */
+if (unlikely(var45 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _count_type_test_skipped");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 947);
+show_backtrace(1);
 }
-/* method abstract_compiler#MType#c_name_cache= for (self: MType, nullable String) */
-void abstract_compiler__MType__c_name_cache_61d(val* self, val* p0) {
-self->attrs[COLOR_abstract_compiler__MType___64dc_name_cache].val = p0; /* @c_name_cache on <self:MType> */
-RET_LABEL:;
+var43 = var45;
+RET_LABEL44:(void)0;
 }
-/* method abstract_compiler#MType#c_name_cache= for (self: Object, nullable String) */
-void VIRTUAL_abstract_compiler__MType__c_name_cache_61d(val* self, val* p0) {
-abstract_compiler__MType__c_name_cache_61d(self, p0);
-RET_LABEL:;
 }
-/* method abstract_compiler#MClassType#c_name for (self: MClassType): String */
-val* abstract_compiler__MClassType__c_name(val* self) {
-val* var /* : String */;
-val* var1 /* : nullable String */;
-val* var_res /* var res: nullable String */;
-val* var2 /* : null */;
-short int var3 /* : Bool */;
-val* var4 /* : Array[Object] */;
-long var5 /* : Int */;
-val* var_ /* var : Array[Object] */;
-static val* varonce;
-val* var6 /* : String */;
-char* var7 /* : NativeString */;
-long var8 /* : Int */;
-val* var9 /* : String */;
-val* var10 /* : MClass */;
-val* var11 /* : MModule */;
-val* var12 /* : String */;
-val* var13 /* : String */;
-static val* varonce14;
-val* var15 /* : String */;
-char* var16 /* : NativeString */;
-long var17 /* : Int */;
-val* var18 /* : String */;
-val* var19 /* : MClass */;
-val* var20 /* : String */;
-val* var21 /* : String */;
-static val* varonce22;
-val* var23 /* : String */;
-char* var24 /* : NativeString */;
-long var25 /* : Int */;
-val* var26 /* : String */;
-val* var27 /* : String */;
-var1 = ((val* (*)(val*))(self->class->vft[COLOR_abstract_compiler__MType__c_name_cache]))(self) /* c_name_cache on <self:MClassType>*/;
-var_res = var1;
-var2 = NULL;
-if (var_res == NULL) {
-var3 = 0; /* is null */
+if (varonce46) {
+var47 = varonce46;
 } else {
-var3 = 1; /* arg is null and recv is not */
+var48 = "total";
+var49 = 5;
+var50 = string__NativeString__to_s_with_length(var48, var49);
+var47 = var50;
+varonce46 = var47;
 }
-if (var3){
-var = var_res;
-goto RET_LABEL;
-} else {
+var51 = 0;
+{
+var52 = BOX_kernel__Int(var51); /* autobox from Int to nullable Object */
+hash_collection__HashMap___91d_93d_61d(var43, var47, var52); /* Direct call hash_collection#HashMap#[]= on <var43:HashMap[String, Int]>*/
 }
-var4 = NEW_array__Array(&type_array__Arraykernel__Object);
-var5 = 5;
-((void (*)(val*, long))(var4->class->vft[COLOR_array__Array__with_capacity]))(var4, var5) /* with_capacity on <var4:Array[Object]>*/;
-CHECK_NEW_array__Array(var4);
-var_ = var4;
-if (varonce) {
-var6 = varonce;
+if (varonce53) {
+var54 = varonce53;
 } else {
-var7 = "";
-var8 = 0;
-var9 = string__NativeString__to_s_with_length(var7, var8);
-var6 = var9;
-varonce = var6;
+var55 = "total";
+var56 = 5;
+var57 = string__NativeString__to_s_with_length(var55, var56);
+var54 = var57;
+varonce53 = var54;
 }
-((void (*)(val*, val*))(var_->class->vft[COLOR_abstract_collection__SimpleCollection__add]))(var_, var6) /* add on <var_:Array[Object]>*/;
-var10 = ((val* (*)(val*))(self->class->vft[COLOR_model__MClassType__mclass]))(self) /* mclass on <self:MClassType>*/;
-var11 = ((val* (*)(val*))(var10->class->vft[COLOR_model__MClass__intro_mmodule]))(var10) /* intro_mmodule on <var10:MClass>*/;
-var12 = ((val* (*)(val*))(var11->class->vft[COLOR_model_base__MModule__name]))(var11) /* name on <var11:MModule>*/;
-var13 = ((val* (*)(val*))(var12->class->vft[COLOR_string__AbstractString__to_cmangle]))(var12) /* to_cmangle on <var12:String>*/;
-((void (*)(val*, val*))(var_->class->vft[COLOR_abstract_collection__SimpleCollection__add]))(var_, var13) /* add on <var_:Array[Object]>*/;
-if (varonce14) {
-var15 = varonce14;
-} else {
-var16 = "__";
-var17 = 2;
-var18 = string__NativeString__to_s_with_length(var16, var17);
-var15 = var18;
-varonce14 = var15;
+var58 = 0;
+{
+var59 = BOX_kernel__Int(var58); /* autobox from Int to nullable Object */
+hash_collection__HashMap___91d_93d_61d(var_count_type_test_total, var54, var59); /* Direct call hash_collection#HashMap#[]= on <var_count_type_test_total:HashMap[String, Int]>*/
 }
-((void (*)(val*, val*))(var_->class->vft[COLOR_abstract_collection__SimpleCollection__add]))(var_, var15) /* add on <var_:Array[Object]>*/;
-var19 = ((val* (*)(val*))(self->class->vft[COLOR_model__MClassType__mclass]))(self) /* mclass on <self:MClassType>*/;
-var20 = ((val* (*)(val*))(var19->class->vft[COLOR_model__MClass__name]))(var19) /* name on <var19:MClass>*/;
-var21 = ((val* (*)(val*))(var20->class->vft[COLOR_string__AbstractString__to_cmangle]))(var20) /* to_cmangle on <var20:String>*/;
-((void (*)(val*, val*))(var_->class->vft[COLOR_abstract_collection__SimpleCollection__add]))(var_, var21) /* add on <var_:Array[Object]>*/;
-if (varonce22) {
-var23 = varonce22;
-} else {
-var24 = "";
-var25 = 0;
-var26 = string__NativeString__to_s_with_length(var24, var25);
-var23 = var26;
-varonce22 = var23;
-}
-((void (*)(val*, val*))(var_->class->vft[COLOR_abstract_collection__SimpleCollection__add]))(var_, var23) /* add on <var_:Array[Object]>*/;
-var27 = ((val* (*)(val*))(var_->class->vft[COLOR_string__Object__to_s]))(var_) /* to_s on <var_:Array[Object]>*/;
-var_res = var27;
-((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__MType__c_name_cache_61d]))(self, var_res) /* c_name_cache= on <self:MClassType>*/;
-var = var_res;
-goto RET_LABEL;
-RET_LABEL:;
-return var;
+{
+{ /* Inline abstract_compiler#AbstractCompiler#count_type_test_tags (self) on <self:AbstractCompiler> */
+var62 = self->attrs[COLOR_abstract_compiler__AbstractCompiler___count_type_test_tags].val; /* _count_type_test_tags on <self:AbstractCompiler> */
+if (unlikely(var62 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _count_type_test_tags");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 944);
+show_backtrace(1);
 }
-/* method abstract_compiler#MClassType#c_name for (self: Object): String */
-val* VIRTUAL_abstract_compiler__MClassType__c_name(val* self) {
-val* var /* : String */;
-val* var1 /* : String */;
-var1 = abstract_compiler__MClassType__c_name(self);
-var = var1;
-RET_LABEL:;
-return var;
+var60 = var62;
+RET_LABEL61:(void)0;
 }
-/* method abstract_compiler#MClassType#ctype for (self: MClassType): String */
-val* abstract_compiler__MClassType__ctype(val* self) {
-val* var /* : String */;
-val* var1 /* : MClass */;
-val* var2 /* : String */;
-static val* varonce;
-val* var3 /* : String */;
-char* var4 /* : NativeString */;
-long var5 /* : Int */;
-val* var6 /* : String */;
-short int var7 /* : Bool */;
-static val* varonce8;
-val* var9 /* : String */;
-char* var10 /* : NativeString */;
-long var11 /* : Int */;
-val* var12 /* : String */;
-val* var13 /* : MClass */;
-val* var14 /* : String */;
-static val* varonce15;
-val* var16 /* : String */;
-char* var17 /* : NativeString */;
-long var18 /* : Int */;
-val* var19 /* : String */;
-short int var20 /* : Bool */;
-static val* varonce21;
-val* var22 /* : String */;
-char* var23 /* : NativeString */;
-long var24 /* : Int */;
-val* var25 /* : String */;
-val* var26 /* : MClass */;
-val* var27 /* : String */;
-static val* varonce28;
-val* var29 /* : String */;
-char* var30 /* : NativeString */;
-long var31 /* : Int */;
-val* var32 /* : String */;
-short int var33 /* : Bool */;
-static val* varonce34;
-val* var35 /* : String */;
-char* var36 /* : NativeString */;
-long var37 /* : Int */;
-val* var38 /* : String */;
-val* var39 /* : MClass */;
-val* var40 /* : String */;
-static val* varonce41;
-val* var42 /* : String */;
-char* var43 /* : NativeString */;
-long var44 /* : Int */;
-val* var45 /* : String */;
-short int var46 /* : Bool */;
-static val* varonce47;
-val* var48 /* : String */;
-char* var49 /* : NativeString */;
-long var50 /* : Int */;
-val* var51 /* : String */;
-val* var52 /* : MClass */;
-val* var53 /* : String */;
-static val* varonce54;
-val* var55 /* : String */;
-char* var56 /* : NativeString */;
-long var57 /* : Int */;
-val* var58 /* : String */;
-short int var59 /* : Bool */;
-static val* varonce60;
-val* var61 /* : String */;
-char* var62 /* : NativeString */;
-long var63 /* : Int */;
-val* var64 /* : String */;
-val* var65 /* : MClass */;
-val* var66 /* : String */;
-static val* varonce67;
-val* var68 /* : String */;
-char* var69 /* : NativeString */;
-long var70 /* : Int */;
-val* var71 /* : String */;
-short int var72 /* : Bool */;
-static val* varonce73;
-val* var74 /* : String */;
-char* var75 /* : NativeString */;
-long var76 /* : Int */;
-val* var77 /* : String */;
-val* var78 /* : MClass */;
-val* var79 /* : MClassKind */;
-val* var80 /* : MClassKind */;
-short int var81 /* : Bool */;
-static val* varonce82;
-val* var83 /* : String */;
-char* var84 /* : NativeString */;
-long var85 /* : Int */;
-val* var86 /* : String */;
-static val* varonce87;
-val* var88 /* : String */;
-char* var89 /* : NativeString */;
-long var90 /* : Int */;
-val* var91 /* : String */;
-var1 = ((val* (*)(val*))(self->class->vft[COLOR_model__MClassType__mclass]))(self) /* mclass on <self:MClassType>*/;
-var2 = ((val* (*)(val*))(var1->class->vft[COLOR_model__MClass__name]))(var1) /* name on <var1:MClass>*/;
-if (varonce) {
-var3 = varonce;
-} else {
-var4 = "Int";
-var5 = 3;
-var6 = string__NativeString__to_s_with_length(var4, var5);
-var3 = var6;
-varonce = var3;
 }
-var7 = ((short int (*)(val*, val*))(var2->class->vft[COLOR_kernel__Object___61d_61d]))(var2, var3) /* == on <var2:String>*/;
-if (var7){
-if (varonce8) {
-var9 = varonce8;
-} else {
-var10 = "long";
-var11 = 4;
-var12 = string__NativeString__to_s_with_length(var10, var11);
-var9 = var12;
-varonce8 = var9;
+var_ = var60;
+{
+var63 = array__AbstractArrayRead__iterator(var_);
 }
-var = var9;
-goto RET_LABEL;
-} else {
-var13 = ((val* (*)(val*))(self->class->vft[COLOR_model__MClassType__mclass]))(self) /* mclass on <self:MClassType>*/;
-var14 = ((val* (*)(val*))(var13->class->vft[COLOR_model__MClass__name]))(var13) /* name on <var13:MClass>*/;
-if (varonce15) {
-var16 = varonce15;
+var_64 = var63;
+for(;;) {
+{
+var65 = array__ArrayIterator__is_ok(var_64);
+}
+if (var65){
+{
+var66 = array__ArrayIterator__item(var_64);
+}
+var_tag = var66;
+{
+{ /* Inline abstract_compiler#AbstractCompiler#count_type_test_resolved (self) on <self:AbstractCompiler> */
+var69 = self->attrs[COLOR_abstract_compiler__AbstractCompiler___count_type_test_resolved].val; /* _count_type_test_resolved on <self:AbstractCompiler> */
+if (unlikely(var69 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _count_type_test_resolved");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 945);
+show_backtrace(1);
+}
+var67 = var69;
+RET_LABEL68:(void)0;
+}
+}
+{
+var70 = hash_collection__HashMap___91d_93d(var67, var_tag);
+}
+{
+{ /* Inline abstract_compiler#AbstractCompiler#count_type_test_unresolved (self) on <self:AbstractCompiler> */
+var73 = self->attrs[COLOR_abstract_compiler__AbstractCompiler___count_type_test_unresolved].val; /* _count_type_test_unresolved on <self:AbstractCompiler> */
+if (unlikely(var73 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _count_type_test_unresolved");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 946);
+show_backtrace(1);
+}
+var71 = var73;
+RET_LABEL72:(void)0;
+}
+}
+{
+var74 = hash_collection__HashMap___91d_93d(var71, var_tag);
+}
+{
+{ /* Inline kernel#Int#+ (var70,var74) on <var70:nullable Object(Int)> */
+/* Covariant cast for argument 0 (i) <var74:nullable Object(Int)> isa OTHER */
+/* <var74:nullable Object(Int)> isa OTHER */
+var77 = 1; /* easy <var74:nullable Object(Int)> isa OTHER*/
+if (unlikely(!var77)) {
+var_class_name = var74 == NULL ? "null" : var74->type->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);
+}
+var78 = ((struct instance_kernel__Int*)var70)->value; /* autounbox from nullable Object to Int */;
+var79 = ((struct instance_kernel__Int*)var74)->value; /* autounbox from nullable Object to Int */;
+var80 = var78 + var79;
+var75 = var80;
+goto RET_LABEL76;
+RET_LABEL76:(void)0;
+}
+}
+{
+{ /* Inline abstract_compiler#AbstractCompiler#count_type_test_skipped (self) on <self:AbstractCompiler> */
+var83 = self->attrs[COLOR_abstract_compiler__AbstractCompiler___count_type_test_skipped].val; /* _count_type_test_skipped on <self:AbstractCompiler> */
+if (unlikely(var83 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _count_type_test_skipped");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 947);
+show_backtrace(1);
+}
+var81 = var83;
+RET_LABEL82:(void)0;
+}
+}
+{
+var84 = hash_collection__HashMap___91d_93d(var81, var_tag);
+}
+{
+{ /* Inline kernel#Int#+ (var75,var84) on <var75:Int> */
+/* Covariant cast for argument 0 (i) <var84:nullable Object(Int)> isa OTHER */
+/* <var84:nullable Object(Int)> isa OTHER */
+var87 = 1; /* easy <var84:nullable Object(Int)> isa OTHER*/
+if (unlikely(!var87)) {
+var_class_name90 = var84 == NULL ? "null" : var84->type->name;
+PRINT_ERROR("Runtime error: Cast failed. Expected `%s`, got `%s`", "OTHER", var_class_name90);
+PRINT_ERROR(" (%s:%d)\n", "../lib/standard/kernel.nit", 374);
+show_backtrace(1);
+}
+var91 = ((struct instance_kernel__Int*)var84)->value; /* autounbox from nullable Object to Int */;
+var92 = var75 + var91;
+var85 = var92;
+goto RET_LABEL86;
+RET_LABEL86:(void)0;
+}
+}
+{
+var93 = BOX_kernel__Int(var85); /* autobox from Int to nullable Object */
+hash_collection__HashMap___91d_93d_61d(var_count_type_test_total, var_tag, var93); /* Direct call hash_collection#HashMap#[]= on <var_count_type_test_total:HashMap[String, Int]>*/
+}
+{
+{ /* Inline abstract_compiler#AbstractCompiler#count_type_test_resolved (self) on <self:AbstractCompiler> */
+var96 = self->attrs[COLOR_abstract_compiler__AbstractCompiler___count_type_test_resolved].val; /* _count_type_test_resolved on <self:AbstractCompiler> */
+if (unlikely(var96 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _count_type_test_resolved");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 945);
+show_backtrace(1);
+}
+var94 = var96;
+RET_LABEL95:(void)0;
+}
+}
+var_97 = var94;
+if (varonce98) {
+var99 = varonce98;
 } else {
-var17 = "Bool";
-var18 = 4;
-var19 = string__NativeString__to_s_with_length(var17, var18);
-var16 = var19;
-varonce15 = var16;
+var100 = "total";
+var101 = 5;
+var102 = string__NativeString__to_s_with_length(var100, var101);
+var99 = var102;
+varonce98 = var99;
 }
-var20 = ((short int (*)(val*, val*))(var14->class->vft[COLOR_kernel__Object___61d_61d]))(var14, var16) /* == on <var14:String>*/;
-if (var20){
-if (varonce21) {
-var22 = varonce21;
+var_103 = var99;
+{
+var104 = hash_collection__HashMap___91d_93d(var_97, var_103);
+}
+{
+{ /* Inline abstract_compiler#AbstractCompiler#count_type_test_resolved (self) on <self:AbstractCompiler> */
+var107 = self->attrs[COLOR_abstract_compiler__AbstractCompiler___count_type_test_resolved].val; /* _count_type_test_resolved on <self:AbstractCompiler> */
+if (unlikely(var107 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _count_type_test_resolved");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 945);
+show_backtrace(1);
+}
+var105 = var107;
+RET_LABEL106:(void)0;
+}
+}
+{
+var108 = hash_collection__HashMap___91d_93d(var105, var_tag);
+}
+{
+{ /* Inline kernel#Int#+ (var104,var108) on <var104:nullable Object(Int)> */
+/* Covariant cast for argument 0 (i) <var108:nullable Object(Int)> isa OTHER */
+/* <var108:nullable Object(Int)> isa OTHER */
+var111 = 1; /* easy <var108:nullable Object(Int)> isa OTHER*/
+if (unlikely(!var111)) {
+var_class_name114 = var108 == NULL ? "null" : var108->type->name;
+PRINT_ERROR("Runtime error: Cast failed. Expected `%s`, got `%s`", "OTHER", var_class_name114);
+PRINT_ERROR(" (%s:%d)\n", "../lib/standard/kernel.nit", 374);
+show_backtrace(1);
+}
+var115 = ((struct instance_kernel__Int*)var104)->value; /* autounbox from nullable Object to Int */;
+var116 = ((struct instance_kernel__Int*)var108)->value; /* autounbox from nullable Object to Int */;
+var117 = var115 + var116;
+var109 = var117;
+goto RET_LABEL110;
+RET_LABEL110:(void)0;
+}
+}
+{
+var118 = BOX_kernel__Int(var109); /* autobox from Int to nullable Object */
+hash_collection__HashMap___91d_93d_61d(var_97, var_103, var118); /* Direct call hash_collection#HashMap#[]= on <var_97:HashMap[String, Int]>*/
+}
+{
+{ /* Inline abstract_compiler#AbstractCompiler#count_type_test_unresolved (self) on <self:AbstractCompiler> */
+var121 = self->attrs[COLOR_abstract_compiler__AbstractCompiler___count_type_test_unresolved].val; /* _count_type_test_unresolved on <self:AbstractCompiler> */
+if (unlikely(var121 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _count_type_test_unresolved");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 946);
+show_backtrace(1);
+}
+var119 = var121;
+RET_LABEL120:(void)0;
+}
+}
+var_122 = var119;
+if (varonce123) {
+var124 = varonce123;
 } else {
-var23 = "short int";
-var24 = 9;
-var25 = string__NativeString__to_s_with_length(var23, var24);
-var22 = var25;
-varonce21 = var22;
+var125 = "total";
+var126 = 5;
+var127 = string__NativeString__to_s_with_length(var125, var126);
+var124 = var127;
+varonce123 = var124;
 }
-var = var22;
-goto RET_LABEL;
-} else {
-var26 = ((val* (*)(val*))(self->class->vft[COLOR_model__MClassType__mclass]))(self) /* mclass on <self:MClassType>*/;
-var27 = ((val* (*)(val*))(var26->class->vft[COLOR_model__MClass__name]))(var26) /* name on <var26:MClass>*/;
-if (varonce28) {
-var29 = varonce28;
-} else {
-var30 = "Char";
-var31 = 4;
-var32 = string__NativeString__to_s_with_length(var30, var31);
-var29 = var32;
-varonce28 = var29;
+var_128 = var124;
+{
+var129 = hash_collection__HashMap___91d_93d(var_122, var_128);
+}
+{
+{ /* Inline abstract_compiler#AbstractCompiler#count_type_test_unresolved (self) on <self:AbstractCompiler> */
+var132 = self->attrs[COLOR_abstract_compiler__AbstractCompiler___count_type_test_unresolved].val; /* _count_type_test_unresolved on <self:AbstractCompiler> */
+if (unlikely(var132 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _count_type_test_unresolved");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 946);
+show_backtrace(1);
+}
+var130 = var132;
+RET_LABEL131:(void)0;
+}
+}
+{
+var133 = hash_collection__HashMap___91d_93d(var130, var_tag);
+}
+{
+{ /* Inline kernel#Int#+ (var129,var133) on <var129:nullable Object(Int)> */
+/* Covariant cast for argument 0 (i) <var133:nullable Object(Int)> isa OTHER */
+/* <var133:nullable Object(Int)> isa OTHER */
+var136 = 1; /* easy <var133:nullable Object(Int)> isa OTHER*/
+if (unlikely(!var136)) {
+var_class_name139 = var133 == NULL ? "null" : var133->type->name;
+PRINT_ERROR("Runtime error: Cast failed. Expected `%s`, got `%s`", "OTHER", var_class_name139);
+PRINT_ERROR(" (%s:%d)\n", "../lib/standard/kernel.nit", 374);
+show_backtrace(1);
+}
+var140 = ((struct instance_kernel__Int*)var129)->value; /* autounbox from nullable Object to Int */;
+var141 = ((struct instance_kernel__Int*)var133)->value; /* autounbox from nullable Object to Int */;
+var142 = var140 + var141;
+var134 = var142;
+goto RET_LABEL135;
+RET_LABEL135:(void)0;
+}
+}
+{
+var143 = BOX_kernel__Int(var134); /* autobox from Int to nullable Object */
+hash_collection__HashMap___91d_93d_61d(var_122, var_128, var143); /* Direct call hash_collection#HashMap#[]= on <var_122:HashMap[String, Int]>*/
+}
+{
+{ /* Inline abstract_compiler#AbstractCompiler#count_type_test_skipped (self) on <self:AbstractCompiler> */
+var146 = self->attrs[COLOR_abstract_compiler__AbstractCompiler___count_type_test_skipped].val; /* _count_type_test_skipped on <self:AbstractCompiler> */
+if (unlikely(var146 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _count_type_test_skipped");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 947);
+show_backtrace(1);
+}
+var144 = var146;
+RET_LABEL145:(void)0;
+}
+}
+var_147 = var144;
+if (varonce148) {
+var149 = varonce148;
+} else {
+var150 = "total";
+var151 = 5;
+var152 = string__NativeString__to_s_with_length(var150, var151);
+var149 = var152;
+varonce148 = var149;
+}
+var_153 = var149;
+{
+var154 = hash_collection__HashMap___91d_93d(var_147, var_153);
+}
+{
+{ /* Inline abstract_compiler#AbstractCompiler#count_type_test_skipped (self) on <self:AbstractCompiler> */
+var157 = self->attrs[COLOR_abstract_compiler__AbstractCompiler___count_type_test_skipped].val; /* _count_type_test_skipped on <self:AbstractCompiler> */
+if (unlikely(var157 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _count_type_test_skipped");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 947);
+show_backtrace(1);
+}
+var155 = var157;
+RET_LABEL156:(void)0;
+}
+}
+{
+var158 = hash_collection__HashMap___91d_93d(var155, var_tag);
+}
+{
+{ /* Inline kernel#Int#+ (var154,var158) on <var154:nullable Object(Int)> */
+/* Covariant cast for argument 0 (i) <var158:nullable Object(Int)> isa OTHER */
+/* <var158:nullable Object(Int)> isa OTHER */
+var161 = 1; /* easy <var158:nullable Object(Int)> isa OTHER*/
+if (unlikely(!var161)) {
+var_class_name164 = var158 == NULL ? "null" : var158->type->name;
+PRINT_ERROR("Runtime error: Cast failed. Expected `%s`, got `%s`", "OTHER", var_class_name164);
+PRINT_ERROR(" (%s:%d)\n", "../lib/standard/kernel.nit", 374);
+show_backtrace(1);
+}
+var165 = ((struct instance_kernel__Int*)var154)->value; /* autounbox from nullable Object to Int */;
+var166 = ((struct instance_kernel__Int*)var158)->value; /* autounbox from nullable Object to Int */;
+var167 = var165 + var166;
+var159 = var167;
+goto RET_LABEL160;
+RET_LABEL160:(void)0;
+}
+}
+{
+var168 = BOX_kernel__Int(var159); /* autobox from Int to nullable Object */
+hash_collection__HashMap___91d_93d_61d(var_147, var_153, var168); /* Direct call hash_collection#HashMap#[]= on <var_147:HashMap[String, Int]>*/
+}
+var_169 = var_count_type_test_total;
+if (varonce170) {
+var171 = varonce170;
+} else {
+var172 = "total";
+var173 = 5;
+var174 = string__NativeString__to_s_with_length(var172, var173);
+var171 = var174;
+varonce170 = var171;
+}
+var_175 = var171;
+{
+var176 = hash_collection__HashMap___91d_93d(var_169, var_175);
+}
+{
+var177 = hash_collection__HashMap___91d_93d(var_count_type_test_total, var_tag);
+}
+{
+{ /* Inline kernel#Int#+ (var176,var177) on <var176:nullable Object(Int)> */
+/* Covariant cast for argument 0 (i) <var177:nullable Object(Int)> isa OTHER */
+/* <var177:nullable Object(Int)> isa OTHER */
+var180 = 1; /* easy <var177:nullable Object(Int)> isa OTHER*/
+if (unlikely(!var180)) {
+var_class_name183 = var177 == NULL ? "null" : var177->type->name;
+PRINT_ERROR("Runtime error: Cast failed. Expected `%s`, got `%s`", "OTHER", var_class_name183);
+PRINT_ERROR(" (%s:%d)\n", "../lib/standard/kernel.nit", 374);
+show_backtrace(1);
+}
+var184 = ((struct instance_kernel__Int*)var176)->value; /* autounbox from nullable Object to Int */;
+var185 = ((struct instance_kernel__Int*)var177)->value; /* autounbox from nullable Object to Int */;
+var186 = var184 + var185;
+var178 = var186;
+goto RET_LABEL179;
+RET_LABEL179:(void)0;
+}
+}
+{
+var187 = BOX_kernel__Int(var178); /* autobox from Int to nullable Object */
+hash_collection__HashMap___91d_93d_61d(var_169, var_175, var187); /* Direct call hash_collection#HashMap#[]= on <var_169:HashMap[String, Int]>*/
+}
+{
+array__ArrayIterator__next(var_64); /* Direct call array#ArrayIterator#next on <var_64:ArrayIterator[String]>*/
 }
-var33 = ((short int (*)(val*, val*))(var27->class->vft[COLOR_kernel__Object___61d_61d]))(var27, var29) /* == on <var27:String>*/;
-if (var33){
-if (varonce34) {
-var35 = varonce34;
 } else {
-var36 = "char";
-var37 = 4;
-var38 = string__NativeString__to_s_with_length(var36, var37);
-var35 = var38;
-varonce34 = var35;
+goto BREAK_label;
 }
-var = var35;
-goto RET_LABEL;
-} else {
-var39 = ((val* (*)(val*))(self->class->vft[COLOR_model__MClassType__mclass]))(self) /* mclass on <self:MClassType>*/;
-var40 = ((val* (*)(val*))(var39->class->vft[COLOR_model__MClass__name]))(var39) /* name on <var39:MClass>*/;
-if (varonce41) {
-var42 = varonce41;
-} else {
-var43 = "Float";
-var44 = 5;
-var45 = string__NativeString__to_s_with_length(var43, var44);
-var42 = var45;
-varonce41 = var42;
-}
-var46 = ((short int (*)(val*, val*))(var40->class->vft[COLOR_kernel__Object___61d_61d]))(var40, var42) /* == on <var40:String>*/;
-if (var46){
-if (varonce47) {
-var48 = varonce47;
-} else {
-var49 = "double";
-var50 = 6;
-var51 = string__NativeString__to_s_with_length(var49, var50);
-var48 = var51;
-varonce47 = var48;
-}
-var = var48;
-goto RET_LABEL;
-} else {
-var52 = ((val* (*)(val*))(self->class->vft[COLOR_model__MClassType__mclass]))(self) /* mclass on <self:MClassType>*/;
-var53 = ((val* (*)(val*))(var52->class->vft[COLOR_model__MClass__name]))(var52) /* name on <var52:MClass>*/;
-if (varonce54) {
-var55 = varonce54;
-} else {
-var56 = "NativeString";
-var57 = 12;
-var58 = string__NativeString__to_s_with_length(var56, var57);
-var55 = var58;
-varonce54 = var55;
 }
-var59 = ((short int (*)(val*, val*))(var53->class->vft[COLOR_kernel__Object___61d_61d]))(var53, var55) /* == on <var53:String>*/;
-if (var59){
-if (varonce60) {
-var61 = varonce60;
-} else {
-var62 = "char*";
-var63 = 5;
-var64 = string__NativeString__to_s_with_length(var62, var63);
-var61 = var64;
-varonce60 = var61;
+BREAK_label: (void)0;
+{
+{ /* Inline abstract_collection#Iterator#finish (var_64) on <var_64:ArrayIterator[String]> */
+RET_LABEL188:(void)0;
 }
-var = var61;
-goto RET_LABEL;
-} else {
-var65 = ((val* (*)(val*))(self->class->vft[COLOR_model__MClassType__mclass]))(self) /* mclass on <self:MClassType>*/;
-var66 = ((val* (*)(val*))(var65->class->vft[COLOR_model__MClass__name]))(var65) /* name on <var65:MClass>*/;
-if (varonce67) {
-var68 = varonce67;
-} else {
-var69 = "NativeArray";
-var70 = 11;
-var71 = string__NativeString__to_s_with_length(var69, var70);
-var68 = var71;
-varonce67 = var68;
 }
-var72 = ((short int (*)(val*, val*))(var66->class->vft[COLOR_kernel__Object___61d_61d]))(var66, var68) /* == on <var66:String>*/;
-if (var72){
-if (varonce73) {
-var74 = varonce73;
+if (varonce189) {
+var190 = varonce189;
 } else {
-var75 = "val*";
-var76 = 4;
-var77 = string__NativeString__to_s_with_length(var75, var76);
-var74 = var77;
-varonce73 = var74;
+var191 = "total";
+var192 = 5;
+var193 = string__NativeString__to_s_with_length(var191, var192);
+var190 = var193;
+varonce189 = var190;
 }
-var = var74;
-goto RET_LABEL;
-} else {
-var78 = ((val* (*)(val*))(self->class->vft[COLOR_model__MClassType__mclass]))(self) /* mclass on <self:MClassType>*/;
-var79 = ((val* (*)(val*))(var78->class->vft[COLOR_model__MClass__kind]))(var78) /* kind on <var78:MClass>*/;
-var80 = ((val* (*)(val*))(self->class->vft[COLOR_model__Object__extern_kind]))(self) /* extern_kind on <self:MClassType>*/;
-var81 = ((short int (*)(val*, val*))(var79->class->vft[COLOR_kernel__Object___61d_61d]))(var79, var80) /* == on <var79:MClassKind>*/;
-if (var81){
-if (varonce82) {
-var83 = varonce82;
-} else {
-var84 = "void*";
-var85 = 5;
-var86 = string__NativeString__to_s_with_length(var84, var85);
-var83 = var86;
-varonce82 = var83;
-}
-var = var83;
-goto RET_LABEL;
-} else {
-if (varonce87) {
-var88 = varonce87;
-} else {
-var89 = "val*";
-var90 = 4;
-var91 = string__NativeString__to_s_with_length(var89, var90);
-var88 = var91;
-varonce87 = var88;
+{
+var194 = hash_collection__HashMap___91d_93d(var_count_type_test_total, var190);
 }
-var = var88;
-goto RET_LABEL;
+var195 = ((struct instance_kernel__Int*)var194)->value; /* autounbox from nullable Object to Int */;
+var_count_type_test = var195;
+{
+{ /* Inline abstract_compiler#AbstractCompiler#count_type_test_tags (self) on <self:AbstractCompiler> */
+var198 = self->attrs[COLOR_abstract_compiler__AbstractCompiler___count_type_test_tags].val; /* _count_type_test_tags on <self:AbstractCompiler> */
+if (unlikely(var198 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _count_type_test_tags");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 944);
+show_backtrace(1);
 }
+var196 = var198;
+RET_LABEL197:(void)0;
 }
 }
+{
+var199 = array__Collection__to_a(var196);
 }
+var_tags = var199;
+if (varonce200) {
+var201 = varonce200;
+} else {
+var202 = "total";
+var203 = 5;
+var204 = string__NativeString__to_s_with_length(var202, var203);
+var201 = var204;
+varonce200 = var201;
 }
+{
+array__Array__add(var_tags, var201); /* Direct call array#Array#add on <var_tags:Array[String]>*/
 }
+var_205 = var_tags;
+{
+var206 = array__AbstractArrayRead__iterator(var_205);
 }
-RET_LABEL:;
-return var;
+var_207 = var206;
+for(;;) {
+{
+var208 = array__ArrayIterator__is_ok(var_207);
+}
+if (var208){
+{
+var209 = array__ArrayIterator__item(var_207);
+}
+var_tag210 = var209;
+var211 = NEW_array__Array(&type_array__Arraykernel__Object);
+{ /* var211 = array_instance Array[Object] */
+var212 = 1;
+var213 = NEW_array__NativeArray(var212, &type_array__NativeArraykernel__Object);
+((struct instance_array__NativeArray*)var213)->values[0] = (val*) var_tag210;
+{
+((void (*)(val*, val*, long))(var211->class->vft[COLOR_array__Array__with_native]))(var211, var213, var212) /* with_native on <var211:Array[Object]>*/;
+}
+}
+{
+file__Object__printn(self, var211); /* Direct call file#Object#printn on <self:AbstractCompiler>*/
+}
+if (varonce214) {
+var215 = varonce214;
+} else {
+var216 = "\11";
+var217 = 1;
+var218 = string__NativeString__to_s_with_length(var216, var217);
+var215 = var218;
+varonce214 = var215;
+}
+{
+{ /* Inline abstract_compiler#AbstractCompiler#count_type_test_resolved (self) on <self:AbstractCompiler> */
+var221 = self->attrs[COLOR_abstract_compiler__AbstractCompiler___count_type_test_resolved].val; /* _count_type_test_resolved on <self:AbstractCompiler> */
+if (unlikely(var221 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _count_type_test_resolved");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 945);
+show_backtrace(1);
+}
+var219 = var221;
+RET_LABEL220:(void)0;
+}
+}
+{
+var222 = hash_collection__HashMap___91d_93d(var219, var_tag210);
+}
+if (varonce223) {
+var224 = varonce223;
+} else {
+var225 = " (";
+var226 = 2;
+var227 = string__NativeString__to_s_with_length(var225, var226);
+var224 = var227;
+varonce223 = var224;
+}
+{
+{ /* Inline abstract_compiler#AbstractCompiler#count_type_test_resolved (self) on <self:AbstractCompiler> */
+var230 = self->attrs[COLOR_abstract_compiler__AbstractCompiler___count_type_test_resolved].val; /* _count_type_test_resolved on <self:AbstractCompiler> */
+if (unlikely(var230 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _count_type_test_resolved");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 945);
+show_backtrace(1);
+}
+var228 = var230;
+RET_LABEL229:(void)0;
+}
+}
+{
+var231 = hash_collection__HashMap___91d_93d(var228, var_tag210);
+}
+{
+var233 = ((struct instance_kernel__Int*)var231)->value; /* autounbox from nullable Object to Int */;
+var232 = abstract_compiler__AbstractCompiler__div(self, var233, var_count_type_test);
+}
+if (varonce234) {
+var235 = varonce234;
+} else {
+var236 = "%)";
+var237 = 2;
+var238 = string__NativeString__to_s_with_length(var236, var237);
+var235 = var238;
+varonce234 = var235;
+}
+var239 = NEW_array__Array(&type_array__Arraykernel__Object);
+{ /* var239 = array_instance Array[Object] */
+var240 = 5;
+var241 = NEW_array__NativeArray(var240, &type_array__NativeArraykernel__Object);
+((struct instance_array__NativeArray*)var241)->values[0] = (val*) var215;
+((struct instance_array__NativeArray*)var241)->values[1] = (val*) var222;
+((struct instance_array__NativeArray*)var241)->values[2] = (val*) var224;
+((struct instance_array__NativeArray*)var241)->values[3] = (val*) var232;
+((struct instance_array__NativeArray*)var241)->values[4] = (val*) var235;
+{
+((void (*)(val*, val*, long))(var239->class->vft[COLOR_array__Array__with_native]))(var239, var241, var240) /* with_native on <var239:Array[Object]>*/;
+}
+}
+{
+var242 = ((val* (*)(val*))(var239->class->vft[COLOR_string__Object__to_s]))(var239) /* to_s on <var239:Array[Object]>*/;
+}
+var243 = NEW_array__Array(&type_array__Arraykernel__Object);
+{ /* var243 = array_instance Array[Object] */
+var244 = 1;
+var245 = NEW_array__NativeArray(var244, &type_array__NativeArraykernel__Object);
+((struct instance_array__NativeArray*)var245)->values[0] = (val*) var242;
+{
+((void (*)(val*, val*, long))(var243->class->vft[COLOR_array__Array__with_native]))(var243, var245, var244) /* with_native on <var243:Array[Object]>*/;
+}
+}
+{
+file__Object__printn(self, var243); /* Direct call file#Object#printn on <self:AbstractCompiler>*/
+}
+if (varonce246) {
+var247 = varonce246;
+} else {
+var248 = "\11";
+var249 = 1;
+var250 = string__NativeString__to_s_with_length(var248, var249);
+var247 = var250;
+varonce246 = var247;
+}
+{
+{ /* Inline abstract_compiler#AbstractCompiler#count_type_test_unresolved (self) on <self:AbstractCompiler> */
+var253 = self->attrs[COLOR_abstract_compiler__AbstractCompiler___count_type_test_unresolved].val; /* _count_type_test_unresolved on <self:AbstractCompiler> */
+if (unlikely(var253 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _count_type_test_unresolved");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 946);
+show_backtrace(1);
+}
+var251 = var253;
+RET_LABEL252:(void)0;
+}
+}
+{
+var254 = hash_collection__HashMap___91d_93d(var251, var_tag210);
+}
+if (varonce255) {
+var256 = varonce255;
+} else {
+var257 = " (";
+var258 = 2;
+var259 = string__NativeString__to_s_with_length(var257, var258);
+var256 = var259;
+varonce255 = var256;
+}
+{
+{ /* Inline abstract_compiler#AbstractCompiler#count_type_test_unresolved (self) on <self:AbstractCompiler> */
+var262 = self->attrs[COLOR_abstract_compiler__AbstractCompiler___count_type_test_unresolved].val; /* _count_type_test_unresolved on <self:AbstractCompiler> */
+if (unlikely(var262 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _count_type_test_unresolved");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 946);
+show_backtrace(1);
+}
+var260 = var262;
+RET_LABEL261:(void)0;
+}
+}
+{
+var263 = hash_collection__HashMap___91d_93d(var260, var_tag210);
+}
+{
+var265 = ((struct instance_kernel__Int*)var263)->value; /* autounbox from nullable Object to Int */;
+var264 = abstract_compiler__AbstractCompiler__div(self, var265, var_count_type_test);
+}
+if (varonce266) {
+var267 = varonce266;
+} else {
+var268 = "%)";
+var269 = 2;
+var270 = string__NativeString__to_s_with_length(var268, var269);
+var267 = var270;
+varonce266 = var267;
+}
+var271 = NEW_array__Array(&type_array__Arraykernel__Object);
+{ /* var271 = array_instance Array[Object] */
+var272 = 5;
+var273 = NEW_array__NativeArray(var272, &type_array__NativeArraykernel__Object);
+((struct instance_array__NativeArray*)var273)->values[0] = (val*) var247;
+((struct instance_array__NativeArray*)var273)->values[1] = (val*) var254;
+((struct instance_array__NativeArray*)var273)->values[2] = (val*) var256;
+((struct instance_array__NativeArray*)var273)->values[3] = (val*) var264;
+((struct instance_array__NativeArray*)var273)->values[4] = (val*) var267;
+{
+((void (*)(val*, val*, long))(var271->class->vft[COLOR_array__Array__with_native]))(var271, var273, var272) /* with_native on <var271:Array[Object]>*/;
+}
+}
+{
+var274 = ((val* (*)(val*))(var271->class->vft[COLOR_string__Object__to_s]))(var271) /* to_s on <var271:Array[Object]>*/;
+}
+var275 = NEW_array__Array(&type_array__Arraykernel__Object);
+{ /* var275 = array_instance Array[Object] */
+var276 = 1;
+var277 = NEW_array__NativeArray(var276, &type_array__NativeArraykernel__Object);
+((struct instance_array__NativeArray*)var277)->values[0] = (val*) var274;
+{
+((void (*)(val*, val*, long))(var275->class->vft[COLOR_array__Array__with_native]))(var275, var277, var276) /* with_native on <var275:Array[Object]>*/;
+}
+}
+{
+file__Object__printn(self, var275); /* Direct call file#Object#printn on <self:AbstractCompiler>*/
+}
+if (varonce278) {
+var279 = varonce278;
+} else {
+var280 = "\11";
+var281 = 1;
+var282 = string__NativeString__to_s_with_length(var280, var281);
+var279 = var282;
+varonce278 = var279;
+}
+{
+{ /* Inline abstract_compiler#AbstractCompiler#count_type_test_skipped (self) on <self:AbstractCompiler> */
+var285 = self->attrs[COLOR_abstract_compiler__AbstractCompiler___count_type_test_skipped].val; /* _count_type_test_skipped on <self:AbstractCompiler> */
+if (unlikely(var285 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _count_type_test_skipped");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 947);
+show_backtrace(1);
 }
-/* method abstract_compiler#MClassType#ctype for (self: Object): String */
-val* VIRTUAL_abstract_compiler__MClassType__ctype(val* self) {
-val* var /* : String */;
-val* var1 /* : String */;
-var1 = abstract_compiler__MClassType__ctype(self);
-var = var1;
-RET_LABEL:;
-return var;
+var283 = var285;
+RET_LABEL284:(void)0;
 }
-/* method abstract_compiler#MClassType#ctypename for (self: MClassType): String */
-val* abstract_compiler__MClassType__ctypename(val* self) {
-val* var /* : String */;
-val* var1 /* : MClass */;
-val* var2 /* : String */;
-static val* varonce;
-val* var3 /* : String */;
-char* var4 /* : NativeString */;
-long var5 /* : Int */;
-val* var6 /* : String */;
-short int var7 /* : Bool */;
-static val* varonce8;
-val* var9 /* : String */;
-char* var10 /* : NativeString */;
-long var11 /* : Int */;
-val* var12 /* : String */;
-val* var13 /* : MClass */;
-val* var14 /* : String */;
-static val* varonce15;
-val* var16 /* : String */;
-char* var17 /* : NativeString */;
-long var18 /* : Int */;
-val* var19 /* : String */;
-short int var20 /* : Bool */;
-static val* varonce21;
-val* var22 /* : String */;
-char* var23 /* : NativeString */;
-long var24 /* : Int */;
-val* var25 /* : String */;
-val* var26 /* : MClass */;
-val* var27 /* : String */;
-static val* varonce28;
-val* var29 /* : String */;
-char* var30 /* : NativeString */;
-long var31 /* : Int */;
-val* var32 /* : String */;
-short int var33 /* : Bool */;
-static val* varonce34;
-val* var35 /* : String */;
-char* var36 /* : NativeString */;
-long var37 /* : Int */;
-val* var38 /* : String */;
-val* var39 /* : MClass */;
-val* var40 /* : String */;
-static val* varonce41;
-val* var42 /* : String */;
-char* var43 /* : NativeString */;
-long var44 /* : Int */;
-val* var45 /* : String */;
-short int var46 /* : Bool */;
-static val* varonce47;
-val* var48 /* : String */;
-char* var49 /* : NativeString */;
-long var50 /* : Int */;
-val* var51 /* : String */;
-val* var52 /* : MClass */;
-val* var53 /* : String */;
-static val* varonce54;
-val* var55 /* : String */;
-char* var56 /* : NativeString */;
-long var57 /* : Int */;
-val* var58 /* : String */;
-short int var59 /* : Bool */;
-static val* varonce60;
-val* var61 /* : String */;
-char* var62 /* : NativeString */;
-long var63 /* : Int */;
-val* var64 /* : String */;
-val* var65 /* : MClass */;
-val* var66 /* : String */;
-static val* varonce67;
-val* var68 /* : String */;
-char* var69 /* : NativeString */;
-long var70 /* : Int */;
-val* var71 /* : String */;
-short int var72 /* : Bool */;
-static val* varonce73;
-val* var74 /* : String */;
-char* var75 /* : NativeString */;
-long var76 /* : Int */;
-val* var77 /* : String */;
-val* var78 /* : MClass */;
-val* var79 /* : MClassKind */;
-val* var80 /* : MClassKind */;
-short int var81 /* : Bool */;
-static val* varonce82;
-val* var83 /* : String */;
-char* var84 /* : NativeString */;
-long var85 /* : Int */;
-val* var86 /* : String */;
-static val* varonce87;
-val* var88 /* : String */;
-char* var89 /* : NativeString */;
-long var90 /* : Int */;
-val* var91 /* : String */;
-var1 = ((val* (*)(val*))(self->class->vft[COLOR_model__MClassType__mclass]))(self) /* mclass on <self:MClassType>*/;
-var2 = ((val* (*)(val*))(var1->class->vft[COLOR_model__MClass__name]))(var1) /* name on <var1:MClass>*/;
-if (varonce) {
-var3 = varonce;
-} else {
-var4 = "Int";
-var5 = 3;
-var6 = string__NativeString__to_s_with_length(var4, var5);
-var3 = var6;
-varonce = var3;
 }
-var7 = ((short int (*)(val*, val*))(var2->class->vft[COLOR_kernel__Object___61d_61d]))(var2, var3) /* == on <var2:String>*/;
-if (var7){
-if (varonce8) {
-var9 = varonce8;
-} else {
-var10 = "l";
-var11 = 1;
-var12 = string__NativeString__to_s_with_length(var10, var11);
-var9 = var12;
-varonce8 = var9;
+{
+var286 = hash_collection__HashMap___91d_93d(var283, var_tag210);
+}
+if (varonce287) {
+var288 = varonce287;
+} else {
+var289 = " (";
+var290 = 2;
+var291 = string__NativeString__to_s_with_length(var289, var290);
+var288 = var291;
+varonce287 = var288;
+}
+{
+{ /* Inline abstract_compiler#AbstractCompiler#count_type_test_skipped (self) on <self:AbstractCompiler> */
+var294 = self->attrs[COLOR_abstract_compiler__AbstractCompiler___count_type_test_skipped].val; /* _count_type_test_skipped on <self:AbstractCompiler> */
+if (unlikely(var294 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _count_type_test_skipped");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 947);
+show_backtrace(1);
+}
+var292 = var294;
+RET_LABEL293:(void)0;
+}
+}
+{
+var295 = hash_collection__HashMap___91d_93d(var292, var_tag210);
+}
+{
+var297 = ((struct instance_kernel__Int*)var295)->value; /* autounbox from nullable Object to Int */;
+var296 = abstract_compiler__AbstractCompiler__div(self, var297, var_count_type_test);
+}
+if (varonce298) {
+var299 = varonce298;
+} else {
+var300 = "%)";
+var301 = 2;
+var302 = string__NativeString__to_s_with_length(var300, var301);
+var299 = var302;
+varonce298 = var299;
+}
+var303 = NEW_array__Array(&type_array__Arraykernel__Object);
+{ /* var303 = array_instance Array[Object] */
+var304 = 5;
+var305 = NEW_array__NativeArray(var304, &type_array__NativeArraykernel__Object);
+((struct instance_array__NativeArray*)var305)->values[0] = (val*) var279;
+((struct instance_array__NativeArray*)var305)->values[1] = (val*) var286;
+((struct instance_array__NativeArray*)var305)->values[2] = (val*) var288;
+((struct instance_array__NativeArray*)var305)->values[3] = (val*) var296;
+((struct instance_array__NativeArray*)var305)->values[4] = (val*) var299;
+{
+((void (*)(val*, val*, long))(var303->class->vft[COLOR_array__Array__with_native]))(var303, var305, var304) /* with_native on <var303:Array[Object]>*/;
 }
-var = var9;
-goto RET_LABEL;
-} else {
-var13 = ((val* (*)(val*))(self->class->vft[COLOR_model__MClassType__mclass]))(self) /* mclass on <self:MClassType>*/;
-var14 = ((val* (*)(val*))(var13->class->vft[COLOR_model__MClass__name]))(var13) /* name on <var13:MClass>*/;
-if (varonce15) {
-var16 = varonce15;
-} else {
-var17 = "Bool";
-var18 = 4;
-var19 = string__NativeString__to_s_with_length(var17, var18);
-var16 = var19;
-varonce15 = var16;
 }
-var20 = ((short int (*)(val*, val*))(var14->class->vft[COLOR_kernel__Object___61d_61d]))(var14, var16) /* == on <var14:String>*/;
-if (var20){
-if (varonce21) {
-var22 = varonce21;
-} else {
-var23 = "s";
-var24 = 1;
-var25 = string__NativeString__to_s_with_length(var23, var24);
-var22 = var25;
-varonce21 = var22;
+{
+var306 = ((val* (*)(val*))(var303->class->vft[COLOR_string__Object__to_s]))(var303) /* to_s on <var303:Array[Object]>*/;
+}
+var307 = NEW_array__Array(&type_array__Arraykernel__Object);
+{ /* var307 = array_instance Array[Object] */
+var308 = 1;
+var309 = NEW_array__NativeArray(var308, &type_array__NativeArraykernel__Object);
+((struct instance_array__NativeArray*)var309)->values[0] = (val*) var306;
+{
+((void (*)(val*, val*, long))(var307->class->vft[COLOR_array__Array__with_native]))(var307, var309, var308) /* with_native on <var307:Array[Object]>*/;
 }
-var = var22;
-goto RET_LABEL;
-} else {
-var26 = ((val* (*)(val*))(self->class->vft[COLOR_model__MClassType__mclass]))(self) /* mclass on <self:MClassType>*/;
-var27 = ((val* (*)(val*))(var26->class->vft[COLOR_model__MClass__name]))(var26) /* name on <var26:MClass>*/;
-if (varonce28) {
-var29 = varonce28;
-} else {
-var30 = "Char";
-var31 = 4;
-var32 = string__NativeString__to_s_with_length(var30, var31);
-var29 = var32;
-varonce28 = var29;
 }
-var33 = ((short int (*)(val*, val*))(var27->class->vft[COLOR_kernel__Object___61d_61d]))(var27, var29) /* == on <var27:String>*/;
-if (var33){
-if (varonce34) {
-var35 = varonce34;
-} else {
-var36 = "c";
-var37 = 1;
-var38 = string__NativeString__to_s_with_length(var36, var37);
-var35 = var38;
-varonce34 = var35;
+{
+file__Object__printn(self, var307); /* Direct call file#Object#printn on <self:AbstractCompiler>*/
 }
-var = var35;
-goto RET_LABEL;
+if (varonce310) {
+var311 = varonce310;
 } else {
-var39 = ((val* (*)(val*))(self->class->vft[COLOR_model__MClassType__mclass]))(self) /* mclass on <self:MClassType>*/;
-var40 = ((val* (*)(val*))(var39->class->vft[COLOR_model__MClass__name]))(var39) /* name on <var39:MClass>*/;
-if (varonce41) {
-var42 = varonce41;
-} else {
-var43 = "Float";
-var44 = 5;
-var45 = string__NativeString__to_s_with_length(var43, var44);
-var42 = var45;
-varonce41 = var42;
-}
-var46 = ((short int (*)(val*, val*))(var40->class->vft[COLOR_kernel__Object___61d_61d]))(var40, var42) /* == on <var40:String>*/;
-if (var46){
-if (varonce47) {
-var48 = varonce47;
-} else {
-var49 = "d";
-var50 = 1;
-var51 = string__NativeString__to_s_with_length(var49, var50);
-var48 = var51;
-varonce47 = var48;
-}
-var = var48;
-goto RET_LABEL;
-} else {
-var52 = ((val* (*)(val*))(self->class->vft[COLOR_model__MClassType__mclass]))(self) /* mclass on <self:MClassType>*/;
-var53 = ((val* (*)(val*))(var52->class->vft[COLOR_model__MClass__name]))(var52) /* name on <var52:MClass>*/;
-if (varonce54) {
-var55 = varonce54;
-} else {
-var56 = "NativeString";
-var57 = 12;
-var58 = string__NativeString__to_s_with_length(var56, var57);
-var55 = var58;
-varonce54 = var55;
+var312 = "\11";
+var313 = 1;
+var314 = string__NativeString__to_s_with_length(var312, var313);
+var311 = var314;
+varonce310 = var311;
 }
-var59 = ((short int (*)(val*, val*))(var53->class->vft[COLOR_kernel__Object___61d_61d]))(var53, var55) /* == on <var53:String>*/;
-if (var59){
-if (varonce60) {
-var61 = varonce60;
-} else {
-var62 = "str";
-var63 = 3;
-var64 = string__NativeString__to_s_with_length(var62, var63);
-var61 = var64;
-varonce60 = var61;
+{
+var315 = hash_collection__HashMap___91d_93d(var_count_type_test_total, var_tag210);
 }
-var = var61;
-goto RET_LABEL;
-} else {
-var65 = ((val* (*)(val*))(self->class->vft[COLOR_model__MClassType__mclass]))(self) /* mclass on <self:MClassType>*/;
-var66 = ((val* (*)(val*))(var65->class->vft[COLOR_model__MClass__name]))(var65) /* name on <var65:MClass>*/;
-if (varonce67) {
-var68 = varonce67;
+if (varonce316) {
+var317 = varonce316;
 } else {
-var69 = "NativeArray";
-var70 = 11;
-var71 = string__NativeString__to_s_with_length(var69, var70);
-var68 = var71;
-varonce67 = var68;
+var318 = " (";
+var319 = 2;
+var320 = string__NativeString__to_s_with_length(var318, var319);
+var317 = var320;
+varonce316 = var317;
 }
-var72 = ((short int (*)(val*, val*))(var66->class->vft[COLOR_kernel__Object___61d_61d]))(var66, var68) /* == on <var66:String>*/;
-if (var72){
-if (varonce73) {
-var74 = varonce73;
-} else {
-var75 = "val";
-var76 = 3;
-var77 = string__NativeString__to_s_with_length(var75, var76);
-var74 = var77;
-varonce73 = var74;
+{
+var321 = hash_collection__HashMap___91d_93d(var_count_type_test_total, var_tag210);
 }
-var = var74;
-goto RET_LABEL;
-} else {
-var78 = ((val* (*)(val*))(self->class->vft[COLOR_model__MClassType__mclass]))(self) /* mclass on <self:MClassType>*/;
-var79 = ((val* (*)(val*))(var78->class->vft[COLOR_model__MClass__kind]))(var78) /* kind on <var78:MClass>*/;
-var80 = ((val* (*)(val*))(self->class->vft[COLOR_model__Object__extern_kind]))(self) /* extern_kind on <self:MClassType>*/;
-var81 = ((short int (*)(val*, val*))(var79->class->vft[COLOR_kernel__Object___61d_61d]))(var79, var80) /* == on <var79:MClassKind>*/;
-if (var81){
-if (varonce82) {
-var83 = varonce82;
-} else {
-var84 = "ptr";
-var85 = 3;
-var86 = string__NativeString__to_s_with_length(var84, var85);
-var83 = var86;
-varonce82 = var83;
-}
-var = var83;
-goto RET_LABEL;
-} else {
-if (varonce87) {
-var88 = varonce87;
+{
+var323 = ((struct instance_kernel__Int*)var321)->value; /* autounbox from nullable Object to Int */;
+var322 = abstract_compiler__AbstractCompiler__div(self, var323, var_count_type_test);
+}
+if (varonce324) {
+var325 = varonce324;
 } else {
-var89 = "val";
-var90 = 3;
-var91 = string__NativeString__to_s_with_length(var89, var90);
-var88 = var91;
-varonce87 = var88;
+var326 = "%)";
+var327 = 2;
+var328 = string__NativeString__to_s_with_length(var326, var327);
+var325 = var328;
+varonce324 = var325;
 }
-var = var88;
-goto RET_LABEL;
+var329 = NEW_array__Array(&type_array__Arraykernel__Object);
+{ /* var329 = array_instance Array[Object] */
+var330 = 5;
+var331 = NEW_array__NativeArray(var330, &type_array__NativeArraykernel__Object);
+((struct instance_array__NativeArray*)var331)->values[0] = (val*) var311;
+((struct instance_array__NativeArray*)var331)->values[1] = (val*) var315;
+((struct instance_array__NativeArray*)var331)->values[2] = (val*) var317;
+((struct instance_array__NativeArray*)var331)->values[3] = (val*) var322;
+((struct instance_array__NativeArray*)var331)->values[4] = (val*) var325;
+{
+((void (*)(val*, val*, long))(var329->class->vft[COLOR_array__Array__with_native]))(var329, var331, var330) /* with_native on <var329:Array[Object]>*/;
 }
 }
+{
+var332 = ((val* (*)(val*))(var329->class->vft[COLOR_string__Object__to_s]))(var329) /* to_s on <var329:Array[Object]>*/;
 }
+var333 = NEW_array__Array(&type_array__Arraykernel__Object);
+{ /* var333 = array_instance Array[Object] */
+var334 = 1;
+var335 = NEW_array__NativeArray(var334, &type_array__NativeArraykernel__Object);
+((struct instance_array__NativeArray*)var335)->values[0] = (val*) var332;
+{
+((void (*)(val*, val*, long))(var333->class->vft[COLOR_array__Array__with_native]))(var333, var335, var334) /* with_native on <var333:Array[Object]>*/;
 }
 }
+{
+file__Object__printn(self, var333); /* Direct call file#Object#printn on <self:AbstractCompiler>*/
 }
+if (varonce336) {
+var337 = varonce336;
+} else {
+var338 = "";
+var339 = 0;
+var340 = string__NativeString__to_s_with_length(var338, var339);
+var337 = var340;
+varonce336 = var337;
 }
-RET_LABEL:;
-return var;
+{
+file__Object__print(self, var337); /* Direct call file#Object#print on <self:AbstractCompiler>*/
 }
-/* method abstract_compiler#MClassType#ctypename for (self: Object): String */
-val* VIRTUAL_abstract_compiler__MClassType__ctypename(val* self) {
-val* var /* : String */;
-val* var1 /* : String */;
-var1 = abstract_compiler__MClassType__ctypename(self);
-var = var1;
-RET_LABEL:;
-return var;
+{
+array__ArrayIterator__next(var_207); /* Direct call array#ArrayIterator#next on <var_207:ArrayIterator[String]>*/
 }
-/* method abstract_compiler#MGenericType#c_name for (self: MGenericType): String */
-val* abstract_compiler__MGenericType__c_name(val* self) {
-val* var /* : String */;
-val* var1 /* : nullable String */;
-val* var_res /* var res: nullable String */;
-val* var2 /* : null */;
-short int var3 /* : Bool */;
-val* var4 /* : String */;
-val* var5 /* : Array[MType] */;
-val* var6 /* : Iterator[nullable Object] */;
-short int var7 /* : Bool */;
-val* var8 /* : nullable Object */;
-val* var_t /* var t: MType */;
-val* var9 /* : String */;
-val* var10 /* : String */;
-var1 = ((val* (*)(val*))(self->class->vft[COLOR_abstract_compiler__MType__c_name_cache]))(self) /* c_name_cache on <self:MGenericType>*/;
-var_res = var1;
-var2 = NULL;
-if (var_res == NULL) {
-var3 = 0; /* is null */
 } else {
-var3 = 1; /* arg is null and recv is not */
+goto BREAK_label341;
+}
+}
+BREAK_label341: (void)0;
+{
+{ /* Inline abstract_collection#Iterator#finish (var_207) on <var_207:ArrayIterator[String]> */
+RET_LABEL342:(void)0;
+}
 }
-if (var3){
-var = var_res;
-goto RET_LABEL;
 } else {
 }
-var4 = ((val* (*)(val*))(self->class->vft[COLOR_abstract_compiler__MGenericType__c_name]))(self) /* c_name on <self:MGenericType>*/;
-var_res = var4;
-var5 = ((val* (*)(val*))(self->class->vft[COLOR_model__MClassType__arguments]))(self) /* arguments on <self:MGenericType>*/;
-var6 = ((val* (*)(val*))(var5->class->vft[COLOR_abstract_collection__Collection__iterator]))(var5) /* iterator on <var5:Array[MType]>*/;
-for(;;) {
-var7 = ((short int (*)(val*))(var6->class->vft[COLOR_abstract_collection__Iterator__is_ok]))(var6) /* is_ok on <var6:Iterator[nullable Object]>*/;
-if(!var7) break;
-var8 = ((val* (*)(val*))(var6->class->vft[COLOR_abstract_collection__Iterator__item]))(var6) /* item on <var6:Iterator[nullable Object]>*/;
-var_t = var8;
-var9 = ((val* (*)(val*))(var_t->class->vft[COLOR_abstract_compiler__MType__c_name]))(var_t) /* c_name on <var_t:MType>*/;
-var10 = ((val* (*)(val*, val*))(var_res->class->vft[COLOR_string__String___43d]))(var_res, var9) /* + on <var_res:nullable String(String)>*/;
-var_res = var10;
-CONTINUE_label: (void)0;
-((void (*)(val*))(var6->class->vft[COLOR_abstract_collection__Iterator__next]))(var6) /* next on <var6:Iterator[nullable Object]>*/;
+RET_LABEL:;
 }
-BREAK_label: (void)0;
-((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__MType__c_name_cache_61d]))(self, var_res) /* c_name_cache= on <self:MGenericType>*/;
-var = var_res;
-goto RET_LABEL;
+/* method abstract_compiler#AbstractCompiler#display_stats for (self: Object) */
+void VIRTUAL_abstract_compiler__AbstractCompiler__display_stats(val* self) {
+abstract_compiler__AbstractCompiler__display_stats(self); /* Direct call abstract_compiler#AbstractCompiler#display_stats on <self:Object(AbstractCompiler)>*/
 RET_LABEL:;
-return var;
 }
-/* method abstract_compiler#MGenericType#c_name for (self: Object): String */
-val* VIRTUAL_abstract_compiler__MGenericType__c_name(val* self) {
-val* var /* : String */;
-val* var1 /* : String */;
-var1 = abstract_compiler__MGenericType__c_name(self);
-var = var1;
+/* method abstract_compiler#AbstractCompiler#finalize_ffi_for_module for (self: AbstractCompiler, MModule) */
+void abstract_compiler__AbstractCompiler__finalize_ffi_for_module(val* self, val* p0) {
+val* var_mmodule /* var mmodule: MModule */;
+val* var_c /* var c: AbstractCompiler */;
+var_mmodule = p0;
+{
+{ /* Inline abstract_compiler#MModule#finalize_ffi (var_mmodule,self) on <var_mmodule:MModule> */
+var_c = self;
+RET_LABEL1:(void)0;
+}
+}
+RET_LABEL:;
+}
+/* method abstract_compiler#AbstractCompiler#finalize_ffi_for_module for (self: Object, MModule) */
+void VIRTUAL_abstract_compiler__AbstractCompiler__finalize_ffi_for_module(val* self, val* p0) {
+abstract_compiler__AbstractCompiler__finalize_ffi_for_module(self, p0); /* Direct call abstract_compiler#AbstractCompiler#finalize_ffi_for_module on <self:Object(AbstractCompiler)>*/
 RET_LABEL:;
-return var;
 }
-/* method abstract_compiler#MParameterType#c_name for (self: MParameterType): String */
-val* abstract_compiler__MParameterType__c_name(val* self) {
+/* method abstract_compiler#AbstractCompiler#div for (self: AbstractCompiler, Int, Int): String */
+val* abstract_compiler__AbstractCompiler__div(val* self, long p0, long p1) {
 val* var /* : String */;
-val* var1 /* : nullable String */;
-val* var_res /* var res: nullable String */;
-val* var2 /* : null */;
+long var_a /* var a: Int */;
+long var_b /* var b: Int */;
+long var1 /* : Int */;
+short int var2 /* : Bool */;
 short int var3 /* : Bool */;
-val* var4 /* : Array[Object] */;
-long var5 /* : Int */;
-val* var_ /* var : Array[Object] */;
+short int var5 /* : Bool */;
 static val* varonce;
 val* var6 /* : String */;
 char* var7 /* : NativeString */;
 long var8 /* : Int */;
-val* var9 /* : String */;
-val* var10 /* : MClass */;
-val* var11 /* : String */;
-static val* varonce12;
-val* var13 /* : String */;
-char* var14 /* : NativeString */;
+val* var9 /* : FlatString */;
+long var10 /* : Int */;
+long var11 /* : Int */;
+short int var13 /* : Bool */;
+int cltype;
+int idtype;
+const char* var_class_name;
+long var14 /* : Int */;
 long var15 /* : Int */;
-val* var16 /* : String */;
-long var17 /* : Int */;
-val* var18 /* : nullable Object */;
-static val* varonce19;
-val* var20 /* : String */;
-char* var21 /* : NativeString */;
-long var22 /* : Int */;
-val* var23 /* : String */;
-val* var24 /* : String */;
-var1 = ((val* (*)(val*))(self->class->vft[COLOR_abstract_compiler__MType__c_name_cache]))(self) /* c_name_cache on <self:MParameterType>*/;
-var_res = var1;
-var2 = NULL;
-if (var_res == NULL) {
-var3 = 0; /* is null */
-} else {
-var3 = 1; /* arg is null and recv is not */
+short int var17 /* : Bool */;
+int cltype18;
+int idtype19;
+const char* var_class_name20;
+long var21 /* : Int */;
+double var22 /* : Float */;
+double var24 /* : Float */;
+double var25 /* : Float */;
+double var26 /* : Float */;
+short int var28 /* : Bool */;
+int cltype29;
+int idtype30;
+const char* var_class_name31;
+double var32 /* : Float */;
+long var33 /* : Int */;
+val* var34 /* : String */;
+var_a = p0;
+var_b = p1;
+var1 = 0;
+{
+{ /* Inline kernel#Int#== (var_b,var1) on <var_b:Int> */
+var5 = var_b == var1;
+var3 = var5;
+goto RET_LABEL4;
+RET_LABEL4:(void)0;
 }
-if (var3){
-var = var_res;
-goto RET_LABEL;
-} else {
+var2 = var3;
 }
-var4 = NEW_array__Array(&type_array__Arraykernel__Object);
-var5 = 5;
-((void (*)(val*, long))(var4->class->vft[COLOR_array__Array__with_capacity]))(var4, var5) /* with_capacity on <var4:Array[Object]>*/;
-CHECK_NEW_array__Array(var4);
-var_ = var4;
+if (var2){
 if (varonce) {
 var6 = varonce;
 } else {
-var7 = "";
-var8 = 0;
+var7 = "n/a";
+var8 = 3;
 var9 = string__NativeString__to_s_with_length(var7, var8);
 var6 = var9;
 varonce = var6;
 }
-((void (*)(val*, val*))(var_->class->vft[COLOR_abstract_collection__SimpleCollection__add]))(var_, var6) /* add on <var_:Array[Object]>*/;
-var10 = ((val* (*)(val*))(self->class->vft[COLOR_model__MParameterType__mclass]))(self) /* mclass on <self:MParameterType>*/;
-var11 = ((val* (*)(val*))(var10->class->vft[COLOR_abstract_compiler__MClass__c_name]))(var10) /* c_name on <var10:MClass>*/;
-((void (*)(val*, val*))(var_->class->vft[COLOR_abstract_collection__SimpleCollection__add]))(var_, var11) /* add on <var_:Array[Object]>*/;
-if (varonce12) {
-var13 = varonce12;
+var = var6;
+goto RET_LABEL;
 } else {
-var14 = "_FT";
-var15 = 3;
-var16 = string__NativeString__to_s_with_length(var14, var15);
-var13 = var16;
-varonce12 = var13;
 }
-((void (*)(val*, val*))(var_->class->vft[COLOR_abstract_collection__SimpleCollection__add]))(var_, var13) /* add on <var_:Array[Object]>*/;
-var17 = ((long (*)(val*))(self->class->vft[COLOR_model__MParameterType__rank]))(self) /* rank on <self:MParameterType>*/;
-var18 = BOX_kernel__Int(var17); /* autobox from Int to nullable Object */
-((void (*)(val*, val*))(var_->class->vft[COLOR_abstract_collection__SimpleCollection__add]))(var_, var18) /* add on <var_:Array[Object]>*/;
-if (varonce19) {
-var20 = varonce19;
-} else {
-var21 = "";
-var22 = 0;
-var23 = string__NativeString__to_s_with_length(var21, var22);
-var20 = var23;
-varonce19 = var20;
+var10 = 10000;
+{
+{ /* Inline kernel#Int#* (var_a,var10) on <var_a:Int> */
+/* Covariant cast for argument 0 (i) <var10:Int> isa OTHER */
+/* <var10:Int> isa OTHER */
+var13 = 1; /* easy <var10:Int> isa OTHER*/
+if (unlikely(!var13)) {
+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", 378);
+show_backtrace(1);
 }
-((void (*)(val*, val*))(var_->class->vft[COLOR_abstract_collection__SimpleCollection__add]))(var_, var20) /* add on <var_:Array[Object]>*/;
-var24 = ((val* (*)(val*))(var_->class->vft[COLOR_string__Object__to_s]))(var_) /* to_s on <var_:Array[Object]>*/;
-var_res = var24;
-((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__MType__c_name_cache_61d]))(self, var_res) /* c_name_cache= on <self:MParameterType>*/;
-var = var_res;
+var14 = var_a * var10;
+var11 = var14;
+goto RET_LABEL12;
+RET_LABEL12:(void)0;
+}
+}
+{
+{ /* Inline kernel#Int#/ (var11,var_b) on <var11:Int> */
+/* Covariant cast for argument 0 (i) <var_b:Int> isa OTHER */
+/* <var_b:Int> isa OTHER */
+var17 = 1; /* easy <var_b:Int> isa OTHER*/
+if (unlikely(!var17)) {
+var_class_name20 = type_kernel__Int.name;
+PRINT_ERROR("Runtime error: Cast failed. Expected `%s`, got `%s`", "OTHER", var_class_name20);
+PRINT_ERROR(" (%s:%d)\n", "../lib/standard/kernel.nit", 379);
+show_backtrace(1);
+}
+var21 = var11 / var_b;
+var15 = var21;
+goto RET_LABEL16;
+RET_LABEL16:(void)0;
+}
+}
+{
+{ /* Inline kernel#Int#to_f (var15) on <var15:Int> */
+var24 = (double)var15;
+var22 = var24;
+goto RET_LABEL23;
+RET_LABEL23:(void)0;
+}
+}
+var25 = 100.0;
+{
+{ /* Inline kernel#Float#/ (var22,var25) on <var22:Float> */
+/* Covariant cast for argument 0 (i) <var25:Float> isa OTHER */
+/* <var25:Float> isa OTHER */
+var28 = 1; /* easy <var25:Float> isa OTHER*/
+if (unlikely(!var28)) {
+var_class_name31 = type_kernel__Float.name;
+PRINT_ERROR("Runtime error: Cast failed. Expected `%s`, got `%s`", "OTHER", var_class_name31);
+PRINT_ERROR(" (%s:%d)\n", "../lib/standard/kernel.nit", 306);
+show_backtrace(1);
+}
+var32 = var22 / var25;
+var26 = var32;
+goto RET_LABEL27;
+RET_LABEL27:(void)0;
+}
+}
+var33 = 2;
+{
+var34 = string__Float__to_precision(var26, var33);
+}
+var = var34;
 goto RET_LABEL;
 RET_LABEL:;
 return var;
 }
-/* method abstract_compiler#MParameterType#c_name for (self: Object): String */
-val* VIRTUAL_abstract_compiler__MParameterType__c_name(val* self) {
+/* method abstract_compiler#AbstractCompiler#div for (self: Object, Int, Int): String */
+val* VIRTUAL_abstract_compiler__AbstractCompiler__div(val* self, long p0, long p1) {
 val* var /* : String */;
 val* var1 /* : String */;
-var1 = abstract_compiler__MParameterType__c_name(self);
+var1 = abstract_compiler__AbstractCompiler__div(self, p0, p1);
 var = var1;
 RET_LABEL:;
 return var;
 }
-/* method abstract_compiler#MVirtualType#c_name for (self: MVirtualType): String */
-val* abstract_compiler__MVirtualType__c_name(val* self) {
+/* method abstract_compiler#CodeFile#name for (self: CodeFile): String */
+val* abstract_compiler__CodeFile__name(val* self) {
 val* var /* : String */;
-val* var1 /* : nullable String */;
-val* var_res /* var res: nullable String */;
-val* var2 /* : null */;
-short int var3 /* : Bool */;
-val* var4 /* : Array[Object] */;
-long var5 /* : Int */;
-val* var_ /* var : Array[Object] */;
-static val* varonce;
-val* var6 /* : String */;
-char* var7 /* : NativeString */;
-long var8 /* : Int */;
-val* var9 /* : String */;
-val* var10 /* : MProperty */;
-val* var11 /* : MPropDef */;
-val* var12 /* : MClassDef */;
-val* var13 /* : MClass */;
-val* var14 /* : String */;
-static val* varonce15;
-val* var16 /* : String */;
-char* var17 /* : NativeString */;
-long var18 /* : Int */;
-val* var19 /* : String */;
-val* var20 /* : MProperty */;
-val* var21 /* : String */;
-static val* varonce22;
-val* var23 /* : String */;
-char* var24 /* : NativeString */;
-long var25 /* : Int */;
-val* var26 /* : String */;
-val* var27 /* : String */;
-var1 = ((val* (*)(val*))(self->class->vft[COLOR_abstract_compiler__MType__c_name_cache]))(self) /* c_name_cache on <self:MVirtualType>*/;
-var_res = var1;
-var2 = NULL;
-if (var_res == NULL) {
-var3 = 0; /* is null */
-} else {
-var3 = 1; /* arg is null and recv is not */
+val* var1 /* : String */;
+var1 = self->attrs[COLOR_abstract_compiler__CodeFile___name].val; /* _name on <self:CodeFile> */
+if (unlikely(var1 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _name");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 1011);
+show_backtrace(1);
 }
-if (var3){
-var = var_res;
-goto RET_LABEL;
-} else {
+var = var1;
+RET_LABEL:;
+return var;
 }
-var4 = NEW_array__Array(&type_array__Arraykernel__Object);
-var5 = 5;
-((void (*)(val*, long))(var4->class->vft[COLOR_array__Array__with_capacity]))(var4, var5) /* with_capacity on <var4:Array[Object]>*/;
-CHECK_NEW_array__Array(var4);
-var_ = var4;
-if (varonce) {
-var6 = varonce;
-} else {
-var7 = "";
-var8 = 0;
-var9 = string__NativeString__to_s_with_length(var7, var8);
-var6 = var9;
-varonce = var6;
+/* method abstract_compiler#CodeFile#name for (self: Object): String */
+val* VIRTUAL_abstract_compiler__CodeFile__name(val* self) {
+val* var /* : String */;
+val* var1 /* : String */;
+val* var3 /* : String */;
+{ /* Inline abstract_compiler#CodeFile#name (self) on <self:Object(CodeFile)> */
+var3 = self->attrs[COLOR_abstract_compiler__CodeFile___name].val; /* _name on <self:Object(CodeFile)> */
+if (unlikely(var3 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _name");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 1011);
+show_backtrace(1);
 }
-((void (*)(val*, val*))(var_->class->vft[COLOR_abstract_collection__SimpleCollection__add]))(var_, var6) /* add on <var_:Array[Object]>*/;
-var10 = ((val* (*)(val*))(self->class->vft[COLOR_model__MVirtualType__mproperty]))(self) /* mproperty on <self:MVirtualType>*/;
-var11 = ((val* (*)(val*))(var10->class->vft[COLOR_model__MProperty__intro]))(var10) /* intro on <var10:MProperty>*/;
-var12 = ((val* (*)(val*))(var11->class->vft[COLOR_model__MPropDef__mclassdef]))(var11) /* mclassdef on <var11:MPropDef>*/;
-var13 = ((val* (*)(val*))(var12->class->vft[COLOR_model__MClassDef__mclass]))(var12) /* mclass on <var12:MClassDef>*/;
-var14 = ((val* (*)(val*))(var13->class->vft[COLOR_abstract_compiler__MClass__c_name]))(var13) /* c_name on <var13:MClass>*/;
-((void (*)(val*, val*))(var_->class->vft[COLOR_abstract_collection__SimpleCollection__add]))(var_, var14) /* add on <var_:Array[Object]>*/;
-if (varonce15) {
-var16 = varonce15;
-} else {
-var17 = "_VT";
-var18 = 3;
-var19 = string__NativeString__to_s_with_length(var17, var18);
-var16 = var19;
-varonce15 = var16;
+var1 = var3;
+RET_LABEL2:(void)0;
 }
-((void (*)(val*, val*))(var_->class->vft[COLOR_abstract_collection__SimpleCollection__add]))(var_, var16) /* add on <var_:Array[Object]>*/;
-var20 = ((val* (*)(val*))(self->class->vft[COLOR_model__MVirtualType__mproperty]))(self) /* mproperty on <self:MVirtualType>*/;
-var21 = ((val* (*)(val*))(var20->class->vft[COLOR_model__MProperty__name]))(var20) /* name on <var20:MProperty>*/;
-((void (*)(val*, val*))(var_->class->vft[COLOR_abstract_collection__SimpleCollection__add]))(var_, var21) /* add on <var_:Array[Object]>*/;
-if (varonce22) {
-var23 = varonce22;
-} else {
-var24 = "";
-var25 = 0;
-var26 = string__NativeString__to_s_with_length(var24, var25);
-var23 = var26;
-varonce22 = var23;
-}
-((void (*)(val*, val*))(var_->class->vft[COLOR_abstract_collection__SimpleCollection__add]))(var_, var23) /* add on <var_:Array[Object]>*/;
-var27 = ((val* (*)(val*))(var_->class->vft[COLOR_string__Object__to_s]))(var_) /* to_s on <var_:Array[Object]>*/;
-var_res = var27;
-((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__MType__c_name_cache_61d]))(self, var_res) /* c_name_cache= on <self:MVirtualType>*/;
-var = var_res;
-goto RET_LABEL;
+var = var1;
 RET_LABEL:;
 return var;
 }
-/* method abstract_compiler#MVirtualType#c_name for (self: Object): String */
-val* VIRTUAL_abstract_compiler__MVirtualType__c_name(val* self) {
-val* var /* : String */;
-val* var1 /* : String */;
-var1 = abstract_compiler__MVirtualType__c_name(self);
+/* method abstract_compiler#CodeFile#name= for (self: CodeFile, String) */
+void abstract_compiler__CodeFile__name_61d(val* self, val* p0) {
+self->attrs[COLOR_abstract_compiler__CodeFile___name].val = p0; /* _name on <self:CodeFile> */
+RET_LABEL:;
+}
+/* method abstract_compiler#CodeFile#name= for (self: Object, String) */
+void VIRTUAL_abstract_compiler__CodeFile__name_61d(val* self, val* p0) {
+{ /* Inline abstract_compiler#CodeFile#name= (self,p0) on <self:Object(CodeFile)> */
+self->attrs[COLOR_abstract_compiler__CodeFile___name].val = p0; /* _name on <self:Object(CodeFile)> */
+RET_LABEL1:(void)0;
+}
+RET_LABEL:;
+}
+/* method abstract_compiler#CodeFile#writers for (self: CodeFile): Array[CodeWriter] */
+val* abstract_compiler__CodeFile__writers(val* self) {
+val* var /* : Array[CodeWriter] */;
+val* var1 /* : Array[CodeWriter] */;
+var1 = self->attrs[COLOR_abstract_compiler__CodeFile___writers].val; /* _writers on <self:CodeFile> */
+if (unlikely(var1 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _writers");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 1012);
+show_backtrace(1);
+}
 var = var1;
 RET_LABEL:;
 return var;
 }
-/* method abstract_compiler#MNullableType#c_name for (self: MNullableType): String */
-val* abstract_compiler__MNullableType__c_name(val* self) {
-val* var /* : String */;
-val* var1 /* : nullable String */;
-val* var_res /* var res: nullable String */;
-val* var2 /* : null */;
-short int var3 /* : Bool */;
-val* var4 /* : Array[Object] */;
-long var5 /* : Int */;
-val* var_ /* var : Array[Object] */;
-static val* varonce;
-val* var6 /* : String */;
-char* var7 /* : NativeString */;
-long var8 /* : Int */;
-val* var9 /* : String */;
-val* var10 /* : MType */;
-val* var11 /* : String */;
-static val* varonce12;
-val* var13 /* : String */;
-char* var14 /* : NativeString */;
-long var15 /* : Int */;
-val* var16 /* : String */;
-val* var17 /* : String */;
-var1 = ((val* (*)(val*))(self->class->vft[COLOR_abstract_compiler__MType__c_name_cache]))(self) /* c_name_cache on <self:MNullableType>*/;
-var_res = var1;
-var2 = NULL;
-if (var_res == NULL) {
-var3 = 0; /* is null */
-} else {
-var3 = 1; /* arg is null and recv is not */
+/* method abstract_compiler#CodeFile#writers for (self: Object): Array[CodeWriter] */
+val* VIRTUAL_abstract_compiler__CodeFile__writers(val* self) {
+val* var /* : Array[CodeWriter] */;
+val* var1 /* : Array[CodeWriter] */;
+val* var3 /* : Array[CodeWriter] */;
+{ /* Inline abstract_compiler#CodeFile#writers (self) on <self:Object(CodeFile)> */
+var3 = self->attrs[COLOR_abstract_compiler__CodeFile___writers].val; /* _writers on <self:Object(CodeFile)> */
+if (unlikely(var3 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _writers");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 1012);
+show_backtrace(1);
+}
+var1 = var3;
+RET_LABEL2:(void)0;
 }
-if (var3){
-var = var_res;
-goto RET_LABEL;
-} else {
+var = var1;
+RET_LABEL:;
+return var;
 }
-var4 = NEW_array__Array(&type_array__Arraykernel__Object);
-var5 = 3;
-((void (*)(val*, long))(var4->class->vft[COLOR_array__Array__with_capacity]))(var4, var5) /* with_capacity on <var4:Array[Object]>*/;
-CHECK_NEW_array__Array(var4);
-var_ = var4;
-if (varonce) {
-var6 = varonce;
-} else {
-var7 = "nullable_";
-var8 = 9;
-var9 = string__NativeString__to_s_with_length(var7, var8);
-var6 = var9;
-varonce = var6;
+/* method abstract_compiler#CodeFile#required_declarations for (self: CodeFile): HashSet[String] */
+val* abstract_compiler__CodeFile__required_declarations(val* self) {
+val* var /* : HashSet[String] */;
+val* var1 /* : HashSet[String] */;
+var1 = self->attrs[COLOR_abstract_compiler__CodeFile___required_declarations].val; /* _required_declarations on <self:CodeFile> */
+if (unlikely(var1 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _required_declarations");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 1013);
+show_backtrace(1);
 }
-((void (*)(val*, val*))(var_->class->vft[COLOR_abstract_collection__SimpleCollection__add]))(var_, var6) /* add on <var_:Array[Object]>*/;
-var10 = ((val* (*)(val*))(self->class->vft[COLOR_model__MNullableType__mtype]))(self) /* mtype on <self:MNullableType>*/;
-var11 = ((val* (*)(val*))(var10->class->vft[COLOR_abstract_compiler__MType__c_name]))(var10) /* c_name on <var10:MType>*/;
-((void (*)(val*, val*))(var_->class->vft[COLOR_abstract_collection__SimpleCollection__add]))(var_, var11) /* add on <var_:Array[Object]>*/;
-if (varonce12) {
-var13 = varonce12;
-} else {
-var14 = "";
-var15 = 0;
-var16 = string__NativeString__to_s_with_length(var14, var15);
-var13 = var16;
-varonce12 = var13;
+var = var1;
+RET_LABEL:;
+return var;
 }
-((void (*)(val*, val*))(var_->class->vft[COLOR_abstract_collection__SimpleCollection__add]))(var_, var13) /* add on <var_:Array[Object]>*/;
-var17 = ((val* (*)(val*))(var_->class->vft[COLOR_string__Object__to_s]))(var_) /* to_s on <var_:Array[Object]>*/;
-var_res = var17;
-((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__MType__c_name_cache_61d]))(self, var_res) /* c_name_cache= on <self:MNullableType>*/;
-var = var_res;
-goto RET_LABEL;
+/* method abstract_compiler#CodeFile#required_declarations for (self: Object): HashSet[String] */
+val* VIRTUAL_abstract_compiler__CodeFile__required_declarations(val* self) {
+val* var /* : HashSet[String] */;
+val* var1 /* : HashSet[String] */;
+val* var3 /* : HashSet[String] */;
+{ /* Inline abstract_compiler#CodeFile#required_declarations (self) on <self:Object(CodeFile)> */
+var3 = self->attrs[COLOR_abstract_compiler__CodeFile___required_declarations].val; /* _required_declarations on <self:Object(CodeFile)> */
+if (unlikely(var3 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _required_declarations");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 1013);
+show_backtrace(1);
+}
+var1 = var3;
+RET_LABEL2:(void)0;
+}
+var = var1;
 RET_LABEL:;
 return var;
 }
-/* method abstract_compiler#MNullableType#c_name for (self: Object): String */
-val* VIRTUAL_abstract_compiler__MNullableType__c_name(val* self) {
-val* var /* : String */;
-val* var1 /* : String */;
-var1 = abstract_compiler__MNullableType__c_name(self);
+/* method abstract_compiler#CodeFile#init for (self: CodeFile) */
+void abstract_compiler__CodeFile__init(val* self) {
+{
+((void (*)(val*))(self->class->vft[COLOR_abstract_compiler__CodeFile__init]))(self) /* init on <self:CodeFile>*/;
+}
+RET_LABEL:;
+}
+/* method abstract_compiler#CodeFile#init for (self: Object) */
+void VIRTUAL_abstract_compiler__CodeFile__init(val* self) {
+{ /* Inline abstract_compiler#CodeFile#init (self) on <self:Object(CodeFile)> */
+{
+((void (*)(val*))(self->class->vft[COLOR_abstract_compiler__CodeFile__init]))(self) /* init on <self:Object(CodeFile)>*/;
+}
+RET_LABEL1:(void)0;
+}
+RET_LABEL:;
+}
+/* method abstract_compiler#CodeWriter#file for (self: CodeWriter): CodeFile */
+val* abstract_compiler__CodeWriter__file(val* self) {
+val* var /* : CodeFile */;
+val* var1 /* : CodeFile */;
+var1 = self->attrs[COLOR_abstract_compiler__CodeWriter___file].val; /* _file on <self:CodeWriter> */
+if (unlikely(var1 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _file");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 1018);
+show_backtrace(1);
+}
 var = var1;
 RET_LABEL:;
 return var;
 }
-/* method abstract_compiler#MClass#c_name for (self: MClass): String */
-val* abstract_compiler__MClass__c_name(val* self) {
-val* var /* : String */;
-val* var1 /* : nullable String */;
-val* var_res /* var res: nullable String */;
-val* var2 /* : null */;
-short int var3 /* : Bool */;
-val* var4 /* : Array[Object] */;
-long var5 /* : Int */;
-val* var_ /* var : Array[Object] */;
-static val* varonce;
-val* var6 /* : String */;
-char* var7 /* : NativeString */;
-long var8 /* : Int */;
-val* var9 /* : String */;
-val* var10 /* : MModule */;
-val* var11 /* : String */;
-val* var12 /* : String */;
-static val* varonce13;
-val* var14 /* : String */;
-char* var15 /* : NativeString */;
-long var16 /* : Int */;
-val* var17 /* : String */;
-val* var18 /* : String */;
-val* var19 /* : String */;
-static val* varonce20;
-val* var21 /* : String */;
-char* var22 /* : NativeString */;
-long var23 /* : Int */;
-val* var24 /* : String */;
-val* var25 /* : String */;
-var1 = ((val* (*)(val*))(self->class->vft[COLOR_abstract_compiler__MClass__c_name_cache]))(self) /* c_name_cache on <self:MClass>*/;
-var_res = var1;
-var2 = NULL;
-if (var_res == NULL) {
-var3 = 0; /* is null */
-} else {
-var3 = 1; /* arg is null and recv is not */
+/* method abstract_compiler#CodeWriter#file for (self: Object): CodeFile */
+val* VIRTUAL_abstract_compiler__CodeWriter__file(val* self) {
+val* var /* : CodeFile */;
+val* var1 /* : CodeFile */;
+val* var3 /* : CodeFile */;
+{ /* Inline abstract_compiler#CodeWriter#file (self) on <self:Object(CodeWriter)> */
+var3 = self->attrs[COLOR_abstract_compiler__CodeWriter___file].val; /* _file on <self:Object(CodeWriter)> */
+if (unlikely(var3 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _file");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 1018);
+show_backtrace(1);
+}
+var1 = var3;
+RET_LABEL2:(void)0;
 }
-if (var3){
-var = var_res;
-goto RET_LABEL;
-} else {
+var = var1;
+RET_LABEL:;
+return var;
 }
-var4 = NEW_array__Array(&type_array__Arraykernel__Object);
-var5 = 5;
-((void (*)(val*, long))(var4->class->vft[COLOR_array__Array__with_capacity]))(var4, var5) /* with_capacity on <var4:Array[Object]>*/;
-CHECK_NEW_array__Array(var4);
-var_ = var4;
-if (varonce) {
-var6 = varonce;
-} else {
-var7 = "";
-var8 = 0;
-var9 = string__NativeString__to_s_with_length(var7, var8);
-var6 = var9;
-varonce = var6;
+/* method abstract_compiler#CodeWriter#file= for (self: CodeWriter, CodeFile) */
+void abstract_compiler__CodeWriter__file_61d(val* self, val* p0) {
+self->attrs[COLOR_abstract_compiler__CodeWriter___file].val = p0; /* _file on <self:CodeWriter> */
+RET_LABEL:;
 }
-((void (*)(val*, val*))(var_->class->vft[COLOR_abstract_collection__SimpleCollection__add]))(var_, var6) /* add on <var_:Array[Object]>*/;
-var10 = ((val* (*)(val*))(self->class->vft[COLOR_model__MClass__intro_mmodule]))(self) /* intro_mmodule on <self:MClass>*/;
-var11 = ((val* (*)(val*))(var10->class->vft[COLOR_model_base__MModule__name]))(var10) /* name on <var10:MModule>*/;
-var12 = ((val* (*)(val*))(var11->class->vft[COLOR_string__AbstractString__to_cmangle]))(var11) /* to_cmangle on <var11:String>*/;
-((void (*)(val*, val*))(var_->class->vft[COLOR_abstract_collection__SimpleCollection__add]))(var_, var12) /* add on <var_:Array[Object]>*/;
-if (varonce13) {
-var14 = varonce13;
-} else {
-var15 = "__";
-var16 = 2;
-var17 = string__NativeString__to_s_with_length(var15, var16);
-var14 = var17;
-varonce13 = var14;
+/* method abstract_compiler#CodeWriter#file= for (self: Object, CodeFile) */
+void VIRTUAL_abstract_compiler__CodeWriter__file_61d(val* self, val* p0) {
+{ /* Inline abstract_compiler#CodeWriter#file= (self,p0) on <self:Object(CodeWriter)> */
+self->attrs[COLOR_abstract_compiler__CodeWriter___file].val = p0; /* _file on <self:Object(CodeWriter)> */
+RET_LABEL1:(void)0;
 }
-((void (*)(val*, val*))(var_->class->vft[COLOR_abstract_collection__SimpleCollection__add]))(var_, var14) /* add on <var_:Array[Object]>*/;
-var18 = ((val* (*)(val*))(self->class->vft[COLOR_model__MClass__name]))(self) /* name on <self:MClass>*/;
-var19 = ((val* (*)(val*))(var18->class->vft[COLOR_string__AbstractString__to_cmangle]))(var18) /* to_cmangle on <var18:String>*/;
-((void (*)(val*, val*))(var_->class->vft[COLOR_abstract_collection__SimpleCollection__add]))(var_, var19) /* add on <var_:Array[Object]>*/;
-if (varonce20) {
-var21 = varonce20;
-} else {
-var22 = "";
-var23 = 0;
-var24 = string__NativeString__to_s_with_length(var22, var23);
-var21 = var24;
-varonce20 = var21;
-}
-((void (*)(val*, val*))(var_->class->vft[COLOR_abstract_collection__SimpleCollection__add]))(var_, var21) /* add on <var_:Array[Object]>*/;
-var25 = ((val* (*)(val*))(var_->class->vft[COLOR_string__Object__to_s]))(var_) /* to_s on <var_:Array[Object]>*/;
-var_res = var25;
-((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__MClass__c_name_cache_61d]))(self, var_res) /* c_name_cache= on <self:MClass>*/;
-var = var_res;
-goto RET_LABEL;
+RET_LABEL:;
+}
+/* method abstract_compiler#CodeWriter#lines for (self: CodeWriter): List[String] */
+val* abstract_compiler__CodeWriter__lines(val* self) {
+val* var /* : List[String] */;
+val* var1 /* : List[String] */;
+var1 = self->attrs[COLOR_abstract_compiler__CodeWriter___lines].val; /* _lines on <self:CodeWriter> */
+if (unlikely(var1 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _lines");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 1019);
+show_backtrace(1);
+}
+var = var1;
 RET_LABEL:;
 return var;
 }
-/* method abstract_compiler#MClass#c_name for (self: Object): String */
-val* VIRTUAL_abstract_compiler__MClass__c_name(val* self) {
-val* var /* : String */;
-val* var1 /* : String */;
-var1 = abstract_compiler__MClass__c_name(self);
+/* method abstract_compiler#CodeWriter#lines for (self: Object): List[String] */
+val* VIRTUAL_abstract_compiler__CodeWriter__lines(val* self) {
+val* var /* : List[String] */;
+val* var1 /* : List[String] */;
+val* var3 /* : List[String] */;
+{ /* Inline abstract_compiler#CodeWriter#lines (self) on <self:Object(CodeWriter)> */
+var3 = self->attrs[COLOR_abstract_compiler__CodeWriter___lines].val; /* _lines on <self:Object(CodeWriter)> */
+if (unlikely(var3 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _lines");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 1019);
+show_backtrace(1);
+}
+var1 = var3;
+RET_LABEL2:(void)0;
+}
 var = var1;
 RET_LABEL:;
 return var;
 }
-/* method abstract_compiler#MClass#c_name_cache for (self: MClass): nullable String */
-val* abstract_compiler__MClass__c_name_cache(val* self) {
-val* var /* : nullable String */;
-val* var1 /* : nullable String */;
-var1 = self->attrs[COLOR_abstract_compiler__MClass___64dc_name_cache].val; /* @c_name_cache on <self:MClass> */
+/* method abstract_compiler#CodeWriter#decl_lines for (self: CodeWriter): List[String] */
+val* abstract_compiler__CodeWriter__decl_lines(val* self) {
+val* var /* : List[String] */;
+val* var1 /* : List[String] */;
+var1 = self->attrs[COLOR_abstract_compiler__CodeWriter___decl_lines].val; /* _decl_lines on <self:CodeWriter> */
+if (unlikely(var1 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _decl_lines");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 1020);
+show_backtrace(1);
+}
 var = var1;
 RET_LABEL:;
 return var;
 }
-/* method abstract_compiler#MClass#c_name_cache for (self: Object): nullable String */
-val* VIRTUAL_abstract_compiler__MClass__c_name_cache(val* self) {
-val* var /* : nullable String */;
-val* var1 /* : nullable String */;
-var1 = abstract_compiler__MClass__c_name_cache(self);
+/* method abstract_compiler#CodeWriter#decl_lines for (self: Object): List[String] */
+val* VIRTUAL_abstract_compiler__CodeWriter__decl_lines(val* self) {
+val* var /* : List[String] */;
+val* var1 /* : List[String] */;
+val* var3 /* : List[String] */;
+{ /* Inline abstract_compiler#CodeWriter#decl_lines (self) on <self:Object(CodeWriter)> */
+var3 = self->attrs[COLOR_abstract_compiler__CodeWriter___decl_lines].val; /* _decl_lines on <self:Object(CodeWriter)> */
+if (unlikely(var3 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _decl_lines");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 1020);
+show_backtrace(1);
+}
+var1 = var3;
+RET_LABEL2:(void)0;
+}
 var = var1;
 RET_LABEL:;
 return var;
 }
-/* method abstract_compiler#MClass#c_name_cache= for (self: MClass, nullable String) */
-void abstract_compiler__MClass__c_name_cache_61d(val* self, val* p0) {
-self->attrs[COLOR_abstract_compiler__MClass___64dc_name_cache].val = p0; /* @c_name_cache on <self:MClass> */
+/* method abstract_compiler#CodeWriter#add_decl for (self: CodeWriter, String) */
+void abstract_compiler__CodeWriter__add_decl(val* self, val* p0) {
+val* var_s /* var s: String */;
+val* var /* : List[String] */;
+val* var2 /* : List[String] */;
+var_s = p0;
+{
+{ /* Inline abstract_compiler#CodeWriter#decl_lines (self) on <self:CodeWriter> */
+var2 = self->attrs[COLOR_abstract_compiler__CodeWriter___decl_lines].val; /* _decl_lines on <self:CodeWriter> */
+if (unlikely(var2 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _decl_lines");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 1020);
+show_backtrace(1);
+}
+var = var2;
+RET_LABEL1:(void)0;
+}
+}
+{
+abstract_collection__Sequence__add(var, var_s); /* Direct call abstract_collection#Sequence#add on <var:List[String]>*/
+}
 RET_LABEL:;
 }
-/* method abstract_compiler#MClass#c_name_cache= for (self: Object, nullable String) */
-void VIRTUAL_abstract_compiler__MClass__c_name_cache_61d(val* self, val* p0) {
-abstract_compiler__MClass__c_name_cache_61d(self, p0);
+/* method abstract_compiler#CodeWriter#add_decl for (self: Object, String) */
+void VIRTUAL_abstract_compiler__CodeWriter__add_decl(val* self, val* p0) {
+abstract_compiler__CodeWriter__add_decl(self, p0); /* Direct call abstract_compiler#CodeWriter#add_decl on <self:Object(CodeWriter)>*/
 RET_LABEL:;
 }
-/* method abstract_compiler#MProperty#c_name for (self: MProperty): String */
-val* abstract_compiler__MProperty__c_name(val* self) {
-val* var /* : String */;
-val* var1 /* : nullable String */;
-val* var_res /* var res: nullable String */;
-val* var2 /* : null */;
-short int var3 /* : Bool */;
-val* var4 /* : Array[Object] */;
-long var5 /* : Int */;
-val* var_ /* var : Array[Object] */;
-static val* varonce;
-val* var6 /* : String */;
-char* var7 /* : NativeString */;
-long var8 /* : Int */;
-val* var9 /* : String */;
-val* var10 /* : MPropDef */;
-val* var11 /* : String */;
-static val* varonce12;
-val* var13 /* : String */;
-char* var14 /* : NativeString */;
-long var15 /* : Int */;
-val* var16 /* : String */;
-val* var17 /* : String */;
-var1 = ((val* (*)(val*))(self->class->vft[COLOR_abstract_compiler__MProperty__c_name_cache]))(self) /* c_name_cache on <self:MProperty>*/;
-var_res = var1;
-var2 = NULL;
-if (var_res == NULL) {
-var3 = 0; /* is null */
-} else {
-var3 = 1; /* arg is null and recv is not */
+/* method abstract_compiler#CodeWriter#init for (self: CodeWriter, CodeFile) */
+void abstract_compiler__CodeWriter__init(val* self, val* p0) {
+val* var_file /* var file: CodeFile */;
+val* var /* : Array[CodeWriter] */;
+val* var3 /* : Array[CodeWriter] */;
+var_file = p0;
+{
+{ /* Inline abstract_compiler#CodeWriter#file= (self,var_file) on <self:CodeWriter> */
+self->attrs[COLOR_abstract_compiler__CodeWriter___file].val = var_file; /* _file on <self:CodeWriter> */
+RET_LABEL1:(void)0;
 }
-if (var3){
-var = var_res;
-goto RET_LABEL;
-} else {
 }
-var4 = NEW_array__Array(&type_array__Arraykernel__Object);
-var5 = 3;
-((void (*)(val*, long))(var4->class->vft[COLOR_array__Array__with_capacity]))(var4, var5) /* with_capacity on <var4:Array[Object]>*/;
-CHECK_NEW_array__Array(var4);
-var_ = var4;
-if (varonce) {
-var6 = varonce;
-} else {
-var7 = "";
-var8 = 0;
-var9 = string__NativeString__to_s_with_length(var7, var8);
-var6 = var9;
-varonce = var6;
+{
+{ /* Inline abstract_compiler#CodeFile#writers (var_file) on <var_file:CodeFile> */
+var3 = var_file->attrs[COLOR_abstract_compiler__CodeFile___writers].val; /* _writers on <var_file:CodeFile> */
+if (unlikely(var3 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _writers");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 1012);
+show_backtrace(1);
 }
-((void (*)(val*, val*))(var_->class->vft[COLOR_abstract_collection__SimpleCollection__add]))(var_, var6) /* add on <var_:Array[Object]>*/;
-var10 = ((val* (*)(val*))(self->class->vft[COLOR_model__MProperty__intro]))(self) /* intro on <self:MProperty>*/;
-var11 = ((val* (*)(val*))(var10->class->vft[COLOR_abstract_compiler__MPropDef__c_name]))(var10) /* c_name on <var10:MPropDef>*/;
-((void (*)(val*, val*))(var_->class->vft[COLOR_abstract_collection__SimpleCollection__add]))(var_, var11) /* add on <var_:Array[Object]>*/;
-if (varonce12) {
-var13 = varonce12;
-} else {
-var14 = "";
-var15 = 0;
-var16 = string__NativeString__to_s_with_length(var14, var15);
-var13 = var16;
-varonce12 = var13;
+var = var3;
+RET_LABEL2:(void)0;
 }
-((void (*)(val*, val*))(var_->class->vft[COLOR_abstract_collection__SimpleCollection__add]))(var_, var13) /* add on <var_:Array[Object]>*/;
-var17 = ((val* (*)(val*))(var_->class->vft[COLOR_string__Object__to_s]))(var_) /* to_s on <var_:Array[Object]>*/;
-var_res = var17;
-((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__MProperty__c_name_cache_61d]))(self, var_res) /* c_name_cache= on <self:MProperty>*/;
-var = var_res;
-goto RET_LABEL;
+}
+{
+array__Array__add(var, self); /* Direct call array#Array#add on <var:Array[CodeWriter]>*/
+}
+RET_LABEL:;
+}
+/* method abstract_compiler#CodeWriter#init for (self: Object, CodeFile) */
+void VIRTUAL_abstract_compiler__CodeWriter__init(val* self, val* p0) {
+abstract_compiler__CodeWriter__init(self, p0); /* Direct call abstract_compiler#CodeWriter#init on <self:Object(CodeWriter)>*/
+RET_LABEL:;
+}
+/* method abstract_compiler#AbstractCompilerVisitor#compiler for (self: AbstractCompilerVisitor): AbstractCompiler */
+val* abstract_compiler__AbstractCompilerVisitor__compiler(val* self) {
+val* var /* : AbstractCompiler */;
+val* var1 /* : AbstractCompiler */;
+var1 = self->attrs[COLOR_abstract_compiler__AbstractCompilerVisitor___compiler].val; /* _compiler on <self:AbstractCompilerVisitor> */
+if (unlikely(var1 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _compiler");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 1041);
+show_backtrace(1);
+}
+var = var1;
 RET_LABEL:;
 return var;
 }
-/* method abstract_compiler#MProperty#c_name for (self: Object): String */
-val* VIRTUAL_abstract_compiler__MProperty__c_name(val* self) {
-val* var /* : String */;
-val* var1 /* : String */;
-var1 = abstract_compiler__MProperty__c_name(self);
+/* method abstract_compiler#AbstractCompilerVisitor#compiler for (self: Object): AbstractCompiler */
+val* VIRTUAL_abstract_compiler__AbstractCompilerVisitor__compiler(val* self) {
+val* var /* : AbstractCompiler */;
+val* var1 /* : AbstractCompiler */;
+val* var3 /* : AbstractCompiler */;
+{ /* Inline abstract_compiler#AbstractCompilerVisitor#compiler (self) on <self:Object(AbstractCompilerVisitor)> */
+var3 = self->attrs[COLOR_abstract_compiler__AbstractCompilerVisitor___compiler].val; /* _compiler on <self:Object(AbstractCompilerVisitor)> */
+if (unlikely(var3 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _compiler");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 1041);
+show_backtrace(1);
+}
+var1 = var3;
+RET_LABEL2:(void)0;
+}
 var = var1;
 RET_LABEL:;
 return var;
 }
-/* method abstract_compiler#MProperty#c_name_cache for (self: MProperty): nullable String */
-val* abstract_compiler__MProperty__c_name_cache(val* self) {
-val* var /* : nullable String */;
-val* var1 /* : nullable String */;
-var1 = self->attrs[COLOR_abstract_compiler__MProperty___64dc_name_cache].val; /* @c_name_cache on <self:MProperty> */
+/* method abstract_compiler#AbstractCompilerVisitor#compiler= for (self: AbstractCompilerVisitor, AbstractCompiler) */
+void abstract_compiler__AbstractCompilerVisitor__compiler_61d(val* self, val* p0) {
+short int var /* : Bool */;
+int cltype;
+int idtype;
+const struct type* type_struct;
+const char* var_class_name;
+/* Covariant cast for argument 0 (compiler) <p0:AbstractCompiler> isa COMPILER */
+/* <p0:AbstractCompiler> isa COMPILER */
+type_struct = self->type->resolution_table->types[COLOR_abstract_compiler__AbstractCompilerVisitor_VTCOMPILER];
+cltype = type_struct->color;
+idtype = type_struct->id;
+if(cltype >= p0->type->table_size) {
+var = 0;
+} else {
+var = p0->type->type_table[cltype] == idtype;
+}
+if (unlikely(!var)) {
+var_class_name = p0 == NULL ? "null" : p0->type->name;
+PRINT_ERROR("Runtime error: Cast failed. Expected `%s`, got `%s`", "COMPILER", var_class_name);
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 1041);
+show_backtrace(1);
+}
+self->attrs[COLOR_abstract_compiler__AbstractCompilerVisitor___compiler].val = p0; /* _compiler on <self:AbstractCompilerVisitor> */
+RET_LABEL:;
+}
+/* method abstract_compiler#AbstractCompilerVisitor#compiler= for (self: Object, AbstractCompiler) */
+void VIRTUAL_abstract_compiler__AbstractCompilerVisitor__compiler_61d(val* self, val* p0) {
+short int var /* : Bool */;
+int cltype;
+int idtype;
+const struct type* type_struct;
+const char* var_class_name;
+{ /* Inline abstract_compiler#AbstractCompilerVisitor#compiler= (self,p0) on <self:Object(AbstractCompilerVisitor)> */
+/* Covariant cast for argument 0 (compiler) <p0:AbstractCompiler> isa COMPILER */
+/* <p0:AbstractCompiler> isa COMPILER */
+type_struct = self->type->resolution_table->types[COLOR_abstract_compiler__AbstractCompilerVisitor_VTCOMPILER];
+cltype = type_struct->color;
+idtype = type_struct->id;
+if(cltype >= p0->type->table_size) {
+var = 0;
+} else {
+var = p0->type->type_table[cltype] == idtype;
+}
+if (unlikely(!var)) {
+var_class_name = p0 == NULL ? "null" : p0->type->name;
+PRINT_ERROR("Runtime error: Cast failed. Expected `%s`, got `%s`", "COMPILER", var_class_name);
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 1041);
+show_backtrace(1);
+}
+self->attrs[COLOR_abstract_compiler__AbstractCompilerVisitor___compiler].val = p0; /* _compiler on <self:Object(AbstractCompilerVisitor)> */
+RET_LABEL1:(void)0;
+}
+RET_LABEL:;
+}
+/* method abstract_compiler#AbstractCompilerVisitor#current_node for (self: AbstractCompilerVisitor): nullable ANode */
+val* abstract_compiler__AbstractCompilerVisitor__current_node(val* self) {
+val* var /* : nullable ANode */;
+val* var1 /* : nullable ANode */;
+var1 = self->attrs[COLOR_abstract_compiler__AbstractCompilerVisitor___current_node].val; /* _current_node on <self:AbstractCompilerVisitor> */
 var = var1;
 RET_LABEL:;
 return var;
 }
-/* method abstract_compiler#MProperty#c_name_cache for (self: Object): nullable String */
-val* VIRTUAL_abstract_compiler__MProperty__c_name_cache(val* self) {
-val* var /* : nullable String */;
-val* var1 /* : nullable String */;
-var1 = abstract_compiler__MProperty__c_name_cache(self);
+/* method abstract_compiler#AbstractCompilerVisitor#current_node for (self: Object): nullable ANode */
+val* VIRTUAL_abstract_compiler__AbstractCompilerVisitor__current_node(val* self) {
+val* var /* : nullable ANode */;
+val* var1 /* : nullable ANode */;
+val* var3 /* : nullable ANode */;
+{ /* Inline abstract_compiler#AbstractCompilerVisitor#current_node (self) on <self:Object(AbstractCompilerVisitor)> */
+var3 = self->attrs[COLOR_abstract_compiler__AbstractCompilerVisitor___current_node].val; /* _current_node on <self:Object(AbstractCompilerVisitor)> */
+var1 = var3;
+RET_LABEL2:(void)0;
+}
 var = var1;
 RET_LABEL:;
 return var;
 }
-/* method abstract_compiler#MProperty#c_name_cache= for (self: MProperty, nullable String) */
-void abstract_compiler__MProperty__c_name_cache_61d(val* self, val* p0) {
-self->attrs[COLOR_abstract_compiler__MProperty___64dc_name_cache].val = p0; /* @c_name_cache on <self:MProperty> */
+/* method abstract_compiler#AbstractCompilerVisitor#current_node= for (self: AbstractCompilerVisitor, nullable ANode) */
+void abstract_compiler__AbstractCompilerVisitor__current_node_61d(val* self, val* p0) {
+self->attrs[COLOR_abstract_compiler__AbstractCompilerVisitor___current_node].val = p0; /* _current_node on <self:AbstractCompilerVisitor> */
 RET_LABEL:;
 }
-/* method abstract_compiler#MProperty#c_name_cache= for (self: Object, nullable String) */
-void VIRTUAL_abstract_compiler__MProperty__c_name_cache_61d(val* self, val* p0) {
-abstract_compiler__MProperty__c_name_cache_61d(self, p0);
+/* method abstract_compiler#AbstractCompilerVisitor#current_node= for (self: Object, nullable ANode) */
+void VIRTUAL_abstract_compiler__AbstractCompilerVisitor__current_node_61d(val* self, val* p0) {
+{ /* Inline abstract_compiler#AbstractCompilerVisitor#current_node= (self,p0) on <self:Object(AbstractCompilerVisitor)> */
+self->attrs[COLOR_abstract_compiler__AbstractCompilerVisitor___current_node].val = p0; /* _current_node on <self:Object(AbstractCompilerVisitor)> */
+RET_LABEL1:(void)0;
+}
 RET_LABEL:;
 }
-/* method abstract_compiler#MPropDef#c_name_cache for (self: MPropDef): nullable String */
-val* abstract_compiler__MPropDef__c_name_cache(val* self) {
-val* var /* : nullable String */;
-val* var1 /* : nullable String */;
-var1 = self->attrs[COLOR_abstract_compiler__MPropDef___64dc_name_cache].val; /* @c_name_cache on <self:MPropDef> */
+/* method abstract_compiler#AbstractCompilerVisitor#frame for (self: AbstractCompilerVisitor): nullable Frame */
+val* abstract_compiler__AbstractCompilerVisitor__frame(val* self) {
+val* var /* : nullable Frame */;
+val* var1 /* : nullable Frame */;
+var1 = self->attrs[COLOR_abstract_compiler__AbstractCompilerVisitor___frame].val; /* _frame on <self:AbstractCompilerVisitor> */
 var = var1;
 RET_LABEL:;
 return var;
 }
-/* method abstract_compiler#MPropDef#c_name_cache for (self: Object): nullable String */
-val* VIRTUAL_abstract_compiler__MPropDef__c_name_cache(val* self) {
-val* var /* : nullable String */;
-val* var1 /* : nullable String */;
-var1 = abstract_compiler__MPropDef__c_name_cache(self);
+/* method abstract_compiler#AbstractCompilerVisitor#frame for (self: Object): nullable Frame */
+val* VIRTUAL_abstract_compiler__AbstractCompilerVisitor__frame(val* self) {
+val* var /* : nullable Frame */;
+val* var1 /* : nullable Frame */;
+val* var3 /* : nullable Frame */;
+{ /* Inline abstract_compiler#AbstractCompilerVisitor#frame (self) on <self:Object(AbstractCompilerVisitor)> */
+var3 = self->attrs[COLOR_abstract_compiler__AbstractCompilerVisitor___frame].val; /* _frame on <self:Object(AbstractCompilerVisitor)> */
+var1 = var3;
+RET_LABEL2:(void)0;
+}
 var = var1;
 RET_LABEL:;
 return var;
 }
-/* method abstract_compiler#MPropDef#c_name_cache= for (self: MPropDef, nullable String) */
-void abstract_compiler__MPropDef__c_name_cache_61d(val* self, val* p0) {
-self->attrs[COLOR_abstract_compiler__MPropDef___64dc_name_cache].val = p0; /* @c_name_cache on <self:MPropDef> */
+/* method abstract_compiler#AbstractCompilerVisitor#frame= for (self: AbstractCompilerVisitor, nullable Frame) */
+void abstract_compiler__AbstractCompilerVisitor__frame_61d(val* self, val* p0) {
+self->attrs[COLOR_abstract_compiler__AbstractCompilerVisitor___frame].val = p0; /* _frame on <self:AbstractCompilerVisitor> */
 RET_LABEL:;
 }
-/* method abstract_compiler#MPropDef#c_name_cache= for (self: Object, nullable String) */
-void VIRTUAL_abstract_compiler__MPropDef__c_name_cache_61d(val* self, val* p0) {
-abstract_compiler__MPropDef__c_name_cache_61d(self, p0);
+/* method abstract_compiler#AbstractCompilerVisitor#frame= for (self: Object, nullable Frame) */
+void VIRTUAL_abstract_compiler__AbstractCompilerVisitor__frame_61d(val* self, val* p0) {
+{ /* Inline abstract_compiler#AbstractCompilerVisitor#frame= (self,p0) on <self:Object(AbstractCompilerVisitor)> */
+self->attrs[COLOR_abstract_compiler__AbstractCompilerVisitor___frame].val = p0; /* _frame on <self:Object(AbstractCompilerVisitor)> */
+RET_LABEL1:(void)0;
+}
 RET_LABEL:;
 }
-/* method abstract_compiler#MPropDef#c_name for (self: MPropDef): String */
-val* abstract_compiler__MPropDef__c_name(val* self) {
-val* var /* : String */;
-val* var1 /* : nullable String */;
-val* var_res /* var res: nullable String */;
-val* var2 /* : null */;
-short int var3 /* : Bool */;
-val* var4 /* : Array[Object] */;
-long var5 /* : Int */;
-val* var_ /* var : Array[Object] */;
-static val* varonce;
-val* var6 /* : String */;
-char* var7 /* : NativeString */;
-long var8 /* : Int */;
-val* var9 /* : String */;
-val* var10 /* : MClassDef */;
-val* var11 /* : MModule */;
-val* var12 /* : String */;
-val* var13 /* : String */;
-static val* varonce14;
-val* var15 /* : String */;
-char* var16 /* : NativeString */;
-long var17 /* : Int */;
-val* var18 /* : String */;
-val* var19 /* : MClassDef */;
-val* var20 /* : MClass */;
-val* var21 /* : String */;
-val* var22 /* : String */;
-static val* varonce23;
-val* var24 /* : String */;
-char* var25 /* : NativeString */;
-long var26 /* : Int */;
-val* var27 /* : String */;
-val* var28 /* : MProperty */;
-val* var29 /* : String */;
-val* var30 /* : String */;
-static val* varonce31;
-val* var32 /* : String */;
-char* var33 /* : NativeString */;
-long var34 /* : Int */;
-val* var35 /* : String */;
-val* var36 /* : String */;
-var1 = ((val* (*)(val*))(self->class->vft[COLOR_abstract_compiler__MPropDef__c_name_cache]))(self) /* c_name_cache on <self:MPropDef>*/;
-var_res = var1;
-var2 = NULL;
-if (var_res == NULL) {
-var3 = 0; /* is null */
-} else {
-var3 = 1; /* arg is null and recv is not */
+/* method abstract_compiler#AbstractCompilerVisitor#object_type for (self: AbstractCompilerVisitor): MClassType */
+val* abstract_compiler__AbstractCompilerVisitor__object_type(val* self) {
+val* var /* : MClassType */;
+val* var1 /* : AbstractCompiler */;
+val* var3 /* : AbstractCompiler */;
+val* var4 /* : MModule */;
+val* var6 /* : MModule */;
+val* var7 /* : MClassType */;
+{
+{ /* Inline abstract_compiler#AbstractCompilerVisitor#compiler (self) on <self:AbstractCompilerVisitor> */
+var3 = self->attrs[COLOR_abstract_compiler__AbstractCompilerVisitor___compiler].val; /* _compiler on <self:AbstractCompilerVisitor> */
+if (unlikely(var3 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _compiler");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 1041);
+show_backtrace(1);
 }
-if (var3){
-var = var_res;
+var1 = var3;
+RET_LABEL2:(void)0;
+}
+}
+{
+{ /* Inline abstract_compiler#AbstractCompiler#mainmodule (var1) on <var1:AbstractCompiler> */
+var6 = var1->attrs[COLOR_abstract_compiler__AbstractCompiler___mainmodule].val; /* _mainmodule on <var1:AbstractCompiler> */
+if (unlikely(var6 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _mainmodule");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 463);
+show_backtrace(1);
+}
+var4 = var6;
+RET_LABEL5:(void)0;
+}
+}
+{
+var7 = model__MModule__object_type(var4);
+}
+var = var7;
 goto RET_LABEL;
-} else {
+RET_LABEL:;
+return var;
 }
-var4 = NEW_array__Array(&type_array__Arraykernel__Object);
-var5 = 7;
-((void (*)(val*, long))(var4->class->vft[COLOR_array__Array__with_capacity]))(var4, var5) /* with_capacity on <var4:Array[Object]>*/;
-CHECK_NEW_array__Array(var4);
-var_ = var4;
-if (varonce) {
-var6 = varonce;
-} else {
-var7 = "";
-var8 = 0;
-var9 = string__NativeString__to_s_with_length(var7, var8);
-var6 = var9;
-varonce = var6;
+/* method abstract_compiler#AbstractCompilerVisitor#object_type for (self: Object): MClassType */
+val* VIRTUAL_abstract_compiler__AbstractCompilerVisitor__object_type(val* self) {
+val* var /* : MClassType */;
+val* var1 /* : MClassType */;
+var1 = abstract_compiler__AbstractCompilerVisitor__object_type(self);
+var = var1;
+RET_LABEL:;
+return var;
 }
-((void (*)(val*, val*))(var_->class->vft[COLOR_abstract_collection__SimpleCollection__add]))(var_, var6) /* add on <var_:Array[Object]>*/;
-var10 = ((val* (*)(val*))(self->class->vft[COLOR_model__MPropDef__mclassdef]))(self) /* mclassdef on <self:MPropDef>*/;
-var11 = ((val* (*)(val*))(var10->class->vft[COLOR_model__MClassDef__mmodule]))(var10) /* mmodule on <var10:MClassDef>*/;
-var12 = ((val* (*)(val*))(var11->class->vft[COLOR_model_base__MModule__name]))(var11) /* name on <var11:MModule>*/;
-var13 = ((val* (*)(val*))(var12->class->vft[COLOR_string__AbstractString__to_cmangle]))(var12) /* to_cmangle on <var12:String>*/;
-((void (*)(val*, val*))(var_->class->vft[COLOR_abstract_collection__SimpleCollection__add]))(var_, var13) /* add on <var_:Array[Object]>*/;
-if (varonce14) {
-var15 = varonce14;
-} else {
-var16 = "__";
-var17 = 2;
-var18 = string__NativeString__to_s_with_length(var16, var17);
-var15 = var18;
-varonce14 = var15;
+/* method abstract_compiler#AbstractCompilerVisitor#bool_type for (self: AbstractCompilerVisitor): MClassType */
+val* abstract_compiler__AbstractCompilerVisitor__bool_type(val* self) {
+val* var /* : MClassType */;
+val* var1 /* : AbstractCompiler */;
+val* var3 /* : AbstractCompiler */;
+val* var4 /* : MModule */;
+val* var6 /* : MModule */;
+val* var7 /* : MClassType */;
+{
+{ /* Inline abstract_compiler#AbstractCompilerVisitor#compiler (self) on <self:AbstractCompilerVisitor> */
+var3 = self->attrs[COLOR_abstract_compiler__AbstractCompilerVisitor___compiler].val; /* _compiler on <self:AbstractCompilerVisitor> */
+if (unlikely(var3 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _compiler");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 1041);
+show_backtrace(1);
 }
-((void (*)(val*, val*))(var_->class->vft[COLOR_abstract_collection__SimpleCollection__add]))(var_, var15) /* add on <var_:Array[Object]>*/;
-var19 = ((val* (*)(val*))(self->class->vft[COLOR_model__MPropDef__mclassdef]))(self) /* mclassdef on <self:MPropDef>*/;
-var20 = ((val* (*)(val*))(var19->class->vft[COLOR_model__MClassDef__mclass]))(var19) /* mclass on <var19:MClassDef>*/;
-var21 = ((val* (*)(val*))(var20->class->vft[COLOR_model__MClass__name]))(var20) /* name on <var20:MClass>*/;
-var22 = ((val* (*)(val*))(var21->class->vft[COLOR_string__AbstractString__to_cmangle]))(var21) /* to_cmangle on <var21:String>*/;
-((void (*)(val*, val*))(var_->class->vft[COLOR_abstract_collection__SimpleCollection__add]))(var_, var22) /* add on <var_:Array[Object]>*/;
-if (varonce23) {
-var24 = varonce23;
-} else {
-var25 = "__";
-var26 = 2;
-var27 = string__NativeString__to_s_with_length(var25, var26);
-var24 = var27;
-varonce23 = var24;
-}
-((void (*)(val*, val*))(var_->class->vft[COLOR_abstract_collection__SimpleCollection__add]))(var_, var24) /* add on <var_:Array[Object]>*/;
-var28 = ((val* (*)(val*))(self->class->vft[COLOR_model__MPropDef__mproperty]))(self) /* mproperty on <self:MPropDef>*/;
-var29 = ((val* (*)(val*))(var28->class->vft[COLOR_model__MProperty__name]))(var28) /* name on <var28:MProperty>*/;
-var30 = ((val* (*)(val*))(var29->class->vft[COLOR_string__AbstractString__to_cmangle]))(var29) /* to_cmangle on <var29:String>*/;
-((void (*)(val*, val*))(var_->class->vft[COLOR_abstract_collection__SimpleCollection__add]))(var_, var30) /* add on <var_:Array[Object]>*/;
-if (varonce31) {
-var32 = varonce31;
-} else {
-var33 = "";
-var34 = 0;
-var35 = string__NativeString__to_s_with_length(var33, var34);
-var32 = var35;
-varonce31 = var32;
+var1 = var3;
+RET_LABEL2:(void)0;
 }
-((void (*)(val*, val*))(var_->class->vft[COLOR_abstract_collection__SimpleCollection__add]))(var_, var32) /* add on <var_:Array[Object]>*/;
-var36 = ((val* (*)(val*))(var_->class->vft[COLOR_string__Object__to_s]))(var_) /* to_s on <var_:Array[Object]>*/;
-var_res = var36;
-((void (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__MPropDef__c_name_cache_61d]))(self, var_res) /* c_name_cache= on <self:MPropDef>*/;
-var = var_res;
+}
+{
+{ /* Inline abstract_compiler#AbstractCompiler#mainmodule (var1) on <var1:AbstractCompiler> */
+var6 = var1->attrs[COLOR_abstract_compiler__AbstractCompiler___mainmodule].val; /* _mainmodule on <var1:AbstractCompiler> */
+if (unlikely(var6 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _mainmodule");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 463);
+show_backtrace(1);
+}
+var4 = var6;
+RET_LABEL5:(void)0;
+}
+}
+{
+var7 = model__MModule__bool_type(var4);
+}
+var = var7;
 goto RET_LABEL;
 RET_LABEL:;
 return var;
 }
-/* method abstract_compiler#MPropDef#c_name for (self: Object): String */
-val* VIRTUAL_abstract_compiler__MPropDef__c_name(val* self) {
-val* var /* : String */;
-val* var1 /* : String */;
-var1 = abstract_compiler__MPropDef__c_name(self);
+/* method abstract_compiler#AbstractCompilerVisitor#bool_type for (self: Object): MClassType */
+val* VIRTUAL_abstract_compiler__AbstractCompilerVisitor__bool_type(val* self) {
+val* var /* : MClassType */;
+val* var1 /* : MClassType */;
+var1 = abstract_compiler__AbstractCompilerVisitor__bool_type(self);
+var = var1;
+RET_LABEL:;
+return var;
+}
+/* method abstract_compiler#AbstractCompilerVisitor#writer for (self: AbstractCompilerVisitor): CodeWriter */
+val* abstract_compiler__AbstractCompilerVisitor__writer(val* self) {
+val* var /* : CodeWriter */;
+val* var1 /* : CodeWriter */;
+var1 = self->attrs[COLOR_abstract_compiler__AbstractCompilerVisitor___writer].val; /* _writer on <self:AbstractCompilerVisitor> */
+if (unlikely(var1 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _writer");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 1056);
+show_backtrace(1);
+}
 var = var1;
 RET_LABEL:;
 return var;
 }
-/* method abstract_compiler#MMethodDef#can_inline for (self: MMethodDef, AbstractCompilerVisitor): Bool */
-short int abstract_compiler__MMethodDef__can_inline(val* self, val* p0) {
+/* method abstract_compiler#AbstractCompilerVisitor#writer for (self: Object): CodeWriter */
+val* VIRTUAL_abstract_compiler__AbstractCompilerVisitor__writer(val* self) {
+val* var /* : CodeWriter */;
+val* var1 /* : CodeWriter */;
+val* var3 /* : CodeWriter */;
+{ /* Inline abstract_compiler#AbstractCompilerVisitor#writer (self) on <self:Object(AbstractCompilerVisitor)> */
+var3 = self->attrs[COLOR_abstract_compiler__AbstractCompilerVisitor___writer].val; /* _writer on <self:Object(AbstractCompilerVisitor)> */
+if (unlikely(var3 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _writer");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 1056);
+show_backtrace(1);
+}
+var1 = var3;
+RET_LABEL2:(void)0;
+}
+var = var1;
+RET_LABEL:;
+return var;
+}
+/* method abstract_compiler#AbstractCompilerVisitor#writer= for (self: AbstractCompilerVisitor, CodeWriter) */
+void abstract_compiler__AbstractCompilerVisitor__writer_61d(val* self, val* p0) {
+self->attrs[COLOR_abstract_compiler__AbstractCompilerVisitor___writer].val = p0; /* _writer on <self:AbstractCompilerVisitor> */
+RET_LABEL:;
+}
+/* method abstract_compiler#AbstractCompilerVisitor#writer= for (self: Object, CodeWriter) */
+void VIRTUAL_abstract_compiler__AbstractCompilerVisitor__writer_61d(val* self, val* p0) {
+{ /* Inline abstract_compiler#AbstractCompilerVisitor#writer= (self,p0) on <self:Object(AbstractCompilerVisitor)> */
+self->attrs[COLOR_abstract_compiler__AbstractCompilerVisitor___writer].val = p0; /* _writer on <self:Object(AbstractCompilerVisitor)> */
+RET_LABEL1:(void)0;
+}
+RET_LABEL:;
+}
+/* method abstract_compiler#AbstractCompilerVisitor#init for (self: AbstractCompilerVisitor, AbstractCompiler) */
+void abstract_compiler__AbstractCompilerVisitor__init(val* self, val* p0) {
 short int var /* : Bool */;
-short int var1 /* : Bool */;
 int cltype;
 int idtype;
 const struct type* type_struct;
-val* var_v /* var v: AbstractCompilerVisitor */;
-val* var2 /* : AbstractCompiler */;
-val* var3 /* : ModelBuilder */;
-val* var_modelbuilder /* var modelbuilder: ModelBuilder */;
-val* var4 /* : HashMap[MPropDef, APropdef] */;
-short int var5 /* : Bool */;
-val* var6 /* : HashMap[MPropDef, APropdef] */;
-val* var7 /* : nullable Object */;
-val* var_npropdef /* var npropdef: APropdef */;
-short int var8 /* : Bool */;
-val* var9 /* : MProperty */;
-val* var10 /* : String */;
-static val* varonce;
-val* var11 /* : String */;
-char* var12 /* : NativeString */;
-long var13 /* : Int */;
-val* var14 /* : String */;
-short int var15 /* : Bool */;
-short int var16 /* : Bool */;
-/* Covariant cast for argument 0 (v) <p0:AbstractCompilerVisitor> isa VISITOR */
-/* <p0:AbstractCompilerVisitor> isa VISITOR */
-type_struct = self->type->resolution_table->types[COLOR_model__MPropDef_VTVISITOR];
+const char* var_class_name;
+val* var_compiler /* var compiler: AbstractCompiler */;
+short int var2 /* : Bool */;
+int cltype3;
+int idtype4;
+const struct type* type_struct5;
+const char* var_class_name6;
+val* var7 /* : CodeWriter */;
+val* var8 /* : List[CodeFile] */;
+val* var10 /* : List[CodeFile] */;
+val* var11 /* : nullable Object */;
+/* Covariant cast for argument 0 (compiler) <p0:AbstractCompiler> isa COMPILER */
+/* <p0:AbstractCompiler> isa COMPILER */
+type_struct = self->type->resolution_table->types[COLOR_abstract_compiler__AbstractCompilerVisitor_VTCOMPILER];
 cltype = type_struct->color;
 idtype = type_struct->id;
 if(cltype >= p0->type->table_size) {
-var1 = 0;
+var = 0;
 } else {
-var1 = p0->type->type_table[cltype] == idtype;
+var = p0->type->type_table[cltype] == idtype;
 }
-if (!var1) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "src/abstract_compiler.nit", 1229);
-exit(1);
+if (unlikely(!var)) {
+var_class_name = p0 == NULL ? "null" : p0->type->name;
+PRINT_ERROR("Runtime error: Cast failed. Expected `%s`, got `%s`", "COMPILER", var_class_name);
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 1058);
+show_backtrace(1);
 }
-var_v = p0;
-var2 = ((val* (*)(val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__compiler]))(var_v) /* compiler on <var_v:AbstractCompilerVisitor>*/;
-var3 = ((val* (*)(val*))(var2->class->vft[COLOR_abstract_compiler__AbstractCompiler__modelbuilder]))(var2) /* modelbuilder on <var2:AbstractCompiler>*/;
-var_modelbuilder = var3;
-var4 = ((val* (*)(val*))(var_modelbuilder->class->vft[COLOR_modelize_property__ModelBuilder__mpropdef2npropdef]))(var_modelbuilder) /* mpropdef2npropdef on <var_modelbuilder:ModelBuilder>*/;
-var5 = ((short int (*)(val*, val*))(var4->class->vft[COLOR_abstract_collection__MapRead__has_key]))(var4, self) /* has_key on <var4:HashMap[MPropDef, APropdef]>*/;
-if (var5){
-var6 = ((val* (*)(val*))(var_modelbuilder->class->vft[COLOR_modelize_property__ModelBuilder__mpropdef2npropdef]))(var_modelbuilder) /* mpropdef2npropdef on <var_modelbuilder:ModelBuilder>*/;
-var7 = ((val* (*)(val*, val*))(var6->class->vft[COLOR_abstract_collection__MapRead___91d_93d]))(var6, self) /* [] on <var6:HashMap[MPropDef, APropdef]>*/;
-var_npropdef = var7;
-var8 = ((short int (*)(val*))(var_npropdef->class->vft[COLOR_abstract_compiler__APropdef__can_inline]))(var_npropdef) /* can_inline on <var_npropdef:APropdef>*/;
-var = var8;
-goto RET_LABEL;
-} else {
-var9 = ((val* (*)(val*))(self->class->vft[COLOR_model__MPropDef__mproperty]))(self) /* mproperty on <self:MMethodDef>*/;
-var10 = ((val* (*)(val*))(var9->class->vft[COLOR_model__MProperty__name]))(var9) /* name on <var9:MProperty(MMethod)>*/;
-if (varonce) {
-var11 = varonce;
+var_compiler = p0;
+{
+{ /* Inline abstract_compiler#AbstractCompilerVisitor#compiler= (self,var_compiler) on <self:AbstractCompilerVisitor> */
+/* Covariant cast for argument 0 (compiler) <var_compiler:AbstractCompiler> isa COMPILER */
+/* <var_compiler:AbstractCompiler> isa COMPILER */
+type_struct5 = self->type->resolution_table->types[COLOR_abstract_compiler__AbstractCompilerVisitor_VTCOMPILER];
+cltype3 = type_struct5->color;
+idtype4 = type_struct5->id;
+if(cltype3 >= var_compiler->type->table_size) {
+var2 = 0;
 } else {
-var12 = "init";
-var13 = 4;
-var14 = string__NativeString__to_s_with_length(var12, var13);
-var11 = var14;
-varonce = var11;
+var2 = var_compiler->type->type_table[cltype3] == idtype4;
+}
+if (unlikely(!var2)) {
+var_class_name6 = var_compiler == NULL ? "null" : var_compiler->type->name;
+PRINT_ERROR("Runtime error: Cast failed. Expected `%s`, got `%s`", "COMPILER", var_class_name6);
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 1041);
+show_backtrace(1);
+}
+self->attrs[COLOR_abstract_compiler__AbstractCompilerVisitor___compiler].val = var_compiler; /* _compiler on <self:AbstractCompilerVisitor> */
+RET_LABEL1:(void)0;
 }
-var15 = ((short int (*)(val*, val*))(var10->class->vft[COLOR_kernel__Object___61d_61d]))(var10, var11) /* == on <var10:String>*/;
-if (var15){
-var16 = 1;
-var = var16;
-goto RET_LABEL;
-} else {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Aborted", "src/abstract_compiler.nit", 1240);
-exit(1);
+}
+var7 = NEW_abstract_compiler__CodeWriter(&type_abstract_compiler__CodeWriter);
+{
+{ /* Inline abstract_compiler#AbstractCompiler#files (var_compiler) on <var_compiler:AbstractCompiler> */
+var10 = var_compiler->attrs[COLOR_abstract_compiler__AbstractCompiler___files].val; /* _files on <var_compiler:AbstractCompiler> */
+if (unlikely(var10 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _files");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 499);
+show_backtrace(1);
+}
+var8 = var10;
+RET_LABEL9:(void)0;
+}
+}
+{
+var11 = list__List__last(var8);
+}
+{
+abstract_compiler__CodeWriter__init(var7, var11); /* Direct call abstract_compiler#CodeWriter#init on <var7:CodeWriter>*/
+}
+{
+{ /* Inline abstract_compiler#AbstractCompilerVisitor#writer= (self,var7) on <self:AbstractCompilerVisitor> */
+self->attrs[COLOR_abstract_compiler__AbstractCompilerVisitor___writer].val = var7; /* _writer on <self:AbstractCompilerVisitor> */
+RET_LABEL12:(void)0;
 }
 }
 RET_LABEL:;
-return var;
 }
-/* method abstract_compiler#MMethodDef#can_inline for (self: Object, AbstractCompilerVisitor): Bool */
-short int VIRTUAL_abstract_compiler__MMethodDef__can_inline(val* self, val* p0) {
-short int var /* : Bool */;
-short int var1 /* : Bool */;
-var1 = abstract_compiler__MMethodDef__can_inline(self, p0);
+/* method abstract_compiler#AbstractCompilerVisitor#init for (self: Object, AbstractCompiler) */
+void VIRTUAL_abstract_compiler__AbstractCompilerVisitor__init(val* self, val* p0) {
+abstract_compiler__AbstractCompilerVisitor__init(self, p0); /* Direct call abstract_compiler#AbstractCompilerVisitor#init on <self:Object(AbstractCompilerVisitor)>*/
+RET_LABEL:;
+}
+/* method abstract_compiler#AbstractCompilerVisitor#get_class for (self: AbstractCompilerVisitor, String): MClass */
+val* abstract_compiler__AbstractCompilerVisitor__get_class(val* self, val* p0) {
+val* var /* : MClass */;
+val* var_name /* var name: String */;
+val* var1 /* : AbstractCompiler */;
+val* var3 /* : AbstractCompiler */;
+val* var4 /* : MModule */;
+val* var6 /* : MModule */;
+val* var7 /* : MClass */;
+var_name = p0;
+{
+{ /* Inline abstract_compiler#AbstractCompilerVisitor#compiler (self) on <self:AbstractCompilerVisitor> */
+var3 = self->attrs[COLOR_abstract_compiler__AbstractCompilerVisitor___compiler].val; /* _compiler on <self:AbstractCompilerVisitor> */
+if (unlikely(var3 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _compiler");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 1041);
+show_backtrace(1);
+}
+var1 = var3;
+RET_LABEL2:(void)0;
+}
+}
+{
+{ /* Inline abstract_compiler#AbstractCompiler#mainmodule (var1) on <var1:AbstractCompiler> */
+var6 = var1->attrs[COLOR_abstract_compiler__AbstractCompiler___mainmodule].val; /* _mainmodule on <var1:AbstractCompiler> */
+if (unlikely(var6 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _mainmodule");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 463);
+show_backtrace(1);
+}
+var4 = var6;
+RET_LABEL5:(void)0;
+}
+}
+{
+var7 = model__MModule__get_primitive_class(var4, var_name);
+}
+var = var7;
+goto RET_LABEL;
+RET_LABEL:;
+return var;
+}
+/* method abstract_compiler#AbstractCompilerVisitor#get_class for (self: Object, String): MClass */
+val* VIRTUAL_abstract_compiler__AbstractCompilerVisitor__get_class(val* self, val* p0) {
+val* var /* : MClass */;
+val* var1 /* : MClass */;
+var1 = abstract_compiler__AbstractCompilerVisitor__get_class(self, p0);
 var = var1;
 RET_LABEL:;
 return var;
 }
-/* method abstract_compiler#MMethodDef#compile_inside_to_c for (self: MMethodDef, AbstractCompilerVisitor, Array[RuntimeVariable]): nullable RuntimeVariable */
-val* abstract_compiler__MMethodDef__compile_inside_to_c(val* self, val* p0, val* p1) {
-val* var /* : nullable RuntimeVariable */;
+/* method abstract_compiler#AbstractCompilerVisitor#get_property for (self: AbstractCompilerVisitor, String, MType): MMethod */
+val* abstract_compiler__AbstractCompilerVisitor__get_property(val* self, val* p0, val* p1) {
+val* var /* : MMethod */;
+val* var_name /* var name: String */;
+val* var_recv /* var recv: MType */;
 short int var1 /* : Bool */;
 int cltype;
 int idtype;
-const struct type* type_struct;
-val* var_v /* var v: AbstractCompilerVisitor */;
-val* var_arguments /* var arguments: Array[RuntimeVariable] */;
 val* var2 /* : AbstractCompiler */;
-val* var3 /* : ModelBuilder */;
-val* var_modelbuilder /* var modelbuilder: ModelBuilder */;
-val* var4 /* : HashMap[MPropDef, APropdef] */;
-short int var5 /* : Bool */;
-val* var6 /* : HashMap[MPropDef, APropdef] */;
-val* var7 /* : nullable Object */;
-val* var_npropdef /* var npropdef: APropdef */;
+val* var4 /* : AbstractCompiler */;
+val* var5 /* : ModelBuilder */;
+val* var7 /* : ModelBuilder */;
 val* var8 /* : nullable ANode */;
-val* var_oldnode /* var oldnode: nullable ANode */;
-val* var9 /* : MProperty */;
-val* var10 /* : String */;
-static val* varonce;
-val* var11 /* : String */;
-char* var12 /* : NativeString */;
-long var13 /* : Int */;
-val* var14 /* : String */;
-short int var15 /* : Bool */;
-val* var16 /* : HashMap[MClassDef, AClassdef] */;
-val* var17 /* : MClassDef */;
-val* var18 /* : nullable Object */;
-val* var_nclassdef /* var nclassdef: AClassdef */;
-val* var19 /* : nullable ANode */;
-val* var_oldnode20 /* var oldnode: nullable ANode */;
-val* var21 /* : null */;
-/* Covariant cast for argument 0 (v) <p0:AbstractCompilerVisitor> isa VISITOR */
-/* <p0:AbstractCompilerVisitor> isa VISITOR */
-type_struct = self->type->resolution_table->types[COLOR_model__MPropDef_VTVISITOR];
-cltype = type_struct->color;
-idtype = type_struct->id;
-if(cltype >= p0->type->table_size) {
+val* var10 /* : nullable ANode */;
+val* var11 /* : MClass */;
+val* var13 /* : MClass */;
+val* var14 /* : AbstractCompiler */;
+val* var16 /* : AbstractCompiler */;
+val* var17 /* : MModule */;
+val* var19 /* : MModule */;
+val* var20 /* : MMethod */;
+var_name = p0;
+var_recv = p1;
+/* <var_recv:MType> isa MClassType */
+cltype = type_model__MClassType.color;
+idtype = type_model__MClassType.id;
+if(cltype >= var_recv->type->table_size) {
 var1 = 0;
 } else {
-var1 = p0->type->type_table[cltype] == idtype;
+var1 = var_recv->type->type_table[cltype] == idtype;
 }
-if (!var1) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "src/abstract_compiler.nit", 1244);
-exit(1);
+if (unlikely(!var1)) {
+PRINT_ERROR("Runtime error: %s", "Assert failed");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 1070);
+show_backtrace(1);
 }
-var_v = p0;
-var_arguments = p1;
-var2 = ((val* (*)(val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__compiler]))(var_v) /* compiler on <var_v:AbstractCompilerVisitor>*/;
-var3 = ((val* (*)(val*))(var2->class->vft[COLOR_abstract_compiler__AbstractCompiler__modelbuilder]))(var2) /* modelbuilder on <var2:AbstractCompiler>*/;
-var_modelbuilder = var3;
-var4 = ((val* (*)(val*))(var_modelbuilder->class->vft[COLOR_modelize_property__ModelBuilder__mpropdef2npropdef]))(var_modelbuilder) /* mpropdef2npropdef on <var_modelbuilder:ModelBuilder>*/;
-var5 = ((short int (*)(val*, val*))(var4->class->vft[COLOR_abstract_collection__MapRead__has_key]))(var4, self) /* has_key on <var4:HashMap[MPropDef, APropdef]>*/;
-if (var5){
-var6 = ((val* (*)(val*))(var_modelbuilder->class->vft[COLOR_modelize_property__ModelBuilder__mpropdef2npropdef]))(var_modelbuilder) /* mpropdef2npropdef on <var_modelbuilder:ModelBuilder>*/;
-var7 = ((val* (*)(val*, val*))(var6->class->vft[COLOR_abstract_collection__MapRead___91d_93d]))(var6, self) /* [] on <var6:HashMap[MPropDef, APropdef]>*/;
-var_npropdef = var7;
-var8 = ((val* (*)(val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__current_node]))(var_v) /* current_node on <var_v:AbstractCompilerVisitor>*/;
-var_oldnode = var8;
-((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__current_node_61d]))(var_v, var_npropdef) /* current_node= on <var_v:AbstractCompilerVisitor>*/;
-((void (*)(val*, val*, val*))(self->class->vft[COLOR_abstract_compiler__MMethodDef__compile_parameter_check]))(self, var_v, var_arguments) /* compile_parameter_check on <self:MMethodDef>*/;
-((void (*)(val*, val*, val*, val*))(var_npropdef->class->vft[COLOR_abstract_compiler__APropdef__compile_to_c]))(var_npropdef, var_v, self, var_arguments) /* compile_to_c on <var_npropdef:APropdef>*/;
-((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__current_node_61d]))(var_v, var_oldnode) /* current_node= on <var_v:AbstractCompilerVisitor>*/;
-} else {
-var9 = ((val* (*)(val*))(self->class->vft[COLOR_model__MPropDef__mproperty]))(self) /* mproperty on <self:MMethodDef>*/;
-var10 = ((val* (*)(val*))(var9->class->vft[COLOR_model__MProperty__name]))(var9) /* name on <var9:MProperty(MMethod)>*/;
-if (varonce) {
-var11 = varonce;
-} else {
-var12 = "init";
-var13 = 4;
-var14 = string__NativeString__to_s_with_length(var12, var13);
-var11 = var14;
-varonce = var11;
+{
+{ /* Inline abstract_compiler#AbstractCompilerVisitor#compiler (self) on <self:AbstractCompilerVisitor> */
+var4 = self->attrs[COLOR_abstract_compiler__AbstractCompilerVisitor___compiler].val; /* _compiler on <self:AbstractCompilerVisitor> */
+if (unlikely(var4 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _compiler");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 1041);
+show_backtrace(1);
 }
-var15 = ((short int (*)(val*, val*))(var10->class->vft[COLOR_kernel__Object___61d_61d]))(var10, var11) /* == on <var10:String>*/;
-if (var15){
-var16 = ((val* (*)(val*))(var_modelbuilder->class->vft[COLOR_modelize_class__ModelBuilder__mclassdef2nclassdef]))(var_modelbuilder) /* mclassdef2nclassdef on <var_modelbuilder:ModelBuilder>*/;
-var17 = ((val* (*)(val*))(self->class->vft[COLOR_model__MPropDef__mclassdef]))(self) /* mclassdef on <self:MMethodDef>*/;
-var18 = ((val* (*)(val*, val*))(var16->class->vft[COLOR_abstract_collection__MapRead___91d_93d]))(var16, var17) /* [] on <var16:HashMap[MClassDef, AClassdef]>*/;
-var_nclassdef = var18;
-var19 = ((val* (*)(val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__current_node]))(var_v) /* current_node on <var_v:AbstractCompilerVisitor>*/;
-var_oldnode20 = var19;
-((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__current_node_61d]))(var_v, var_nclassdef) /* current_node= on <var_v:AbstractCompilerVisitor>*/;
-((void (*)(val*, val*, val*))(self->class->vft[COLOR_abstract_compiler__MMethodDef__compile_parameter_check]))(self, var_v, var_arguments) /* compile_parameter_check on <self:MMethodDef>*/;
-((void (*)(val*, val*, val*, val*))(var_nclassdef->class->vft[COLOR_abstract_compiler__AClassdef__compile_to_c]))(var_nclassdef, var_v, self, var_arguments) /* compile_to_c on <var_nclassdef:AClassdef>*/;
-((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__current_node_61d]))(var_v, var_oldnode20) /* current_node= on <var_v:AbstractCompilerVisitor>*/;
-} else {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Aborted", "src/abstract_compiler.nit", 1263);
-exit(1);
-}
-}
-var21 = NULL;
-var = var21;
+var2 = var4;
+RET_LABEL3:(void)0;
+}
+}
+{
+{ /* Inline abstract_compiler#AbstractCompiler#modelbuilder (var2) on <var2:AbstractCompiler> */
+var7 = var2->attrs[COLOR_abstract_compiler__AbstractCompiler___modelbuilder].val; /* _modelbuilder on <var2:AbstractCompiler> */
+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 abstract_compiler#AbstractCompilerVisitor#current_node (self) on <self:AbstractCompilerVisitor> */
+var10 = self->attrs[COLOR_abstract_compiler__AbstractCompilerVisitor___current_node].val; /* _current_node on <self:AbstractCompilerVisitor> */
+var8 = var10;
+RET_LABEL9:(void)0;
+}
+}
+{
+{ /* Inline model#MClassType#mclass (var_recv) on <var_recv:MType(MClassType)> */
+var13 = var_recv->attrs[COLOR_model__MClassType___mclass].val; /* _mclass on <var_recv:MType(MClassType)> */
+if (unlikely(var13 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _mclass");
+PRINT_ERROR(" (%s:%d)\n", "model/model.nit", 986);
+show_backtrace(1);
+}
+var11 = var13;
+RET_LABEL12:(void)0;
+}
+}
+{
+{ /* Inline abstract_compiler#AbstractCompilerVisitor#compiler (self) on <self:AbstractCompilerVisitor> */
+var16 = self->attrs[COLOR_abstract_compiler__AbstractCompilerVisitor___compiler].val; /* _compiler on <self:AbstractCompilerVisitor> */
+if (unlikely(var16 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _compiler");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 1041);
+show_backtrace(1);
+}
+var14 = var16;
+RET_LABEL15:(void)0;
+}
+}
+{
+{ /* Inline abstract_compiler#AbstractCompiler#mainmodule (var14) on <var14:AbstractCompiler> */
+var19 = var14->attrs[COLOR_abstract_compiler__AbstractCompiler___mainmodule].val; /* _mainmodule on <var14:AbstractCompiler> */
+if (unlikely(var19 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _mainmodule");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 463);
+show_backtrace(1);
+}
+var17 = var19;
+RET_LABEL18:(void)0;
+}
+}
+{
+var20 = modelbuilder__ModelBuilder__force_get_primitive_method(var5, var8, var_name, var11, var17);
+}
+var = var20;
 goto RET_LABEL;
 RET_LABEL:;
 return var;
 }
-/* method abstract_compiler#MMethodDef#compile_inside_to_c for (self: Object, AbstractCompilerVisitor, Array[RuntimeVariable]): nullable RuntimeVariable */
-val* VIRTUAL_abstract_compiler__MMethodDef__compile_inside_to_c(val* self, val* p0, val* p1) {
-val* var /* : nullable RuntimeVariable */;
-val* var1 /* : nullable RuntimeVariable */;
-var1 = abstract_compiler__MMethodDef__compile_inside_to_c(self, p0, p1);
+/* method abstract_compiler#AbstractCompilerVisitor#get_property for (self: Object, String, MType): MMethod */
+val* VIRTUAL_abstract_compiler__AbstractCompilerVisitor__get_property(val* self, val* p0, val* p1) {
+val* var /* : MMethod */;
+val* var1 /* : MMethod */;
+var1 = abstract_compiler__AbstractCompilerVisitor__get_property(self, p0, p1);
 var = var1;
 RET_LABEL:;
 return var;
 }
-/* method abstract_compiler#MMethodDef#compile_parameter_check for (self: MMethodDef, AbstractCompilerVisitor, Array[RuntimeVariable]) */
-void abstract_compiler__MMethodDef__compile_parameter_check(val* self, val* p0, val* p1) {
-short int var /* : Bool */;
-int cltype;
-int idtype;
-const struct type* type_struct;
-val* var_v /* var v: AbstractCompilerVisitor */;
+/* method abstract_compiler#AbstractCompilerVisitor#compile_callsite for (self: AbstractCompilerVisitor, CallSite, Array[RuntimeVariable]): nullable RuntimeVariable */
+val* abstract_compiler__AbstractCompilerVisitor__compile_callsite(val* self, val* p0, val* p1) {
+val* var /* : nullable RuntimeVariable */;
+val* var_callsite /* var callsite: CallSite */;
 val* var_arguments /* var arguments: Array[RuntimeVariable] */;
-val* var1 /* : AbstractCompiler */;
-val* var2 /* : ModelBuilder */;
-val* var3 /* : ToolContext */;
-val* var4 /* : OptionBool */;
-val* var5 /* : nullable Object */;
-short int var6 /* : Bool */;
-val* var7 /* : Range[Int] */;
-long var8 /* : Int */;
-val* var9 /* : nullable MSignature */;
+val* var1 /* : MMethodDef */;
+val* var3 /* : MMethodDef */;
+val* var4 /* : Array[MProperty] */;
+val* var6 /* : Array[MProperty] */;
+val* var_initializers /* var initializers: Array[MProperty] */;
+short int var7 /* : Bool */;
+short int var8 /* : Bool */;
+val* var9 /* : nullable Object */;
+val* var_recv /* var recv: RuntimeVariable */;
 long var10 /* : Int */;
-val* var11 /* : Discrete */;
-val* var12 /* : Discrete */;
-val* var13 /* : Iterator[nullable Object] */;
-short int var14 /* : Bool */;
-val* var15 /* : nullable Object */;
 long var_i /* var i: Int */;
-long var16 /* : Int */;
-val* var17 /* : nullable MSignature */;
-long var18 /* : Int */;
-short int var19 /* : Bool */;
-short int var21 /* : Bool */;
-val* var22 /* : MProperty */;
-val* var23 /* : MPropDef */;
+val* var_ /* var : Array[MProperty] */;
+val* var11 /* : ArrayIterator[nullable Object] */;
+val* var_12 /* var : ArrayIterator[MProperty] */;
+short int var13 /* : Bool */;
+val* var14 /* : nullable Object */;
+val* var_p /* var p: MProperty */;
+short int var15 /* : Bool */;
+int cltype;
+int idtype;
+val* var16 /* : Array[RuntimeVariable] */;
+long var17 /* : Int */;
+val* var_18 /* var : Array[RuntimeVariable] */;
+val* var_args /* var args: Array[RuntimeVariable] */;
+val* var19 /* : MPropDef */;
+val* var21 /* : MPropDef */;
+val* var22 /* : nullable MSignature */;
 val* var24 /* : nullable MSignature */;
 val* var25 /* : Array[MParameter] */;
-val* var26 /* : nullable Object */;
-val* var27 /* : MType */;
-val* var_origmtype /* var origmtype: MType */;
-short int var28 /* : Bool */;
-short int var29 /* : Bool */;
-val* var30 /* : nullable MSignature */;
-val* var31 /* : Array[MParameter] */;
+val* var27 /* : Array[MParameter] */;
+val* var_28 /* var : Array[MParameter] */;
+val* var29 /* : ArrayIterator[nullable Object] */;
+val* var_30 /* var : ArrayIterator[MParameter] */;
+short int var31 /* : Bool */;
 val* var32 /* : nullable Object */;
-val* var33 /* : MType */;
-val* var_mtype /* var mtype: MType */;
-static val* varonce;
-val* var34 /* : String */;
-char* var35 /* : NativeString */;
-long var36 /* : Int */;
-val* var37 /* : String */;
-static val* varonce38;
-val* var39 /* : String */;
-char* var40 /* : NativeString */;
-long var41 /* : Int */;
-val* var42 /* : String */;
-val* var43 /* : nullable MSignature */;
-val* var44 /* : Array[MParameter] */;
-val* var45 /* : nullable Object */;
-val* var46 /* : String */;
-static val* varonce47;
-val* var48 /* : String */;
-char* var49 /* : NativeString */;
-long var50 /* : Int */;
-val* var51 /* : String */;
-long var52 /* : Int */;
-long var53 /* : Int */;
-long var55 /* : Int */;
-val* var56 /* : nullable Object */;
-val* var57 /* : String */;
-static val* varonce58;
-val* var59 /* : String */;
-char* var60 /* : NativeString */;
-long var61 /* : Int */;
-val* var62 /* : String */;
-static val* varonce63;
-val* var64 /* : String */;
-char* var65 /* : NativeString */;
-long var66 /* : Int */;
-val* var67 /* : String */;
-val* var68 /* : Array[Object] */;
-long var69 /* : Int */;
-val* var70 /* : NativeArray[Object] */;
-val* var71 /* : Object */;
-val* var72 /* : String */;
-long var73 /* : Int */;
-long var74 /* : Int */;
-long var76 /* : Int */;
-val* var77 /* : nullable Object */;
-static val* varonce78;
-val* var79 /* : String */;
-char* var80 /* : NativeString */;
-long var81 /* : Int */;
-val* var82 /* : String */;
-val* var83 /* : RuntimeVariable */;
-val* var_cond /* var cond: RuntimeVariable */;
-static val* varonce84;
-val* var85 /* : String */;
-char* var86 /* : NativeString */;
-long var87 /* : Int */;
-val* var88 /* : String */;
-static val* varonce89;
-val* var90 /* : String */;
-char* var91 /* : NativeString */;
-long var92 /* : Int */;
-val* var93 /* : String */;
-val* var94 /* : Array[Object] */;
-long var95 /* : Int */;
-val* var96 /* : NativeArray[Object] */;
-val* var97 /* : String */;
-static val* varonce98;
-val* var99 /* : String */;
-char* var100 /* : NativeString */;
-long var101 /* : Int */;
-val* var102 /* : String */;
-static val* varonce103;
-val* var104 /* : String */;
-char* var105 /* : NativeString */;
-long var106 /* : Int */;
-val* var107 /* : String */;
-/* Covariant cast for argument 0 (v) <p0:AbstractCompilerVisitor> isa VISITOR */
-/* <p0:AbstractCompilerVisitor> isa VISITOR */
-type_struct = self->type->resolution_table->types[COLOR_model__MPropDef_VTVISITOR];
-cltype = type_struct->color;
-idtype = type_struct->id;
-if(cltype >= p0->type->table_size) {
-var = 0;
-} else {
-var = p0->type->type_table[cltype] == idtype;
+val* var_x /* var x: MParameter */;
+val* var33 /* : nullable Object */;
+long var34 /* : Int */;
+long var35 /* : Int */;
+short int var37 /* : Bool */;
+int cltype38;
+int idtype39;
+const char* var_class_name;
+long var40 /* : Int */;
+val* var42 /* : nullable RuntimeVariable */;
+short int var43 /* : Bool */;
+int cltype44;
+int idtype45;
+val* var46 /* : nullable Object */;
+long var47 /* : Int */;
+long var48 /* : Int */;
+short int var50 /* : Bool */;
+int cltype51;
+int idtype52;
+const char* var_class_name53;
+long var54 /* : Int */;
+long var57 /* : Int */;
+long var59 /* : Int */;
+short int var60 /* : Bool */;
+short int var61 /* : Bool */;
+short int var63 /* : Bool */;
+val* var64 /* : MMethod */;
+val* var66 /* : MMethod */;
+val* var67 /* : Array[RuntimeVariable] */;
+long var68 /* : Int */;
+val* var_69 /* var : Array[RuntimeVariable] */;
+val* var70 /* : nullable RuntimeVariable */;
+val* var71 /* : MMethod */;
+val* var73 /* : MMethod */;
+val* var74 /* : nullable RuntimeVariable */;
+var_callsite = p0;
+var_arguments = p1;
+{
+{ /* Inline typing#CallSite#mpropdef (var_callsite) on <var_callsite:CallSite> */
+var3 = var_callsite->attrs[COLOR_typing__CallSite___mpropdef].val; /* _mpropdef on <var_callsite:CallSite> */
+if (unlikely(var3 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _mpropdef");
+PRINT_ERROR(" (%s:%d)\n", "semantize/typing.nit", 486);
+show_backtrace(1);
 }
-if (!var) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "src/abstract_compiler.nit", 1268);
-exit(1);
+var1 = var3;
+RET_LABEL2:(void)0;
 }
-var_v = p0;
-var_arguments = p1;
-var1 = ((val* (*)(val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__compiler]))(var_v) /* compiler on <var_v:AbstractCompilerVisitor>*/;
-var2 = ((val* (*)(val*))(var1->class->vft[COLOR_abstract_compiler__AbstractCompiler__modelbuilder]))(var1) /* modelbuilder on <var1:AbstractCompiler>*/;
-var3 = ((val* (*)(val*))(var2->class->vft[COLOR_modelbuilder__ModelBuilder__toolcontext]))(var2) /* toolcontext on <var2:ModelBuilder>*/;
-var4 = ((val* (*)(val*))(var3->class->vft[COLOR_abstract_compiler__ToolContext__opt_no_check_covariance]))(var3) /* opt_no_check_covariance on <var3:ToolContext>*/;
-var5 = ((val* (*)(val*))(var4->class->vft[COLOR_opts__Option__value]))(var4) /* value on <var4:OptionBool>*/;
-var6 = ((struct instance_kernel__Bool*)var5)->value; /* autounbox from nullable Object to Bool */;
-if (var6){
-goto RET_LABEL;
-} else {
 }
-var7 = NEW_range__Range(&type_range__Rangekernel__Int);
-var8 = 0;
-var9 = ((val* (*)(val*))(self->class->vft[COLOR_model__MMethodDef__msignature]))(self) /* msignature on <self:MMethodDef>*/;
-if (var9 == NULL) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Reciever is null", "src/abstract_compiler.nit", 1273);
-exit(1);
-} else {
-var10 = ((long (*)(val*))(var9->class->vft[COLOR_model__MSignature__arity]))(var9) /* arity on <var9:nullable MSignature>*/;
+{
+{ /* Inline model#MMethodDef#initializers (var1) on <var1:MMethodDef> */
+var6 = var1->attrs[COLOR_model__MMethodDef___initializers].val; /* _initializers on <var1:MMethodDef> */
+if (unlikely(var6 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _initializers");
+PRINT_ERROR(" (%s:%d)\n", "model/model.nit", 1967);
+show_backtrace(1);
+}
+var4 = var6;
+RET_LABEL5:(void)0;
 }
-var11 = BOX_kernel__Int(var8); /* autobox from Int to Discrete */
-var12 = BOX_kernel__Int(var10); /* autobox from Int to Discrete */
-((void (*)(val*, val*, val*))(var7->class->vft[COLOR_range__Range__without_last]))(var7, var11, var12) /* without_last on <var7:Range[Int]>*/;
-CHECK_NEW_range__Range(var7);
-var13 = ((val* (*)(val*))(var7->class->vft[COLOR_abstract_collection__Collection__iterator]))(var7) /* iterator on <var7:Range[Int]>*/;
+}
+var_initializers = var4;
+{
+var7 = array__AbstractArrayRead__is_empty(var_initializers);
+}
+var8 = !var7;
+if (var8){
+{
+var9 = abstract_collection__SequenceRead__first(var_arguments);
+}
+var_recv = var9;
+var10 = 1;
+var_i = var10;
+var_ = var_initializers;
+{
+var11 = array__AbstractArrayRead__iterator(var_);
+}
+var_12 = var11;
 for(;;) {
-var14 = ((short int (*)(val*))(var13->class->vft[COLOR_abstract_collection__Iterator__is_ok]))(var13) /* is_ok on <var13:Iterator[nullable Object]>*/;
-if(!var14) break;
-var15 = ((val* (*)(val*))(var13->class->vft[COLOR_abstract_collection__Iterator__item]))(var13) /* item on <var13:Iterator[nullable Object]>*/;
-var16 = ((struct instance_kernel__Int*)var15)->value; /* autounbox from nullable Object to Int */;
-var_i = var16;
-var17 = ((val* (*)(val*))(self->class->vft[COLOR_model__MMethodDef__msignature]))(self) /* msignature on <self:MMethodDef>*/;
-if (var17 == NULL) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Reciever is null", "src/abstract_compiler.nit", 1275);
-exit(1);
-} else {
-var18 = ((long (*)(val*))(var17->class->vft[COLOR_model__MSignature__vararg_rank]))(var17) /* vararg_rank on <var17:nullable MSignature>*/;
-}
-{ /* Inline kernel#Int#== (var18,var_i) */
-var21 = var18 == var_i;
+{
+var13 = array__ArrayIterator__is_ok(var_12);
+}
+if (var13){
+{
+var14 = array__ArrayIterator__item(var_12);
+}
+var_p = var14;
+/* <var_p:MProperty> isa MMethod */
+cltype = type_model__MMethod.color;
+idtype = type_model__MMethod.id;
+if(cltype >= var_p->type->table_size) {
+var15 = 0;
+} else {
+var15 = var_p->type->type_table[cltype] == idtype;
+}
+if (var15){
+var16 = NEW_array__Array(&type_array__Arrayabstract_compiler__RuntimeVariable);
+var17 = 1;
+{
+array__Array__with_capacity(var16, var17); /* Direct call array#Array#with_capacity on <var16:Array[RuntimeVariable]>*/
+}
+var_18 = var16;
+{
+array__AbstractArray__push(var_18, var_recv); /* Direct call array#AbstractArray#push on <var_18:Array[RuntimeVariable]>*/
+}
+var_args = var_18;
+{
+{ /* Inline model#MProperty#intro (var_p) on <var_p:MProperty(MMethod)> */
+var21 = var_p->attrs[COLOR_model__MProperty___intro].val; /* _intro on <var_p:MProperty(MMethod)> */
+if (unlikely(var21 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _intro");
+PRINT_ERROR(" (%s:%d)\n", "model/model.nit", 1649);
+show_backtrace(1);
+}
 var19 = var21;
-goto RET_LABEL20;
 RET_LABEL20:(void)0;
 }
-if (var19){
-goto CONTINUE_label;
-} else {
 }
-var22 = ((val* (*)(val*))(self->class->vft[COLOR_model__MPropDef__mproperty]))(self) /* mproperty on <self:MMethodDef>*/;
-var23 = ((val* (*)(val*))(var22->class->vft[COLOR_model__MProperty__intro]))(var22) /* intro on <var22:MProperty(MMethod)>*/;
-var24 = ((val* (*)(val*))(var23->class->vft[COLOR_model__MMethodDef__msignature]))(var23) /* msignature on <var23:MPropDef(MMethodDef)>*/;
-if (var24 == NULL) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Reciever is null", "src/abstract_compiler.nit", 1278);
-exit(1);
-} else {
-var25 = ((val* (*)(val*))(var24->class->vft[COLOR_model__MSignature__mparameters]))(var24) /* mparameters on <var24:nullable MSignature>*/;
+{
+{ /* Inline model#MMethodDef#msignature (var19) on <var19:MPropDef(MMethodDef)> */
+var24 = var19->attrs[COLOR_model__MMethodDef___msignature].val; /* _msignature on <var19:MPropDef(MMethodDef)> */
+var22 = var24;
+RET_LABEL23:(void)0;
 }
-var26 = ((val* (*)(val*, long))(var25->class->vft[COLOR_abstract_collection__SequenceRead___91d_93d]))(var25, var_i) /* [] on <var25:Array[MParameter]>*/;
-var27 = ((val* (*)(val*))(var26->class->vft[COLOR_model__MParameter__mtype]))(var26) /* mtype on <var26:nullable Object(MParameter)>*/;
-var_origmtype = var27;
-var28 = ((short int (*)(val*))(var_origmtype->class->vft[COLOR_model__MType__need_anchor]))(var_origmtype) /* need_anchor on <var_origmtype:MType>*/;
-var29 = !var28;
-if (var29){
-goto CONTINUE_label;
-} else {
 }
-var30 = ((val* (*)(val*))(self->class->vft[COLOR_model__MMethodDef__msignature]))(self) /* msignature on <self:MMethodDef>*/;
-if (var30 == NULL) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Reciever is null", "src/abstract_compiler.nit", 1282);
-exit(1);
+if (var22 == NULL) {
+PRINT_ERROR("Runtime error: %s", "Receiver is null");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 1084);
+show_backtrace(1);
 } else {
-var31 = ((val* (*)(val*))(var30->class->vft[COLOR_model__MSignature__mparameters]))(var30) /* mparameters on <var30:nullable MSignature>*/;
+{ /* Inline model#MSignature#mparameters (var22) on <var22:nullable MSignature> */
+if (unlikely(var22 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Receiver is null");
+PRINT_ERROR(" (%s:%d)\n", "model/model.nit", 1465);
+show_backtrace(1);
 }
-var32 = ((val* (*)(val*, long))(var31->class->vft[COLOR_abstract_collection__SequenceRead___91d_93d]))(var31, var_i) /* [] on <var31:Array[MParameter]>*/;
-var33 = ((val* (*)(val*))(var32->class->vft[COLOR_model__MParameter__mtype]))(var32) /* mtype on <var32:nullable Object(MParameter)>*/;
-var_mtype = var33;
-if (varonce) {
-var34 = varonce;
-} else {
-var35 = "/* Covariant cast for argument ";
-var36 = 31;
-var37 = string__NativeString__to_s_with_length(var35, var36);
-var34 = var37;
-varonce = var34;
-}
-if (varonce38) {
-var39 = varonce38;
-} else {
-var40 = " (";
-var41 = 2;
-var42 = string__NativeString__to_s_with_length(var40, var41);
-var39 = var42;
-varonce38 = var39;
-}
-var43 = ((val* (*)(val*))(self->class->vft[COLOR_model__MMethodDef__msignature]))(self) /* msignature on <self:MMethodDef>*/;
-if (var43 == NULL) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Reciever is null", "src/abstract_compiler.nit", 1286);
-exit(1);
-} else {
-var44 = ((val* (*)(val*))(var43->class->vft[COLOR_model__MSignature__mparameters]))(var43) /* mparameters on <var43:nullable MSignature>*/;
-}
-var45 = ((val* (*)(val*, long))(var44->class->vft[COLOR_abstract_collection__SequenceRead___91d_93d]))(var44, var_i) /* [] on <var44:Array[MParameter]>*/;
-var46 = ((val* (*)(val*))(var45->class->vft[COLOR_model__MParameter__name]))(var45) /* name on <var45:nullable Object(MParameter)>*/;
-if (varonce47) {
-var48 = varonce47;
-} else {
-var49 = ") ";
-var50 = 2;
-var51 = string__NativeString__to_s_with_length(var49, var50);
-var48 = var51;
-varonce47 = var48;
-}
-var52 = 1;
-{ /* Inline kernel#Int#+ (var_i,var52) */
-var55 = var_i + var52;
-var53 = var55;
-goto RET_LABEL54;
-RET_LABEL54:(void)0;
-}
-var56 = ((val* (*)(val*, long))(var_arguments->class->vft[COLOR_abstract_collection__SequenceRead___91d_93d]))(var_arguments, var53) /* [] on <var_arguments:Array[RuntimeVariable]>*/;
-var57 = ((val* (*)(val*))(var56->class->vft[COLOR_string__Object__inspect]))(var56) /* inspect on <var56:nullable Object(RuntimeVariable)>*/;
-if (varonce58) {
-var59 = varonce58;
-} else {
-var60 = " isa ";
-var61 = 5;
-var62 = string__NativeString__to_s_with_length(var60, var61);
-var59 = var62;
-varonce58 = var59;
-}
-if (varonce63) {
-var64 = varonce63;
-} else {
-var65 = " */";
-var66 = 3;
-var67 = string__NativeString__to_s_with_length(var65, var66);
-var64 = var67;
-varonce63 = var64;
-}
-var68 = NEW_array__Array(&type_array__Arraykernel__Object);
-{ /* var68 = array_instance Array[Object] */
-var69 = 9;
-var70 = NEW_array__NativeArray(var69, &type_array__NativeArraykernel__Object);
-((struct instance_array__NativeArray*)var70)->values[0] = (val*) var34;
-var71 = BOX_kernel__Int(var_i); /* autobox from Int to Object */
-((struct instance_array__NativeArray*)var70)->values[1] = (val*) var71;
-((struct instance_array__NativeArray*)var70)->values[2] = (val*) var39;
-((struct instance_array__NativeArray*)var70)->values[3] = (val*) var46;
-((struct instance_array__NativeArray*)var70)->values[4] = (val*) var48;
-((struct instance_array__NativeArray*)var70)->values[5] = (val*) var57;
-((struct instance_array__NativeArray*)var70)->values[6] = (val*) var59;
-((struct instance_array__NativeArray*)var70)->values[7] = (val*) var_mtype;
-((struct instance_array__NativeArray*)var70)->values[8] = (val*) var64;
-((void (*)(val*, val*, long))(var68->class->vft[COLOR_array__Array__with_native]))(var68, var70, var69) /* with_native on <var68:Array[Object]>*/;
-CHECK_NEW_array__Array(var68);
-}
-var72 = ((val* (*)(val*))(var68->class->vft[COLOR_string__Object__to_s]))(var68) /* to_s on <var68:Array[Object]>*/;
-((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(var_v, var72) /* add on <var_v:AbstractCompilerVisitor>*/;
-var73 = 1;
-{ /* Inline kernel#Int#+ (var_i,var73) */
-var76 = var_i + var73;
-var74 = var76;
-goto RET_LABEL75;
-RET_LABEL75:(void)0;
-}
-var77 = ((val* (*)(val*, long))(var_arguments->class->vft[COLOR_abstract_collection__SequenceRead___91d_93d]))(var_arguments, var74) /* [] on <var_arguments:Array[RuntimeVariable]>*/;
-if (varonce78) {
-var79 = varonce78;
-} else {
-var80 = "covariance";
-var81 = 10;
-var82 = string__NativeString__to_s_with_length(var80, var81);
-var79 = var82;
-varonce78 = var79;
-}
-var83 = ((val* (*)(val*, val*, val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__type_test]))(var_v, var77, var_mtype, var79) /* type_test on <var_v:AbstractCompilerVisitor>*/;
-var_cond = var83;
-if (varonce84) {
-var85 = varonce84;
-} else {
-var86 = "if (!";
-var87 = 5;
-var88 = string__NativeString__to_s_with_length(var86, var87);
-var85 = var88;
-varonce84 = var85;
-}
-if (varonce89) {
-var90 = varonce89;
-} else {
-var91 = ") {";
-var92 = 3;
-var93 = string__NativeString__to_s_with_length(var91, var92);
-var90 = var93;
-varonce89 = var90;
-}
-var94 = NEW_array__Array(&type_array__Arraykernel__Object);
-{ /* var94 = array_instance Array[Object] */
-var95 = 3;
-var96 = NEW_array__NativeArray(var95, &type_array__NativeArraykernel__Object);
-((struct instance_array__NativeArray*)var96)->values[0] = (val*) var85;
-((struct instance_array__NativeArray*)var96)->values[1] = (val*) var_cond;
-((struct instance_array__NativeArray*)var96)->values[2] = (val*) var90;
-((void (*)(val*, val*, long))(var94->class->vft[COLOR_array__Array__with_native]))(var94, var96, var95) /* with_native on <var94:Array[Object]>*/;
-CHECK_NEW_array__Array(var94);
-}
-var97 = ((val* (*)(val*))(var94->class->vft[COLOR_string__Object__to_s]))(var94) /* to_s on <var94:Array[Object]>*/;
-((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(var_v, var97) /* add on <var_v:AbstractCompilerVisitor>*/;
-if (varonce98) {
-var99 = varonce98;
-} else {
-var100 = "Cast failed";
-var101 = 11;
-var102 = string__NativeString__to_s_with_length(var100, var101);
-var99 = var102;
-varonce98 = var99;
+var27 = var22->attrs[COLOR_model__MSignature___mparameters].val; /* _mparameters on <var22:nullable MSignature> */
+if (unlikely(var27 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _mparameters");
+PRINT_ERROR(" (%s:%d)\n", "model/model.nit", 1465);
+show_backtrace(1);
 }
-((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add_abort]))(var_v, var99) /* add_abort on <var_v:AbstractCompilerVisitor>*/;
-if (varonce103) {
-var104 = varonce103;
-} else {
-var105 = "}";
-var106 = 1;
-var107 = string__NativeString__to_s_with_length(var105, var106);
-var104 = var107;
-varonce103 = var104;
+var25 = var27;
+RET_LABEL26:(void)0;
 }
-((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(var_v, var104) /* add on <var_v:AbstractCompilerVisitor>*/;
-CONTINUE_label: (void)0;
-((void (*)(val*))(var13->class->vft[COLOR_abstract_collection__Iterator__next]))(var13) /* next on <var13:Iterator[nullable Object]>*/;
 }
-BREAK_label: (void)0;
-RET_LABEL:;
+var_28 = var25;
+{
+var29 = array__AbstractArrayRead__iterator(var_28);
 }
-/* method abstract_compiler#MMethodDef#compile_parameter_check for (self: Object, AbstractCompilerVisitor, Array[RuntimeVariable]) */
-void VIRTUAL_abstract_compiler__MMethodDef__compile_parameter_check(val* self, val* p0, val* p1) {
-abstract_compiler__MMethodDef__compile_parameter_check(self, p0, p1);
-RET_LABEL:;
+var_30 = var29;
+for(;;) {
+{
+var31 = array__ArrayIterator__is_ok(var_30);
 }
-/* method abstract_compiler#APropdef#compile_to_c for (self: APropdef, AbstractCompilerVisitor, MMethodDef, Array[RuntimeVariable]) */
-void abstract_compiler__APropdef__compile_to_c(val* self, val* p0, val* p1, val* p2) {
-val* var_v /* var v: AbstractCompilerVisitor */;
-val* var_mpropdef /* var mpropdef: MMethodDef */;
-val* var_arguments /* var arguments: Array[RuntimeVariable] */;
-static val* varonce;
-val* var /* : String */;
-char* var1 /* : NativeString */;
-long var2 /* : Int */;
-val* var3 /* : String */;
-val* var4 /* : String */;
-static val* varonce5;
-val* var6 /* : String */;
-char* var7 /* : NativeString */;
-long var8 /* : Int */;
-val* var9 /* : String */;
-static val* varonce10;
-val* var11 /* : String */;
-char* var12 /* : NativeString */;
-long var13 /* : Int */;
-val* var14 /* : String */;
-val* var15 /* : Location */;
-val* var16 /* : String */;
-static val* varonce17;
-val* var18 /* : String */;
-char* var19 /* : NativeString */;
-long var20 /* : Int */;
-val* var21 /* : String */;
-val* var22 /* : Array[Object] */;
-long var23 /* : Int */;
-val* var24 /* : NativeArray[Object] */;
-val* var25 /* : String */;
-static val* varonce26;
-val* var27 /* : String */;
-char* var28 /* : NativeString */;
-long var29 /* : Int */;
-val* var30 /* : String */;
-var_v = p0;
-var_mpropdef = p1;
-var_arguments = p2;
-if (varonce) {
-var = varonce;
-} else {
-var1 = "printf(\"NOT YET IMPLEMENTED ";
-var2 = 28;
-var3 = string__NativeString__to_s_with_length(var1, var2);
-var = var3;
-varonce = var;
+if (var31){
+{
+var32 = array__ArrayIterator__item(var_30);
 }
-var4 = ((val* (*)(val*))(self->class->vft[COLOR_string__Object__class_name]))(self) /* class_name on <self:APropdef>*/;
-if (varonce5) {
-var6 = varonce5;
-} else {
-var7 = " ";
-var8 = 1;
-var9 = string__NativeString__to_s_with_length(var7, var8);
-var6 = var9;
-varonce5 = var6;
+var_x = var32;
+{
+var33 = array__Array___91d_93d(var_arguments, var_i);
 }
-if (varonce10) {
-var11 = varonce10;
-} else {
-var12 = " at ";
-var13 = 4;
-var14 = string__NativeString__to_s_with_length(var12, var13);
-var11 = var14;
-varonce10 = var11;
+{
+array__Array__add(var_args, var33); /* Direct call array#Array#add on <var_args:Array[RuntimeVariable]>*/
 }
-var15 = ((val* (*)(val*))(self->class->vft[COLOR_parser_nodes__ANode__location]))(self) /* location on <self:APropdef>*/;
-var16 = ((val* (*)(val*))(var15->class->vft[COLOR_string__Object__to_s]))(var15) /* to_s on <var15:Location>*/;
-if (varonce17) {
-var18 = varonce17;
-} else {
-var19 = "\\n\");";
-var20 = 5;
-var21 = string__NativeString__to_s_with_length(var19, var20);
-var18 = var21;
-varonce17 = var18;
+var34 = 1;
+{
+{ /* Inline kernel#Int#+ (var_i,var34) on <var_i:Int> */
+/* Covariant cast for argument 0 (i) <var34:Int> isa OTHER */
+/* <var34:Int> isa OTHER */
+var37 = 1; /* easy <var34:Int> isa OTHER*/
+if (unlikely(!var37)) {
+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);
+}
+var40 = var_i + var34;
+var35 = var40;
+goto RET_LABEL36;
+RET_LABEL36:(void)0;
+}
+}
+var_i = var35;
+{
+array__ArrayIterator__next(var_30); /* Direct call array#ArrayIterator#next on <var_30:ArrayIterator[MParameter]>*/
 }
-var22 = NEW_array__Array(&type_array__Arraykernel__Object);
-{ /* var22 = array_instance Array[Object] */
-var23 = 7;
-var24 = NEW_array__NativeArray(var23, &type_array__NativeArraykernel__Object);
-((struct instance_array__NativeArray*)var24)->values[0] = (val*) var;
-((struct instance_array__NativeArray*)var24)->values[1] = (val*) var4;
-((struct instance_array__NativeArray*)var24)->values[2] = (val*) var6;
-((struct instance_array__NativeArray*)var24)->values[3] = (val*) var_mpropdef;
-((struct instance_array__NativeArray*)var24)->values[4] = (val*) var11;
-((struct instance_array__NativeArray*)var24)->values[5] = (val*) var16;
-((struct instance_array__NativeArray*)var24)->values[6] = (val*) var18;
-((void (*)(val*, val*, long))(var22->class->vft[COLOR_array__Array__with_native]))(var22, var24, var23) /* with_native on <var22:Array[Object]>*/;
-CHECK_NEW_array__Array(var22);
-}
-var25 = ((val* (*)(val*))(var22->class->vft[COLOR_string__Object__to_s]))(var22) /* to_s on <var22:Array[Object]>*/;
-((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(var_v, var25) /* add on <var_v:AbstractCompilerVisitor>*/;
-if (varonce26) {
-var27 = varonce26;
 } else {
-var28 = "Not yet implemented";
-var29 = 19;
-var30 = string__NativeString__to_s_with_length(var28, var29);
-var27 = var30;
-varonce26 = var27;
+goto BREAK_label;
 }
-((void (*)(val*, val*))(self->class->vft[COLOR_parser_nodes__ANode__debug]))(self, var27) /* debug on <self:APropdef>*/;
-RET_LABEL:;
 }
-/* method abstract_compiler#APropdef#compile_to_c for (self: Object, AbstractCompilerVisitor, MMethodDef, Array[RuntimeVariable]) */
-void VIRTUAL_abstract_compiler__APropdef__compile_to_c(val* self, val* p0, val* p1, val* p2) {
-abstract_compiler__APropdef__compile_to_c(self, p0, p1, p2);
-RET_LABEL:;
+BREAK_label: (void)0;
+{
+{ /* Inline abstract_collection#Iterator#finish (var_30) on <var_30:ArrayIterator[MParameter]> */
+RET_LABEL41:(void)0;
 }
-/* method abstract_compiler#APropdef#can_inline for (self: APropdef): Bool */
-short int abstract_compiler__APropdef__can_inline(val* self) {
-short int var /* : Bool */;
-short int var1 /* : Bool */;
-var1 = 1;
-var = var1;
-goto RET_LABEL;
-RET_LABEL:;
-return var;
 }
-/* method abstract_compiler#APropdef#can_inline for (self: Object): Bool */
-short int VIRTUAL_abstract_compiler__APropdef__can_inline(val* self) {
-short int var /* : Bool */;
-short int var1 /* : Bool */;
-var1 = abstract_compiler__APropdef__can_inline(self);
-var = var1;
-RET_LABEL:;
-return var;
+{
+var42 = separate_compiler__SeparateCompilerVisitor__send(self, var_p, var_args);
 }
-/* method abstract_compiler#AConcreteMethPropdef#compile_to_c for (self: AConcreteMethPropdef, AbstractCompilerVisitor, MMethodDef, Array[RuntimeVariable]) */
-void abstract_compiler__AConcreteMethPropdef__compile_to_c(val* self, val* p0, val* p1, val* p2) {
-val* var_v /* var v: AbstractCompilerVisitor */;
-val* var_mpropdef /* var mpropdef: MMethodDef */;
-val* var_arguments /* var arguments: Array[RuntimeVariable] */;
-val* var /* : Range[Int] */;
-long var1 /* : Int */;
-val* var2 /* : nullable MSignature */;
-long var3 /* : Int */;
-val* var4 /* : Discrete */;
-val* var5 /* : Discrete */;
-val* var6 /* : Iterator[nullable Object] */;
-short int var7 /* : Bool */;
-val* var8 /* : nullable Object */;
-long var_i /* var i: Int */;
-long var9 /* : Int */;
-val* var10 /* : nullable ASignature */;
-val* var11 /* : ANodes[AParam] */;
-val* var12 /* : nullable Object */;
-val* var13 /* : nullable Variable */;
-val* var_variable /* var variable: Variable */;
-val* var14 /* : RuntimeVariable */;
-long var15 /* : Int */;
-long var16 /* : Int */;
-long var18 /* : Int */;
-val* var19 /* : nullable Object */;
-val* var20 /* : nullable Array[MMethod] */;
-val* var_auto_super_inits /* var auto_super_inits: nullable Array[MMethod] */;
-val* var21 /* : null */;
-short int var22 /* : Bool */;
-val* var23 /* : Array[RuntimeVariable] */;
-long var24 /* : Int */;
-val* var_ /* var : Array[RuntimeVariable] */;
-val* var25 /* : nullable Object */;
-val* var_selfarg /* var selfarg: Array[RuntimeVariable] */;
-val* var26 /* : Iterator[nullable Object] */;
-short int var27 /* : Bool */;
-val* var28 /* : nullable Object */;
-val* var_auto_super_init /* var auto_super_init: MMethod */;
-val* var29 /* : MPropDef */;
-val* var30 /* : nullable MSignature */;
-long var31 /* : Int */;
-long var32 /* : Int */;
-short int var33 /* : Bool */;
-short int var35 /* : Bool */;
-val* var36 /* : nullable RuntimeVariable */;
-val* var37 /* : nullable RuntimeVariable */;
-val* var39 /* : nullable AExpr */;
-var_v = p0;
-var_mpropdef = p1;
-var_arguments = p2;
-var = NEW_range__Range(&type_range__Rangekernel__Int);
-var1 = 0;
-var2 = ((val* (*)(val*))(var_mpropdef->class->vft[COLOR_model__MMethodDef__msignature]))(var_mpropdef) /* msignature on <var_mpropdef:MMethodDef>*/;
-if (var2 == NULL) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Reciever is null", "src/abstract_compiler.nit", 1310);
-exit(1);
-} else {
-var3 = ((long (*)(val*))(var2->class->vft[COLOR_model__MSignature__arity]))(var2) /* arity on <var2:nullable MSignature>*/;
-}
-var4 = BOX_kernel__Int(var1); /* autobox from Int to Discrete */
-var5 = BOX_kernel__Int(var3); /* autobox from Int to Discrete */
-((void (*)(val*, val*, val*))(var->class->vft[COLOR_range__Range__without_last]))(var, var4, var5) /* without_last on <var:Range[Int]>*/;
-CHECK_NEW_range__Range(var);
-var6 = ((val* (*)(val*))(var->class->vft[COLOR_abstract_collection__Collection__iterator]))(var) /* iterator on <var:Range[Int]>*/;
-for(;;) {
-var7 = ((short int (*)(val*))(var6->class->vft[COLOR_abstract_collection__Iterator__is_ok]))(var6) /* is_ok on <var6:Iterator[nullable Object]>*/;
-if(!var7) break;
-var8 = ((val* (*)(val*))(var6->class->vft[COLOR_abstract_collection__Iterator__item]))(var6) /* item on <var6:Iterator[nullable Object]>*/;
-var9 = ((struct instance_kernel__Int*)var8)->value; /* autounbox from nullable Object to Int */;
-var_i = var9;
-var10 = ((val* (*)(val*))(self->class->vft[COLOR_parser_nodes__AMethPropdef__n_signature]))(self) /* n_signature on <self:AConcreteMethPropdef>*/;
-if (var10 == NULL) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Reciever is null", "src/abstract_compiler.nit", 1311);
-exit(1);
-} else {
-var11 = ((val* (*)(val*))(var10->class->vft[COLOR_parser_nodes__ASignature__n_params]))(var10) /* n_params on <var10:nullable ASignature>*/;
-}
-var12 = ((val* (*)(val*, long))(var11->class->vft[COLOR_abstract_collection__SequenceRead___91d_93d]))(var11, var_i) /* [] on <var11:ANodes[AParam]>*/;
-var13 = ((val* (*)(val*))(var12->class->vft[COLOR_scope__AParam__variable]))(var12) /* variable on <var12:nullable Object(AParam)>*/;
-if (var13 == NULL) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "src/abstract_compiler.nit", 1311);
-exit(1);
-}
-var_variable = var13;
-var14 = ((val* (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__variable]))(var_v, var_variable) /* variable on <var_v:AbstractCompilerVisitor>*/;
-var15 = 1;
-{ /* Inline kernel#Int#+ (var_i,var15) */
-var18 = var_i + var15;
-var16 = var18;
-goto RET_LABEL17;
-RET_LABEL17:(void)0;
+} else {
+/* <var_p:MProperty> isa MAttribute */
+cltype44 = type_model__MAttribute.color;
+idtype45 = type_model__MAttribute.id;
+if(cltype44 >= var_p->type->table_size) {
+var43 = 0;
+} else {
+var43 = var_p->type->type_table[cltype44] == idtype45;
+}
+if (var43){
+{
+var46 = array__Array___91d_93d(var_arguments, var_i);
+}
+{
+separate_compiler__SeparateCompilerVisitor__write_attribute(self, var_p, var_recv, var46); /* Direct call separate_compiler#SeparateCompilerVisitor#write_attribute on <self:AbstractCompilerVisitor>*/
 }
-var19 = ((val* (*)(val*, long))(var_arguments->class->vft[COLOR_abstract_collection__SequenceRead___91d_93d]))(var_arguments, var16) /* [] on <var_arguments:Array[RuntimeVariable]>*/;
-((void (*)(val*, val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__assign]))(var_v, var14, var19) /* assign on <var_v:AbstractCompilerVisitor>*/;
-CONTINUE_label: (void)0;
-((void (*)(val*))(var6->class->vft[COLOR_abstract_collection__Iterator__next]))(var6) /* next on <var6:Iterator[nullable Object]>*/;
+var47 = 1;
+{
+{ /* Inline kernel#Int#+ (var_i,var47) on <var_i:Int> */
+/* Covariant cast for argument 0 (i) <var47:Int> isa OTHER */
+/* <var47:Int> isa OTHER */
+var50 = 1; /* easy <var47:Int> isa OTHER*/
+if (unlikely(!var50)) {
+var_class_name53 = type_kernel__Int.name;
+PRINT_ERROR("Runtime error: Cast failed. Expected `%s`, got `%s`", "OTHER", var_class_name53);
+PRINT_ERROR(" (%s:%d)\n", "../lib/standard/kernel.nit", 374);
+show_backtrace(1);
 }
-BREAK_label: (void)0;
-var20 = ((val* (*)(val*))(self->class->vft[COLOR_auto_super_init__AConcreteMethPropdef__auto_super_inits]))(self) /* auto_super_inits on <self:AConcreteMethPropdef>*/;
-var_auto_super_inits = var20;
-var21 = NULL;
-if (var_auto_super_inits == NULL) {
-var22 = 0; /* is null */
-} else {
-var22 = 1; /* arg is null and recv is not */
-}
-if (var22){
-var23 = NEW_array__Array(&type_array__Arrayabstract_compiler__RuntimeVariable);
-var24 = 1;
-((void (*)(val*, long))(var23->class->vft[COLOR_array__Array__with_capacity]))(var23, var24) /* with_capacity on <var23:Array[RuntimeVariable]>*/;
-CHECK_NEW_array__Array(var23);
-var_ = var23;
-var25 = ((val* (*)(val*))(var_arguments->class->vft[COLOR_abstract_collection__Collection__first]))(var_arguments) /* first on <var_arguments:Array[RuntimeVariable]>*/;
-((void (*)(val*, val*))(var_->class->vft[COLOR_abstract_collection__Sequence__push]))(var_, var25) /* push on <var_:Array[RuntimeVariable]>*/;
-var_selfarg = var_;
-var26 = ((val* (*)(val*))(var_auto_super_inits->class->vft[COLOR_abstract_collection__Collection__iterator]))(var_auto_super_inits) /* iterator on <var_auto_super_inits:nullable Array[MMethod](Array[MMethod])>*/;
-for(;;) {
-var27 = ((short int (*)(val*))(var26->class->vft[COLOR_abstract_collection__Iterator__is_ok]))(var26) /* is_ok on <var26:Iterator[nullable Object]>*/;
-if(!var27) break;
-var28 = ((val* (*)(val*))(var26->class->vft[COLOR_abstract_collection__Iterator__item]))(var26) /* item on <var26:Iterator[nullable Object]>*/;
-var_auto_super_init = var28;
-var29 = ((val* (*)(val*))(var_auto_super_init->class->vft[COLOR_model__MProperty__intro]))(var_auto_super_init) /* intro on <var_auto_super_init:MMethod>*/;
-var30 = ((val* (*)(val*))(var29->class->vft[COLOR_model__MMethodDef__msignature]))(var29) /* msignature on <var29:MPropDef(MMethodDef)>*/;
-if (var30 == NULL) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Reciever is null", "src/abstract_compiler.nit", 1319);
-exit(1);
-} else {
-var31 = ((long (*)(val*))(var30->class->vft[COLOR_model__MSignature__arity]))(var30) /* arity on <var30:nullable MSignature>*/;
-}
-var32 = 0;
-{ /* Inline kernel#Int#== (var31,var32) */
-var35 = var31 == var32;
-var33 = var35;
-goto RET_LABEL34;
-RET_LABEL34:(void)0;
+var54 = var_i + var47;
+var48 = var54;
+goto RET_LABEL49;
+RET_LABEL49:(void)0;
 }
-if (var33){
-var36 = ((val* (*)(val*, val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__send]))(var_v, var_auto_super_init, var_selfarg) /* send on <var_v:AbstractCompilerVisitor>*/;
-var36;
+}
+var_i = var48;
 } else {
-var37 = ((val* (*)(val*, val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__send]))(var_v, var_auto_super_init, var_arguments) /* send on <var_v:AbstractCompilerVisitor>*/;
-var37;
+PRINT_ERROR("Runtime error: %s", "Aborted");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 1092);
+show_backtrace(1);
+}
 }
-CONTINUE_label38: (void)0;
-((void (*)(val*))(var26->class->vft[COLOR_abstract_collection__Iterator__next]))(var26) /* next on <var26:Iterator[nullable Object]>*/;
+{
+array__ArrayIterator__next(var_12); /* Direct call array#ArrayIterator#next on <var_12:ArrayIterator[MProperty]>*/
 }
-BREAK_label38: (void)0;
 } else {
+goto BREAK_label55;
 }
-var39 = ((val* (*)(val*))(self->class->vft[COLOR_parser_nodes__AConcreteMethPropdef__n_block]))(self) /* n_block on <self:AConcreteMethPropdef>*/;
-((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__stmt]))(var_v, var39) /* stmt on <var_v:AbstractCompilerVisitor>*/;
-RET_LABEL:;
 }
-/* method abstract_compiler#AConcreteMethPropdef#compile_to_c for (self: Object, AbstractCompilerVisitor, MMethodDef, Array[RuntimeVariable]) */
-void VIRTUAL_abstract_compiler__AConcreteMethPropdef__compile_to_c(val* self, val* p0, val* p1, val* p2) {
-abstract_compiler__AConcreteMethPropdef__compile_to_c(self, p0, p1, p2);
-RET_LABEL:;
+BREAK_label55: (void)0;
+{
+{ /* Inline abstract_collection#Iterator#finish (var_12) on <var_12:ArrayIterator[MProperty]> */
+RET_LABEL56:(void)0;
 }
-/* method abstract_compiler#AConcreteMethPropdef#can_inline for (self: AConcreteMethPropdef): Bool */
-short int abstract_compiler__AConcreteMethPropdef__can_inline(val* self) {
-short int var /* : Bool */;
-val* var1 /* : nullable Array[MMethod] */;
-val* var2 /* : null */;
-short int var3 /* : Bool */;
-short int var4 /* : Bool */;
-val* var5 /* : nullable AExpr */;
-val* var_nblock /* var nblock: nullable AExpr */;
-val* var6 /* : null */;
-short int var7 /* : Bool */;
-short int var8 /* : Bool */;
-short int var9 /* : Bool */;
-short int var10 /* : Bool */;
-val* var11 /* : nullable MPropDef */;
-val* var12 /* : MProperty */;
-val* var13 /* : String */;
-static val* varonce;
-val* var14 /* : String */;
-char* var15 /* : NativeString */;
-long var16 /* : Int */;
-val* var17 /* : String */;
-short int var18 /* : Bool */;
-short int var_ /* var : Bool */;
-val* var19 /* : nullable MPropDef */;
-val* var20 /* : MProperty */;
-val* var21 /* : String */;
-static val* varonce22;
-val* var23 /* : String */;
-char* var24 /* : NativeString */;
-long var25 /* : Int */;
-val* var26 /* : String */;
-short int var27 /* : Bool */;
-short int var_28 /* var : Bool */;
-val* var29 /* : nullable MPropDef */;
-val* var30 /* : MClassDef */;
-val* var31 /* : MClass */;
-val* var32 /* : String */;
-static val* varonce33;
-val* var34 /* : String */;
-char* var35 /* : NativeString */;
-long var36 /* : Int */;
-val* var37 /* : String */;
-short int var38 /* : Bool */;
-short int var39 /* : Bool */;
-short int var40 /* : Bool */;
-short int var41 /* : Bool */;
-int cltype;
-int idtype;
-short int var_42 /* var : Bool */;
-val* var43 /* : ANodes[AExpr] */;
-long var44 /* : Int */;
-long var45 /* : Int */;
-short int var46 /* : Bool */;
-short int var48 /* : Bool */;
-short int var49 /* : Bool */;
-short int var50 /* : Bool */;
-var1 = ((val* (*)(val*))(self->class->vft[COLOR_auto_super_init__AConcreteMethPropdef__auto_super_inits]))(self) /* auto_super_inits on <self:AConcreteMethPropdef>*/;
-var2 = NULL;
-if (var1 == NULL) {
-var3 = 0; /* is null */
-} else {
-var3 = 1; /* arg is null and recv is not */
 }
-if (var3){
-var4 = 0;
-var = var4;
-goto RET_LABEL;
-} else {
+{
+{ /* Inline array#AbstractArrayRead#length (var_arguments) on <var_arguments:Array[RuntimeVariable]> */
+var59 = var_arguments->attrs[COLOR_array__AbstractArrayRead___length].l; /* _length on <var_arguments:Array[RuntimeVariable]> */
+var57 = var59;
+RET_LABEL58:(void)0;
 }
-var5 = ((val* (*)(val*))(self->class->vft[COLOR_parser_nodes__AConcreteMethPropdef__n_block]))(self) /* n_block on <self:AConcreteMethPropdef>*/;
-var_nblock = var5;
-var6 = NULL;
-if (var_nblock == NULL) {
-var7 = 1; /* is null */
-} else {
-var7 = 0; /* arg is null but recv is not */
 }
-if (var7){
-var8 = 1;
-var = var8;
-goto RET_LABEL;
-} else {
+{
+{ /* Inline kernel#Int#== (var_i,var57) on <var_i:Int> */
+var63 = var_i == var57;
+var61 = var63;
+goto RET_LABEL62;
+RET_LABEL62:(void)0;
 }
-var11 = ((val* (*)(val*))(self->class->vft[COLOR_modelize_property__APropdef__mpropdef]))(self) /* mpropdef on <self:AConcreteMethPropdef>*/;
-if (var11 == NULL) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Reciever is null", "src/abstract_compiler.nit", 1334);
-exit(1);
-} else {
-var12 = ((val* (*)(val*))(var11->class->vft[COLOR_model__MPropDef__mproperty]))(var11) /* mproperty on <var11:nullable MPropDef(nullable MMethodDef)>*/;
+var60 = var61;
 }
-var13 = ((val* (*)(val*))(var12->class->vft[COLOR_model__MProperty__name]))(var12) /* name on <var12:MProperty(MMethod)>*/;
-if (varonce) {
-var14 = varonce;
-} else {
-var15 = "==";
-var16 = 2;
-var17 = string__NativeString__to_s_with_length(var15, var16);
-var14 = var17;
-varonce = var14;
+if (unlikely(!var60)) {
+PRINT_ERROR("Runtime error: %s", "Assert failed");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 1094);
+show_backtrace(1);
 }
-var18 = ((short int (*)(val*, val*))(var13->class->vft[COLOR_kernel__Object___61d_61d]))(var13, var14) /* == on <var13:String>*/;
-var_ = var18;
-if (var18){
-var10 = var_;
-} else {
-var19 = ((val* (*)(val*))(self->class->vft[COLOR_modelize_property__APropdef__mpropdef]))(self) /* mpropdef on <self:AConcreteMethPropdef>*/;
-if (var19 == NULL) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Reciever is null", "src/abstract_compiler.nit", 1334);
-exit(1);
-} else {
-var20 = ((val* (*)(val*))(var19->class->vft[COLOR_model__MPropDef__mproperty]))(var19) /* mproperty on <var19:nullable MPropDef(nullable MMethodDef)>*/;
+{
+{ /* Inline typing#CallSite#mproperty (var_callsite) on <var_callsite:CallSite> */
+var66 = var_callsite->attrs[COLOR_typing__CallSite___mproperty].val; /* _mproperty on <var_callsite:CallSite> */
+if (unlikely(var66 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _mproperty");
+PRINT_ERROR(" (%s:%d)\n", "semantize/typing.nit", 483);
+show_backtrace(1);
 }
-var21 = ((val* (*)(val*))(var20->class->vft[COLOR_model__MProperty__name]))(var20) /* name on <var20:MProperty(MMethod)>*/;
-if (varonce22) {
-var23 = varonce22;
-} else {
-var24 = "!=";
-var25 = 2;
-var26 = string__NativeString__to_s_with_length(var24, var25);
-var23 = var26;
-varonce22 = var23;
+var64 = var66;
+RET_LABEL65:(void)0;
 }
-var27 = ((short int (*)(val*, val*))(var21->class->vft[COLOR_kernel__Object___61d_61d]))(var21, var23) /* == on <var21:String>*/;
-var10 = var27;
 }
-var_28 = var10;
-if (var10){
-var29 = ((val* (*)(val*))(self->class->vft[COLOR_modelize_property__APropdef__mpropdef]))(self) /* mpropdef on <self:AConcreteMethPropdef>*/;
-if (var29 == NULL) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Reciever is null", "src/abstract_compiler.nit", 1334);
-exit(1);
-} else {
-var30 = ((val* (*)(val*))(var29->class->vft[COLOR_model__MPropDef__mclassdef]))(var29) /* mclassdef on <var29:nullable MPropDef(nullable MMethodDef)>*/;
+var67 = NEW_array__Array(&type_array__Arrayabstract_compiler__RuntimeVariable);
+var68 = 1;
+{
+array__Array__with_capacity(var67, var68); /* Direct call array#Array#with_capacity on <var67:Array[RuntimeVariable]>*/
 }
-var31 = ((val* (*)(val*))(var30->class->vft[COLOR_model__MClassDef__mclass]))(var30) /* mclass on <var30:MClassDef>*/;
-var32 = ((val* (*)(val*))(var31->class->vft[COLOR_model__MClass__name]))(var31) /* name on <var31:MClass>*/;
-if (varonce33) {
-var34 = varonce33;
-} else {
-var35 = "Object";
-var36 = 6;
-var37 = string__NativeString__to_s_with_length(var35, var36);
-var34 = var37;
-varonce33 = var34;
+var_69 = var67;
+{
+array__AbstractArray__push(var_69, var_recv); /* Direct call array#AbstractArray#push on <var_69:Array[RuntimeVariable]>*/
 }
-var38 = ((short int (*)(val*, val*))(var32->class->vft[COLOR_kernel__Object___61d_61d]))(var32, var34) /* == on <var32:String>*/;
-var9 = var38;
-} else {
-var9 = var_28;
+{
+var70 = separate_compiler__SeparateCompilerVisitor__send(self, var64, var_69);
 }
-if (var9){
-var39 = 1;
-var = var39;
+var = var70;
 goto RET_LABEL;
 } else {
 }
-/* <var_nblock:nullable AExpr(AExpr)> isa ABlockExpr */
-cltype = type_parser_nodes__ABlockExpr.color;
-idtype = type_parser_nodes__ABlockExpr.id;
-if(cltype >= var_nblock->type->table_size) {
-var41 = 0;
-} else {
-var41 = var_nblock->type->type_table[cltype] == idtype;
+{
+{ /* Inline typing#CallSite#mproperty (var_callsite) on <var_callsite:CallSite> */
+var73 = var_callsite->attrs[COLOR_typing__CallSite___mproperty].val; /* _mproperty on <var_callsite:CallSite> */
+if (unlikely(var73 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _mproperty");
+PRINT_ERROR(" (%s:%d)\n", "semantize/typing.nit", 483);
+show_backtrace(1);
 }
-var_42 = var41;
-if (var41){
-var43 = ((val* (*)(val*))(var_nblock->class->vft[COLOR_parser_nodes__ABlockExpr__n_expr]))(var_nblock) /* n_expr on <var_nblock:nullable AExpr(ABlockExpr)>*/;
-var44 = ((long (*)(val*))(var43->class->vft[COLOR_abstract_collection__Collection__length]))(var43) /* length on <var43:ANodes[AExpr]>*/;
-var45 = 0;
-{ /* Inline kernel#Int#== (var44,var45) */
-var48 = var44 == var45;
-var46 = var48;
-goto RET_LABEL47;
-RET_LABEL47:(void)0;
+var71 = var73;
+RET_LABEL72:(void)0;
 }
-var40 = var46;
-} else {
-var40 = var_42;
 }
-if (var40){
-var49 = 1;
-var = var49;
-goto RET_LABEL;
-} else {
+{
+var74 = separate_compiler__SeparateCompilerVisitor__send(self, var71, var_arguments);
 }
-var50 = 0;
-var = var50;
+var = var74;
 goto RET_LABEL;
 RET_LABEL:;
 return var;
 }
-/* method abstract_compiler#AConcreteMethPropdef#can_inline for (self: Object): Bool */
-short int VIRTUAL_abstract_compiler__AConcreteMethPropdef__can_inline(val* self) {
-short int var /* : Bool */;
-short int var1 /* : Bool */;
-var1 = abstract_compiler__AConcreteMethPropdef__can_inline(self);
+/* method abstract_compiler#AbstractCompilerVisitor#compile_callsite for (self: Object, CallSite, Array[RuntimeVariable]): nullable RuntimeVariable */
+val* VIRTUAL_abstract_compiler__AbstractCompilerVisitor__compile_callsite(val* self, val* p0, val* p1) {
+val* var /* : nullable RuntimeVariable */;
+val* var1 /* : nullable RuntimeVariable */;
+var1 = abstract_compiler__AbstractCompilerVisitor__compile_callsite(self, p0, p1);
 var = var1;
 RET_LABEL:;
 return var;
 }
-/* method abstract_compiler#AInternMethPropdef#compile_to_c for (self: AInternMethPropdef, AbstractCompilerVisitor, MMethodDef, Array[RuntimeVariable]) */
-void abstract_compiler__AInternMethPropdef__compile_to_c(val* self, val* p0, val* p1, val* p2) {
-val* var_v /* var v: AbstractCompilerVisitor */;
+/* method abstract_compiler#AbstractCompilerVisitor#varargize for (self: AbstractCompilerVisitor, MMethodDef, RuntimeVariable, SequenceRead[AExpr]): Array[RuntimeVariable] */
+val* abstract_compiler__AbstractCompilerVisitor__varargize(val* self, val* p0, val* p1, val* p2) {
+val* var /* : Array[RuntimeVariable] */;
 val* var_mpropdef /* var mpropdef: MMethodDef */;
-val* var_arguments /* var arguments: Array[RuntimeVariable] */;
-val* var /* : MProperty */;
-val* var1 /* : String */;
-val* var_pname /* var pname: String */;
-val* var2 /* : MClassDef */;
-val* var3 /* : MClass */;
-val* var4 /* : String */;
-val* var_cname /* var cname: String */;
+val* var_recv /* var recv: RuntimeVariable */;
+val* var_args /* var args: SequenceRead[AExpr] */;
+val* var1 /* : MSignature */;
+val* var2 /* : nullable MSignature */;
+val* var4 /* : nullable MSignature */;
 val* var5 /* : nullable MSignature */;
-val* var6 /* : nullable MType */;
-val* var_ret /* var ret: nullable MType */;
-val* var7 /* : null */;
-short int var8 /* : Bool */;
-val* var9 /* : nullable Object */;
-val* var10 /* : MType */;
-short int var11 /* : Bool */;
-static val* varonce;
-val* var12 /* : String */;
-char* var13 /* : NativeString */;
+val* var7 /* : nullable MSignature */;
+val* var_msignature /* var msignature: MSignature */;
+val* var8 /* : Array[RuntimeVariable] */;
+val* var_res /* var res: Array[RuntimeVariable] */;
+short int var9 /* : Bool */;
+long var10 /* : Int */;
+long var12 /* : Int */;
+long var_vararg_rank /* var vararg_rank: Int */;
+long var13 /* : Int */;
 long var14 /* : Int */;
-val* var15 /* : String */;
-short int var16 /* : Bool */;
-short int var_ /* var : Bool */;
-static val* varonce17;
-val* var18 /* : String */;
-char* var19 /* : NativeString */;
-long var20 /* : Int */;
-val* var21 /* : String */;
-short int var22 /* : Bool */;
-static val* varonce23;
-val* var24 /* : String */;
-char* var25 /* : NativeString */;
-long var26 /* : Int */;
-val* var27 /* : String */;
-short int var28 /* : Bool */;
-static val* varonce29;
-val* var30 /* : String */;
-char* var31 /* : NativeString */;
-long var32 /* : Int */;
-val* var33 /* : String */;
-short int var34 /* : Bool */;
-static val* varonce35;
-val* var36 /* : String */;
-char* var37 /* : NativeString */;
-long var38 /* : Int */;
-val* var39 /* : String */;
-val* var40 /* : nullable Object */;
-static val* varonce41;
-val* var42 /* : String */;
-char* var43 /* : NativeString */;
-long var44 /* : Int */;
-val* var45 /* : String */;
-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 /* : String */;
-short int var55 /* : Bool */;
-val* var56 /* : nullable Object */;
-static val* varonce57;
-val* var58 /* : String */;
-char* var59 /* : NativeString */;
-long var60 /* : Int */;
-val* var61 /* : String */;
-short int var62 /* : Bool */;
-long var63 /* : Int */;
-val* var64 /* : nullable Object */;
-static val* varonce65;
-val* var66 /* : String */;
-char* var67 /* : NativeString */;
-long var68 /* : Int */;
-val* var69 /* : String */;
-long var70 /* : Int */;
-val* var71 /* : nullable Object */;
-val* var72 /* : Array[Object] */;
-long var73 /* : Int */;
-val* var74 /* : NativeArray[Object] */;
-val* var75 /* : String */;
-val* var76 /* : RuntimeVariable */;
-static val* varonce77;
-val* var78 /* : String */;
-char* var79 /* : NativeString */;
-long var80 /* : Int */;
-val* var81 /* : String */;
-short int var82 /* : Bool */;
-long var83 /* : Int */;
-val* var84 /* : nullable Object */;
-static val* varonce85;
-val* var86 /* : String */;
-char* var87 /* : NativeString */;
-long var88 /* : Int */;
-val* var89 /* : String */;
-long var90 /* : Int */;
-val* var91 /* : nullable Object */;
-val* var92 /* : Array[Object] */;
-long var93 /* : Int */;
-val* var94 /* : NativeArray[Object] */;
-val* var95 /* : String */;
-val* var96 /* : RuntimeVariable */;
-static val* varonce97;
-val* var98 /* : String */;
-char* var99 /* : NativeString */;
-long var100 /* : Int */;
-val* var101 /* : String */;
-short int var102 /* : Bool */;
-static val* varonce103;
-val* var104 /* : String */;
-char* var105 /* : NativeString */;
-long var106 /* : Int */;
-val* var107 /* : String */;
-long var108 /* : Int */;
-val* var109 /* : nullable Object */;
-val* var110 /* : Array[Object] */;
-long var111 /* : Int */;
-val* var112 /* : NativeArray[Object] */;
-val* var113 /* : String */;
-val* var114 /* : RuntimeVariable */;
-static val* varonce115;
-val* var116 /* : String */;
-char* var117 /* : NativeString */;
-long var118 /* : Int */;
-val* var119 /* : String */;
-short int var120 /* : Bool */;
-long var121 /* : Int */;
-val* var122 /* : nullable Object */;
-static val* varonce123;
-val* var124 /* : String */;
-char* var125 /* : NativeString */;
-long var126 /* : Int */;
-val* var127 /* : String */;
-val* var128 /* : Array[Object] */;
-long var129 /* : Int */;
-val* var130 /* : NativeArray[Object] */;
-val* var131 /* : String */;
-val* var132 /* : RuntimeVariable */;
-static val* varonce133;
-val* var134 /* : String */;
-char* var135 /* : NativeString */;
-long var136 /* : Int */;
-val* var137 /* : String */;
-short int var138 /* : Bool */;
-long var139 /* : Int */;
-val* var140 /* : nullable Object */;
-static val* varonce141;
-val* var142 /* : String */;
-char* var143 /* : NativeString */;
-long var144 /* : Int */;
-val* var145 /* : String */;
-val* var146 /* : Array[Object] */;
-long var147 /* : Int */;
-val* var148 /* : NativeArray[Object] */;
-val* var149 /* : String */;
-val* var150 /* : RuntimeVariable */;
-static val* varonce151;
-val* var152 /* : String */;
-char* var153 /* : NativeString */;
-long var154 /* : Int */;
-val* var155 /* : String */;
-short int var156 /* : Bool */;
-long var157 /* : Int */;
-val* var158 /* : nullable Object */;
-static val* varonce159;
-val* var160 /* : String */;
-char* var161 /* : NativeString */;
-long var162 /* : Int */;
-val* var163 /* : String */;
-long var164 /* : Int */;
-val* var165 /* : nullable Object */;
-val* var166 /* : Array[Object] */;
-long var167 /* : Int */;
-val* var168 /* : NativeArray[Object] */;
-val* var169 /* : String */;
-val* var170 /* : RuntimeVariable */;
-static val* varonce171;
-val* var172 /* : String */;
-char* var173 /* : NativeString */;
-long var174 /* : Int */;
-val* var175 /* : String */;
-short int var176 /* : Bool */;
-long var177 /* : Int */;
-val* var178 /* : nullable Object */;
-static val* varonce179;
-val* var180 /* : String */;
-char* var181 /* : NativeString */;
-long var182 /* : Int */;
-val* var183 /* : String */;
-long var184 /* : Int */;
-val* var185 /* : nullable Object */;
-val* var186 /* : Array[Object] */;
-long var187 /* : Int */;
-val* var188 /* : NativeArray[Object] */;
-val* var189 /* : String */;
-val* var190 /* : RuntimeVariable */;
-static val* varonce191;
-val* var192 /* : String */;
-char* var193 /* : NativeString */;
-long var194 /* : Int */;
-val* var195 /* : String */;
-short int var196 /* : Bool */;
-long var197 /* : Int */;
-val* var198 /* : nullable Object */;
-static val* varonce199;
-val* var200 /* : String */;
-char* var201 /* : NativeString */;
-long var202 /* : Int */;
-val* var203 /* : String */;
-long var204 /* : Int */;
-val* var205 /* : nullable Object */;
-val* var206 /* : Array[Object] */;
-long var207 /* : Int */;
-val* var208 /* : NativeArray[Object] */;
-val* var209 /* : String */;
-val* var210 /* : RuntimeVariable */;
-static val* varonce211;
-val* var212 /* : String */;
-char* var213 /* : NativeString */;
-long var214 /* : Int */;
-val* var215 /* : String */;
-short int var216 /* : Bool */;
-long var217 /* : Int */;
-val* var218 /* : nullable Object */;
-static val* varonce219;
-val* var220 /* : String */;
-char* var221 /* : NativeString */;
-long var222 /* : Int */;
-val* var223 /* : String */;
-long var224 /* : Int */;
-val* var225 /* : nullable Object */;
-val* var226 /* : Array[Object] */;
-long var227 /* : Int */;
-val* var228 /* : NativeArray[Object] */;
-val* var229 /* : String */;
-val* var230 /* : RuntimeVariable */;
-static val* varonce231;
-val* var232 /* : String */;
-char* var233 /* : NativeString */;
-long var234 /* : Int */;
-val* var235 /* : String */;
-short int var236 /* : Bool */;
-long var237 /* : Int */;
-val* var238 /* : nullable Object */;
-static val* varonce239;
-val* var240 /* : String */;
-char* var241 /* : NativeString */;
-long var242 /* : Int */;
-val* var243 /* : String */;
-long var244 /* : Int */;
-val* var245 /* : nullable Object */;
-val* var246 /* : Array[Object] */;
-long var247 /* : Int */;
-val* var248 /* : NativeArray[Object] */;
-val* var249 /* : String */;
-val* var250 /* : RuntimeVariable */;
-static val* varonce251;
-val* var252 /* : String */;
-char* var253 /* : NativeString */;
-long var254 /* : Int */;
-val* var255 /* : String */;
-short int var256 /* : Bool */;
-long var257 /* : Int */;
-val* var258 /* : nullable Object */;
-long var259 /* : Int */;
-val* var260 /* : nullable Object */;
-val* var261 /* : RuntimeVariable */;
-static val* varonce262;
-val* var263 /* : String */;
-char* var264 /* : NativeString */;
-long var265 /* : Int */;
-val* var266 /* : String */;
-short int var267 /* : Bool */;
-long var268 /* : Int */;
-val* var269 /* : nullable Object */;
-long var270 /* : Int */;
-val* var271 /* : nullable Object */;
-val* var272 /* : RuntimeVariable */;
-val* var_res /* var res: RuntimeVariable */;
-static val* varonce273;
-val* var274 /* : String */;
-char* var275 /* : NativeString */;
-long var276 /* : Int */;
-val* var277 /* : String */;
-val* var278 /* : Array[Object] */;
-long var279 /* : Int */;
-val* var280 /* : NativeArray[Object] */;
-val* var281 /* : String */;
-val* var282 /* : RuntimeVariable */;
-static val* varonce283;
-val* var284 /* : String */;
-char* var285 /* : NativeString */;
-long var286 /* : Int */;
-val* var287 /* : String */;
-short int var288 /* : Bool */;
-long var289 /* : Int */;
-val* var290 /* : nullable Object */;
-static val* varonce291;
-val* var292 /* : String */;
-char* var293 /* : NativeString */;
-long var294 /* : Int */;
-val* var295 /* : String */;
-long var296 /* : Int */;
-val* var297 /* : nullable Object */;
-val* var298 /* : Array[Object] */;
-long var299 /* : Int */;
-val* var300 /* : NativeArray[Object] */;
-val* var301 /* : String */;
-val* var302 /* : RuntimeVariable */;
-static val* varonce303;
-val* var304 /* : String */;
-char* var305 /* : NativeString */;
-long var306 /* : Int */;
-val* var307 /* : String */;
-short int var308 /* : Bool */;
-long var309 /* : Int */;
-val* var310 /* : nullable Object */;
-static val* varonce311;
-val* var312 /* : String */;
-char* var313 /* : NativeString */;
-long var314 /* : Int */;
-val* var315 /* : String */;
-long var316 /* : Int */;
-val* var317 /* : nullable Object */;
-val* var318 /* : Array[Object] */;
-long var319 /* : Int */;
-val* var320 /* : NativeArray[Object] */;
-val* var321 /* : String */;
-val* var322 /* : RuntimeVariable */;
-static val* varonce323;
-val* var324 /* : String */;
-char* var325 /* : NativeString */;
-long var326 /* : Int */;
-val* var327 /* : String */;
-short int var328 /* : Bool */;
-long var329 /* : Int */;
-val* var330 /* : nullable Object */;
-static val* varonce331;
-val* var332 /* : String */;
-char* var333 /* : NativeString */;
-long var334 /* : Int */;
-val* var335 /* : String */;
-long var336 /* : Int */;
-val* var337 /* : nullable Object */;
-val* var338 /* : Array[Object] */;
-long var339 /* : Int */;
-val* var340 /* : NativeArray[Object] */;
-val* var341 /* : String */;
-val* var342 /* : RuntimeVariable */;
-static val* varonce343;
-val* var344 /* : String */;
-char* var345 /* : NativeString */;
-long var346 /* : Int */;
-val* var347 /* : String */;
-short int var348 /* : Bool */;
-long var349 /* : Int */;
-val* var350 /* : nullable Object */;
-static val* varonce351;
-val* var352 /* : String */;
-char* var353 /* : NativeString */;
-long var354 /* : Int */;
-val* var355 /* : String */;
-long var356 /* : Int */;
-val* var357 /* : nullable Object */;
-val* var358 /* : Array[Object] */;
-long var359 /* : Int */;
-val* var360 /* : NativeArray[Object] */;
-val* var361 /* : String */;
-val* var362 /* : RuntimeVariable */;
-static val* varonce363;
-val* var364 /* : String */;
-char* var365 /* : NativeString */;
-long var366 /* : Int */;
-val* var367 /* : String */;
-short int var368 /* : Bool */;
-static val* varonce369;
-val* var370 /* : String */;
-char* var371 /* : NativeString */;
-long var372 /* : Int */;
-val* var373 /* : String */;
-long var374 /* : Int */;
-val* var375 /* : nullable Object */;
-val* var376 /* : Array[Object] */;
-long var377 /* : Int */;
-val* var378 /* : NativeArray[Object] */;
-val* var379 /* : String */;
-val* var380 /* : RuntimeVariable */;
-static val* varonce381;
-val* var382 /* : String */;
-char* var383 /* : NativeString */;
-long var384 /* : Int */;
-val* var385 /* : String */;
-short int var386 /* : Bool */;
-long var387 /* : Int */;
-val* var388 /* : nullable Object */;
-val* var389 /* : Array[Object] */;
-long var390 /* : Int */;
-val* var391 /* : NativeArray[Object] */;
-val* var392 /* : String */;
-val* var393 /* : RuntimeVariable */;
-static val* varonce394;
-val* var395 /* : String */;
-char* var396 /* : NativeString */;
-long var397 /* : Int */;
-val* var398 /* : String */;
-short int var399 /* : Bool */;
-static val* varonce400;
-val* var401 /* : String */;
-char* var402 /* : NativeString */;
-long var403 /* : Int */;
-val* var404 /* : String */;
-short int var405 /* : Bool */;
-static val* varonce406;
-val* var407 /* : String */;
-char* var408 /* : NativeString */;
-long var409 /* : Int */;
-val* var410 /* : String */;
-val* var411 /* : nullable Object */;
-static val* varonce412;
-val* var413 /* : String */;
-char* var414 /* : NativeString */;
-long var415 /* : Int */;
-val* var416 /* : String */;
-val* var417 /* : Array[Object] */;
-long var418 /* : Int */;
-val* var419 /* : NativeArray[Object] */;
-val* var420 /* : String */;
-static val* varonce421;
-val* var422 /* : String */;
-char* var423 /* : NativeString */;
-long var424 /* : Int */;
-val* var425 /* : String */;
-short int var426 /* : Bool */;
-static val* varonce427;
-val* var428 /* : String */;
-char* var429 /* : NativeString */;
-long var430 /* : Int */;
-val* var431 /* : String */;
-val* var432 /* : nullable Object */;
-val* var433 /* : Array[Object] */;
-long var434 /* : Int */;
-val* var435 /* : NativeArray[Object] */;
-val* var436 /* : String */;
-val* var437 /* : RuntimeVariable */;
-static val* varonce438;
-val* var439 /* : String */;
-char* var440 /* : NativeString */;
-long var441 /* : Int */;
-val* var442 /* : String */;
-short int var443 /* : Bool */;
-long var444 /* : Int */;
-val* var445 /* : nullable Object */;
-static val* varonce446;
-val* var447 /* : String */;
-char* var448 /* : NativeString */;
-long var449 /* : Int */;
-val* var450 /* : String */;
-long var451 /* : Int */;
-val* var452 /* : nullable Object */;
-val* var453 /* : Array[Object] */;
-long var454 /* : Int */;
-val* var455 /* : NativeArray[Object] */;
-val* var456 /* : String */;
-val* var457 /* : RuntimeVariable */;
-static val* varonce458;
-val* var459 /* : String */;
-char* var460 /* : NativeString */;
-long var461 /* : Int */;
-val* var462 /* : String */;
-short int var463 /* : Bool */;
-long var464 /* : Int */;
-val* var465 /* : nullable Object */;
-static val* varonce466;
-val* var467 /* : String */;
-char* var468 /* : NativeString */;
-long var469 /* : Int */;
-val* var470 /* : String */;
-long var471 /* : Int */;
-val* var472 /* : nullable Object */;
-val* var473 /* : Array[Object] */;
-long var474 /* : Int */;
-val* var475 /* : NativeArray[Object] */;
-val* var476 /* : String */;
-val* var477 /* : RuntimeVariable */;
-static val* varonce478;
-val* var479 /* : String */;
-char* var480 /* : NativeString */;
-long var481 /* : Int */;
-val* var482 /* : String */;
-short int var483 /* : Bool */;
-long var484 /* : Int */;
-val* var485 /* : nullable Object */;
-long var486 /* : Int */;
-val* var487 /* : nullable Object */;
-val* var488 /* : RuntimeVariable */;
-static val* varonce489;
-val* var490 /* : String */;
-char* var491 /* : NativeString */;
-long var492 /* : Int */;
-val* var493 /* : String */;
-short int var494 /* : Bool */;
-long var495 /* : Int */;
-val* var496 /* : nullable Object */;
-long var497 /* : Int */;
-val* var498 /* : nullable Object */;
-val* var499 /* : RuntimeVariable */;
-val* var_res500 /* var res: RuntimeVariable */;
-static val* varonce501;
-val* var502 /* : String */;
-char* var503 /* : NativeString */;
-long var504 /* : Int */;
-val* var505 /* : String */;
-val* var506 /* : Array[Object] */;
-long var507 /* : Int */;
-val* var508 /* : NativeArray[Object] */;
-val* var509 /* : String */;
-val* var510 /* : RuntimeVariable */;
-static val* varonce511;
-val* var512 /* : String */;
-char* var513 /* : NativeString */;
-long var514 /* : Int */;
-val* var515 /* : String */;
-short int var516 /* : Bool */;
-long var517 /* : Int */;
-val* var518 /* : nullable Object */;
-static val* varonce519;
-val* var520 /* : String */;
-char* var521 /* : NativeString */;
-long var522 /* : Int */;
-val* var523 /* : String */;
-val* var524 /* : Array[Object] */;
-long var525 /* : Int */;
-val* var526 /* : NativeArray[Object] */;
-val* var527 /* : String */;
-val* var528 /* : RuntimeVariable */;
-static val* varonce529;
-val* var530 /* : String */;
-char* var531 /* : NativeString */;
-long var532 /* : Int */;
-val* var533 /* : String */;
-short int var534 /* : Bool */;
-long var535 /* : Int */;
-val* var536 /* : nullable Object */;
-static val* varonce537;
-val* var538 /* : String */;
-char* var539 /* : NativeString */;
-long var540 /* : Int */;
-val* var541 /* : String */;
-val* var542 /* : Array[Object] */;
-long var543 /* : Int */;
-val* var544 /* : NativeArray[Object] */;
-val* var545 /* : String */;
-val* var546 /* : RuntimeVariable */;
-static val* varonce547;
-val* var548 /* : String */;
-char* var549 /* : NativeString */;
-long var550 /* : Int */;
-val* var551 /* : String */;
-short int var552 /* : Bool */;
-long var553 /* : Int */;
-val* var554 /* : nullable Object */;
-static val* varonce555;
-val* var556 /* : String */;
-char* var557 /* : NativeString */;
-long var558 /* : Int */;
-val* var559 /* : String */;
-long var560 /* : Int */;
-val* var561 /* : nullable Object */;
-val* var562 /* : Array[Object] */;
-long var563 /* : Int */;
-val* var564 /* : NativeArray[Object] */;
-val* var565 /* : String */;
-val* var566 /* : RuntimeVariable */;
-static val* varonce567;
-val* var568 /* : String */;
-char* var569 /* : NativeString */;
-long var570 /* : Int */;
-val* var571 /* : String */;
-short int var572 /* : Bool */;
-long var573 /* : Int */;
-val* var574 /* : nullable Object */;
-static val* varonce575;
-val* var576 /* : String */;
-char* var577 /* : NativeString */;
-long var578 /* : Int */;
-val* var579 /* : String */;
-long var580 /* : Int */;
-val* var581 /* : nullable Object */;
-val* var582 /* : Array[Object] */;
-long var583 /* : Int */;
-val* var584 /* : NativeArray[Object] */;
-val* var585 /* : String */;
-val* var586 /* : RuntimeVariable */;
-static val* varonce587;
-val* var588 /* : String */;
-char* var589 /* : NativeString */;
-long var590 /* : Int */;
-val* var591 /* : String */;
-short int var592 /* : Bool */;
-long var593 /* : Int */;
-val* var594 /* : nullable Object */;
-static val* varonce595;
-val* var596 /* : String */;
-char* var597 /* : NativeString */;
-long var598 /* : Int */;
-val* var599 /* : String */;
-long var600 /* : Int */;
-val* var601 /* : nullable Object */;
-val* var602 /* : Array[Object] */;
-long var603 /* : Int */;
-val* var604 /* : NativeArray[Object] */;
-val* var605 /* : String */;
-val* var606 /* : RuntimeVariable */;
-static val* varonce607;
-val* var608 /* : String */;
-char* var609 /* : NativeString */;
-long var610 /* : Int */;
-val* var611 /* : String */;
-short int var612 /* : Bool */;
-long var613 /* : Int */;
-val* var614 /* : nullable Object */;
-static val* varonce615;
-val* var616 /* : String */;
-char* var617 /* : NativeString */;
-long var618 /* : Int */;
-val* var619 /* : String */;
-long var620 /* : Int */;
-val* var621 /* : nullable Object */;
-val* var622 /* : Array[Object] */;
-long var623 /* : Int */;
-val* var624 /* : NativeArray[Object] */;
-val* var625 /* : String */;
-val* var626 /* : RuntimeVariable */;
-static val* varonce627;
-val* var628 /* : String */;
-char* var629 /* : NativeString */;
-long var630 /* : Int */;
-val* var631 /* : String */;
-short int var632 /* : Bool */;
-long var633 /* : Int */;
-val* var634 /* : nullable Object */;
-static val* varonce635;
-val* var636 /* : String */;
-char* var637 /* : NativeString */;
-long var638 /* : Int */;
-val* var639 /* : String */;
-val* var640 /* : Array[Object] */;
-long var641 /* : Int */;
-val* var642 /* : NativeArray[Object] */;
-val* var643 /* : String */;
-val* var644 /* : RuntimeVariable */;
-static val* varonce645;
-val* var646 /* : String */;
-char* var647 /* : NativeString */;
-long var648 /* : Int */;
-val* var649 /* : String */;
-short int var650 /* : Bool */;
-static val* varonce651;
-val* var652 /* : String */;
-char* var653 /* : NativeString */;
-long var654 /* : Int */;
-val* var655 /* : String */;
-long var656 /* : Int */;
-val* var657 /* : nullable Object */;
-val* var658 /* : Array[Object] */;
-long var659 /* : Int */;
-val* var660 /* : NativeArray[Object] */;
-val* var661 /* : String */;
-val* var662 /* : RuntimeVariable */;
-static val* varonce663;
-val* var664 /* : String */;
-char* var665 /* : NativeString */;
-long var666 /* : Int */;
-val* var667 /* : String */;
-short int var668 /* : Bool */;
-static val* varonce669;
-val* var670 /* : String */;
-char* var671 /* : NativeString */;
-long var672 /* : Int */;
-val* var673 /* : String */;
-short int var674 /* : Bool */;
-static val* varonce675;
-val* var676 /* : String */;
-char* var677 /* : NativeString */;
-long var678 /* : Int */;
-val* var679 /* : String */;
-val* var680 /* : nullable Object */;
-static val* varonce681;
-val* var682 /* : String */;
-char* var683 /* : NativeString */;
-long var684 /* : Int */;
-val* var685 /* : String */;
-val* var686 /* : Array[Object] */;
-long var687 /* : Int */;
-val* var688 /* : NativeArray[Object] */;
-val* var689 /* : String */;
-static val* varonce690;
-val* var691 /* : String */;
-char* var692 /* : NativeString */;
-long var693 /* : Int */;
-val* var694 /* : String */;
-short int var695 /* : Bool */;
-static val* varonce696;
-val* var697 /* : String */;
-char* var698 /* : NativeString */;
-long var699 /* : Int */;
-val* var700 /* : String */;
-val* var701 /* : nullable Object */;
-val* var702 /* : Array[Object] */;
-long var703 /* : Int */;
-val* var704 /* : NativeArray[Object] */;
-val* var705 /* : String */;
-val* var706 /* : RuntimeVariable */;
-static val* varonce707;
-val* var708 /* : String */;
-char* var709 /* : NativeString */;
-long var710 /* : Int */;
-val* var711 /* : String */;
-short int var712 /* : Bool */;
-long var713 /* : Int */;
-val* var714 /* : nullable Object */;
-long var715 /* : Int */;
-val* var716 /* : nullable Object */;
-val* var717 /* : RuntimeVariable */;
-static val* varonce718;
-val* var719 /* : String */;
-char* var720 /* : NativeString */;
-long var721 /* : Int */;
-val* var722 /* : String */;
-short int var723 /* : Bool */;
-long var724 /* : Int */;
-val* var725 /* : nullable Object */;
-long var726 /* : Int */;
-val* var727 /* : nullable Object */;
-val* var728 /* : RuntimeVariable */;
-val* var_res729 /* var res: RuntimeVariable */;
-static val* varonce730;
-val* var731 /* : String */;
-char* var732 /* : NativeString */;
-long var733 /* : Int */;
-val* var734 /* : String */;
-val* var735 /* : Array[Object] */;
-long var736 /* : Int */;
-val* var737 /* : NativeArray[Object] */;
-val* var738 /* : String */;
-val* var739 /* : RuntimeVariable */;
-static val* varonce740;
-val* var741 /* : String */;
-char* var742 /* : NativeString */;
-long var743 /* : Int */;
-val* var744 /* : String */;
-short int var745 /* : Bool */;
-static val* varonce746;
-val* var747 /* : String */;
-char* var748 /* : NativeString */;
-long var749 /* : Int */;
-val* var750 /* : String */;
-short int var751 /* : Bool */;
-static val* varonce752;
-val* var753 /* : String */;
-char* var754 /* : NativeString */;
-long var755 /* : Int */;
-val* var756 /* : String */;
-val* var757 /* : nullable Object */;
-static val* varonce758;
-val* var759 /* : String */;
-char* var760 /* : NativeString */;
-long var761 /* : Int */;
-val* var762 /* : String */;
-val* var763 /* : Array[Object] */;
-long var764 /* : Int */;
-val* var765 /* : NativeArray[Object] */;
-val* var766 /* : String */;
-static val* varonce767;
-val* var768 /* : String */;
-char* var769 /* : NativeString */;
-long var770 /* : Int */;
-val* var771 /* : String */;
-short int var772 /* : Bool */;
-static val* varonce773;
-val* var774 /* : String */;
-char* var775 /* : NativeString */;
-long var776 /* : Int */;
-val* var777 /* : String */;
-val* var778 /* : nullable Object */;
-val* var779 /* : Array[Object] */;
-long var780 /* : Int */;
-val* var781 /* : NativeArray[Object] */;
-val* var782 /* : String */;
-val* var783 /* : RuntimeVariable */;
-static val* varonce784;
-val* var785 /* : String */;
-char* var786 /* : NativeString */;
-long var787 /* : Int */;
-val* var788 /* : String */;
-short int var789 /* : Bool */;
-long var790 /* : Int */;
-val* var791 /* : nullable Object */;
-static val* varonce792;
-val* var793 /* : String */;
-char* var794 /* : NativeString */;
-long var795 /* : Int */;
-val* var796 /* : String */;
-long var797 /* : Int */;
-val* var798 /* : nullable Object */;
-val* var799 /* : Array[Object] */;
-long var800 /* : Int */;
-val* var801 /* : NativeArray[Object] */;
-val* var802 /* : String */;
-val* var803 /* : RuntimeVariable */;
-static val* varonce804;
-val* var805 /* : String */;
-char* var806 /* : NativeString */;
-long var807 /* : Int */;
-val* var808 /* : String */;
-short int var809 /* : Bool */;
-long var810 /* : Int */;
-val* var811 /* : nullable Object */;
-static val* varonce812;
-val* var813 /* : String */;
-char* var814 /* : NativeString */;
-long var815 /* : Int */;
-val* var816 /* : String */;
-long var817 /* : Int */;
-val* var818 /* : nullable Object */;
-val* var819 /* : Array[Object] */;
-long var820 /* : Int */;
-val* var821 /* : NativeArray[Object] */;
-val* var822 /* : String */;
-val* var823 /* : RuntimeVariable */;
-static val* varonce824;
-val* var825 /* : String */;
-char* var826 /* : NativeString */;
-long var827 /* : Int */;
-val* var828 /* : String */;
-short int var829 /* : Bool */;
-static val* varonce830;
-val* var831 /* : String */;
-char* var832 /* : NativeString */;
-long var833 /* : Int */;
-val* var834 /* : String */;
-long var835 /* : Int */;
-val* var836 /* : nullable Object */;
-val* var837 /* : Array[Object] */;
-long var838 /* : Int */;
-val* var839 /* : NativeArray[Object] */;
-val* var840 /* : String */;
-val* var841 /* : RuntimeVariable */;
-static val* varonce842;
-val* var843 /* : String */;
-char* var844 /* : NativeString */;
-long var845 /* : Int */;
-val* var846 /* : String */;
-short int var847 /* : Bool */;
-long var848 /* : Int */;
-val* var849 /* : nullable Object */;
-static val* varonce850;
-val* var851 /* : String */;
-char* var852 /* : NativeString */;
-long var853 /* : Int */;
-val* var854 /* : String */;
-val* var855 /* : Array[Object] */;
-long var856 /* : Int */;
-val* var857 /* : NativeArray[Object] */;
-val* var858 /* : String */;
-val* var859 /* : RuntimeVariable */;
-static val* varonce860;
-val* var861 /* : String */;
-char* var862 /* : NativeString */;
-long var863 /* : Int */;
-val* var864 /* : String */;
-short int var865 /* : Bool */;
-long var866 /* : Int */;
-val* var867 /* : nullable Object */;
-static val* varonce868;
-val* var869 /* : String */;
-char* var870 /* : NativeString */;
-long var871 /* : Int */;
-val* var872 /* : String */;
-val* var873 /* : Array[Object] */;
-long var874 /* : Int */;
-val* var875 /* : NativeArray[Object] */;
-val* var876 /* : String */;
-val* var877 /* : RuntimeVariable */;
-static val* varonce878;
-val* var879 /* : String */;
-char* var880 /* : NativeString */;
-long var881 /* : Int */;
-val* var882 /* : String */;
-short int var883 /* : Bool */;
-long var884 /* : Int */;
-val* var885 /* : nullable Object */;
-static val* varonce886;
-val* var887 /* : String */;
-char* var888 /* : NativeString */;
-long var889 /* : Int */;
-val* var890 /* : String */;
-long var891 /* : Int */;
-val* var892 /* : nullable Object */;
-val* var893 /* : Array[Object] */;
-long var894 /* : Int */;
-val* var895 /* : NativeArray[Object] */;
-val* var896 /* : String */;
-val* var897 /* : RuntimeVariable */;
-static val* varonce898;
-val* var899 /* : String */;
-char* var900 /* : NativeString */;
-long var901 /* : Int */;
-val* var902 /* : String */;
-short int var903 /* : Bool */;
-long var904 /* : Int */;
-val* var905 /* : nullable Object */;
-static val* varonce906;
-val* var907 /* : String */;
-char* var908 /* : NativeString */;
-long var909 /* : Int */;
-val* var910 /* : String */;
-long var911 /* : Int */;
-val* var912 /* : nullable Object */;
-val* var913 /* : Array[Object] */;
-long var914 /* : Int */;
-val* var915 /* : NativeArray[Object] */;
-val* var916 /* : String */;
-val* var917 /* : RuntimeVariable */;
-static val* varonce918;
-val* var919 /* : String */;
-char* var920 /* : NativeString */;
-long var921 /* : Int */;
-val* var922 /* : String */;
-short int var923 /* : Bool */;
-long var924 /* : Int */;
-val* var925 /* : nullable Object */;
-long var926 /* : Int */;
-val* var927 /* : nullable Object */;
-val* var928 /* : RuntimeVariable */;
-static val* varonce929;
-val* var930 /* : String */;
-char* var931 /* : NativeString */;
-long var932 /* : Int */;
-val* var933 /* : String */;
-short int var934 /* : Bool */;
-long var935 /* : Int */;
-val* var936 /* : nullable Object */;
-long var937 /* : Int */;
-val* var938 /* : nullable Object */;
-val* var939 /* : RuntimeVariable */;
-val* var_res940 /* var res: RuntimeVariable */;
-static val* varonce941;
-val* var942 /* : String */;
-char* var943 /* : NativeString */;
-long var944 /* : Int */;
-val* var945 /* : String */;
-val* var946 /* : Array[Object] */;
-long var947 /* : Int */;
-val* var948 /* : NativeArray[Object] */;
-val* var949 /* : String */;
-val* var950 /* : RuntimeVariable */;
-static val* varonce951;
-val* var952 /* : String */;
-char* var953 /* : NativeString */;
-long var954 /* : Int */;
-val* var955 /* : String */;
-short int var956 /* : Bool */;
-long var957 /* : Int */;
-val* var958 /* : nullable Object */;
-static val* varonce959;
-val* var960 /* : String */;
-char* var961 /* : NativeString */;
-long var962 /* : Int */;
-val* var963 /* : String */;
-long var964 /* : Int */;
-val* var965 /* : nullable Object */;
-val* var966 /* : Array[Object] */;
-long var967 /* : Int */;
-val* var968 /* : NativeArray[Object] */;
-val* var969 /* : String */;
-val* var970 /* : RuntimeVariable */;
-static val* varonce971;
-val* var972 /* : String */;
-char* var973 /* : NativeString */;
-long var974 /* : Int */;
-val* var975 /* : String */;
-short int var976 /* : Bool */;
-long var977 /* : Int */;
-val* var978 /* : nullable Object */;
-static val* varonce979;
-val* var980 /* : String */;
-char* var981 /* : NativeString */;
-long var982 /* : Int */;
-val* var983 /* : String */;
-long var984 /* : Int */;
-val* var985 /* : nullable Object */;
-val* var986 /* : Array[Object] */;
-long var987 /* : Int */;
-val* var988 /* : NativeArray[Object] */;
-val* var989 /* : String */;
-val* var990 /* : RuntimeVariable */;
-static val* varonce991;
-val* var992 /* : String */;
-char* var993 /* : NativeString */;
-long var994 /* : Int */;
-val* var995 /* : String */;
-short int var996 /* : Bool */;
-long var997 /* : Int */;
-val* var998 /* : nullable Object */;
-static val* varonce999;
-val* var1000 /* : String */;
-char* var1001 /* : NativeString */;
-long var1002 /* : Int */;
-val* var1003 /* : String */;
-long var1004 /* : Int */;
-val* var1005 /* : nullable Object */;
-val* var1006 /* : Array[Object] */;
-long var1007 /* : Int */;
-val* var1008 /* : NativeArray[Object] */;
-val* var1009 /* : String */;
-val* var1010 /* : RuntimeVariable */;
-static val* varonce1011;
-val* var1012 /* : String */;
-char* var1013 /* : NativeString */;
-long var1014 /* : Int */;
-val* var1015 /* : String */;
-short int var1016 /* : Bool */;
-long var1017 /* : Int */;
-val* var1018 /* : nullable Object */;
-static val* varonce1019;
-val* var1020 /* : String */;
-char* var1021 /* : NativeString */;
-long var1022 /* : Int */;
-val* var1023 /* : String */;
-long var1024 /* : Int */;
-val* var1025 /* : nullable Object */;
-val* var1026 /* : Array[Object] */;
-long var1027 /* : Int */;
-val* var1028 /* : NativeArray[Object] */;
-val* var1029 /* : String */;
-val* var1030 /* : RuntimeVariable */;
-static val* varonce1031;
-val* var1032 /* : String */;
-char* var1033 /* : NativeString */;
-long var1034 /* : Int */;
-val* var1035 /* : String */;
-short int var1036 /* : Bool */;
-static val* varonce1037;
-val* var1038 /* : String */;
-char* var1039 /* : NativeString */;
-long var1040 /* : Int */;
-val* var1041 /* : String */;
-long var1042 /* : Int */;
-val* var1043 /* : nullable Object */;
-val* var1044 /* : Array[Object] */;
-long var1045 /* : Int */;
-val* var1046 /* : NativeArray[Object] */;
-val* var1047 /* : String */;
-val* var1048 /* : RuntimeVariable */;
-static val* varonce1049;
-val* var1050 /* : String */;
-char* var1051 /* : NativeString */;
-long var1052 /* : Int */;
-val* var1053 /* : String */;
-short int var1054 /* : Bool */;
-static val* varonce1055;
-val* var1056 /* : String */;
-char* var1057 /* : NativeString */;
-long var1058 /* : Int */;
-val* var1059 /* : String */;
-short int var1060 /* : Bool */;
-long var1061 /* : Int */;
-val* var1062 /* : nullable Object */;
-static val* varonce1063;
-val* var1064 /* : String */;
-char* var1065 /* : NativeString */;
-long var1066 /* : Int */;
-val* var1067 /* : String */;
-long var1068 /* : Int */;
-val* var1069 /* : nullable Object */;
-static val* varonce1070;
-val* var1071 /* : String */;
-char* var1072 /* : NativeString */;
-long var1073 /* : Int */;
-val* var1074 /* : String */;
-val* var1075 /* : Array[Object] */;
-long var1076 /* : Int */;
-val* var1077 /* : NativeArray[Object] */;
-val* var1078 /* : String */;
-val* var1079 /* : RuntimeVariable */;
-static val* varonce1080;
-val* var1081 /* : String */;
-char* var1082 /* : NativeString */;
-long var1083 /* : Int */;
-val* var1084 /* : String */;
-short int var1085 /* : Bool */;
-long var1086 /* : Int */;
-val* var1087 /* : nullable Object */;
-static val* varonce1088;
-val* var1089 /* : String */;
-char* var1090 /* : NativeString */;
-long var1091 /* : Int */;
-val* var1092 /* : String */;
-long var1093 /* : Int */;
-val* var1094 /* : nullable Object */;
-static val* varonce1095;
-val* var1096 /* : String */;
-char* var1097 /* : NativeString */;
-long var1098 /* : Int */;
-val* var1099 /* : String */;
-long var1100 /* : Int */;
-val* var1101 /* : nullable Object */;
-static val* varonce1102;
-val* var1103 /* : String */;
-char* var1104 /* : NativeString */;
-long var1105 /* : Int */;
-val* var1106 /* : String */;
-val* var1107 /* : Array[Object] */;
-long var1108 /* : Int */;
-val* var1109 /* : NativeArray[Object] */;
-val* var1110 /* : String */;
-static val* varonce1111;
-val* var1112 /* : String */;
-char* var1113 /* : NativeString */;
-long var1114 /* : Int */;
-val* var1115 /* : String */;
-short int var1116 /* : Bool */;
-static val* varonce1117;
-val* var1118 /* : String */;
-char* var1119 /* : NativeString */;
-long var1120 /* : Int */;
-val* var1121 /* : String */;
-long var1122 /* : Int */;
-val* var1123 /* : nullable Object */;
-static val* varonce1124;
-val* var1125 /* : String */;
-char* var1126 /* : NativeString */;
-long var1127 /* : Int */;
-val* var1128 /* : String */;
-long var1129 /* : Int */;
-val* var1130 /* : nullable Object */;
-static val* varonce1131;
-val* var1132 /* : String */;
-char* var1133 /* : NativeString */;
-long var1134 /* : Int */;
-val* var1135 /* : String */;
-long var1136 /* : Int */;
-val* var1137 /* : nullable Object */;
-static val* varonce1138;
-val* var1139 /* : String */;
-char* var1140 /* : NativeString */;
-long var1141 /* : Int */;
-val* var1142 /* : String */;
-long var1143 /* : Int */;
-val* var1144 /* : nullable Object */;
-static val* varonce1145;
-val* var1146 /* : String */;
-char* var1147 /* : NativeString */;
-long var1148 /* : Int */;
-val* var1149 /* : String */;
-long var1150 /* : Int */;
-val* var1151 /* : nullable Object */;
-static val* varonce1152;
-val* var1153 /* : String */;
-char* var1154 /* : NativeString */;
-long var1155 /* : Int */;
-val* var1156 /* : String */;
-val* var1157 /* : Array[Object] */;
-long var1158 /* : Int */;
-val* var1159 /* : NativeArray[Object] */;
-val* var1160 /* : String */;
-static val* varonce1161;
-val* var1162 /* : String */;
-char* var1163 /* : NativeString */;
-long var1164 /* : Int */;
-val* var1165 /* : String */;
-short int var1166 /* : Bool */;
-static val* varonce1167;
-val* var1168 /* : String */;
-char* var1169 /* : NativeString */;
-long var1170 /* : Int */;
-val* var1171 /* : String */;
-long var1172 /* : Int */;
-val* var1173 /* : nullable Object */;
-static val* varonce1174;
-val* var1175 /* : String */;
-char* var1176 /* : NativeString */;
-long var1177 /* : Int */;
-val* var1178 /* : String */;
-val* var1179 /* : Array[Object] */;
-long var1180 /* : Int */;
-val* var1181 /* : NativeArray[Object] */;
-val* var1182 /* : String */;
-val* var1183 /* : RuntimeVariable */;
-static val* varonce1184;
-val* var1185 /* : String */;
-char* var1186 /* : NativeString */;
-long var1187 /* : Int */;
-val* var1188 /* : String */;
-short int var1189 /* : Bool */;
-static val* varonce1190;
-val* var1191 /* : String */;
-char* var1192 /* : NativeString */;
-long var1193 /* : Int */;
-val* var1194 /* : String */;
-short int var1195 /* : Bool */;
-static val* varonce1196;
-val* var1197 /* : String */;
-char* var1198 /* : NativeString */;
-long var1199 /* : Int */;
-val* var1200 /* : String */;
-long var1201 /* : Int */;
-val* var1202 /* : nullable Object */;
-static val* varonce1203;
-val* var1204 /* : String */;
-char* var1205 /* : NativeString */;
-long var1206 /* : Int */;
-val* var1207 /* : String */;
-val* var1208 /* : Array[Object] */;
-long var1209 /* : Int */;
-val* var1210 /* : NativeArray[Object] */;
-val* var1211 /* : String */;
-static val* varonce1212;
-val* var1213 /* : String */;
-char* var1214 /* : NativeString */;
-long var1215 /* : Int */;
-val* var1216 /* : String */;
-short int var1217 /* : Bool */;
-static val* varonce1218;
-val* var1219 /* : String */;
-char* var1220 /* : NativeString */;
-long var1221 /* : Int */;
-val* var1222 /* : String */;
-val* var1223 /* : RuntimeVariable */;
-static val* varonce1224;
-val* var1225 /* : String */;
-char* var1226 /* : NativeString */;
-long var1227 /* : Int */;
-val* var1228 /* : String */;
-short int var1229 /* : Bool */;
-static val* varonce1230;
-val* var1231 /* : String */;
-char* var1232 /* : NativeString */;
-long var1233 /* : Int */;
-val* var1234 /* : String */;
-long var1235 /* : Int */;
-val* var1236 /* : nullable Object */;
-static val* varonce1237;
-val* var1238 /* : String */;
-char* var1239 /* : NativeString */;
-long var1240 /* : Int */;
-val* var1241 /* : String */;
-val* var1242 /* : Array[Object] */;
-long var1243 /* : Int */;
-val* var1244 /* : NativeArray[Object] */;
-val* var1245 /* : String */;
-val* var1246 /* : RuntimeVariable */;
-static val* varonce1247;
-val* var1248 /* : String */;
-char* var1249 /* : NativeString */;
-long var1250 /* : Int */;
-val* var1251 /* : String */;
-short int var1252 /* : Bool */;
-static val* varonce1253;
-val* var1254 /* : String */;
-char* var1255 /* : NativeString */;
-long var1256 /* : Int */;
-val* var1257 /* : String */;
-short int var1258 /* : Bool */;
-static val* varonce1259;
-val* var1260 /* : String */;
-char* var1261 /* : NativeString */;
-long var1262 /* : Int */;
-val* var1263 /* : String */;
-val* var1264 /* : nullable Object */;
-val* var1265 /* : Array[Object] */;
-long var1266 /* : Int */;
-val* var1267 /* : NativeArray[Object] */;
-val* var1268 /* : String */;
-val* var1269 /* : RuntimeVariable */;
-static val* varonce1270;
-val* var1271 /* : String */;
-char* var1272 /* : NativeString */;
-long var1273 /* : Int */;
-val* var1274 /* : String */;
-short int var1275 /* : Bool */;
-long var1276 /* : Int */;
-val* var1277 /* : nullable Object */;
-long var1278 /* : Int */;
-val* var1279 /* : nullable Object */;
-val* var1280 /* : RuntimeVariable */;
-static val* varonce1281;
-val* var1282 /* : String */;
-char* var1283 /* : NativeString */;
-long var1284 /* : Int */;
-val* var1285 /* : String */;
-short int var1286 /* : Bool */;
-val* var1287 /* : nullable Object */;
-val* var1288 /* : String */;
-val* var_nat /* var nat: String */;
-static val* varonce1289;
-val* var1290 /* : String */;
-char* var1291 /* : NativeString */;
-long var1292 /* : Int */;
-val* var1293 /* : String */;
-static val* varonce1294;
-val* var1295 /* : String */;
-char* var1296 /* : NativeString */;
-long var1297 /* : Int */;
-val* var1298 /* : String */;
-val* var1299 /* : Array[Object] */;
-long var1300 /* : Int */;
-val* var1301 /* : NativeArray[Object] */;
-val* var1302 /* : String */;
-static val* varonce1303;
-val* var1304 /* : String */;
-char* var1305 /* : NativeString */;
-long var1306 /* : Int */;
-val* var1307 /* : String */;
-short int var1308 /* : Bool */;
-val* var1309 /* : nullable Object */;
-val* var1310 /* : String */;
-val* var_nat1311 /* var nat: String */;
-static val* varonce1312;
-val* var1313 /* : String */;
-char* var1314 /* : NativeString */;
-long var1315 /* : Int */;
-val* var1316 /* : String */;
-val* var1317 /* : Array[Object] */;
-long var1318 /* : Int */;
-val* var1319 /* : NativeArray[Object] */;
-val* var1320 /* : String */;
-val* var1321 /* : RuntimeVariable */;
-static val* varonce1322;
-val* var1323 /* : String */;
-char* var1324 /* : NativeString */;
-long var1325 /* : Int */;
-val* var1326 /* : String */;
-short int var1327 /* : Bool */;
-static val* varonce1328;
-val* var1329 /* : String */;
-char* var1330 /* : NativeString */;
-long var1331 /* : Int */;
-val* var1332 /* : String */;
-static val* varonce1333;
-val* var1334 /* : String */;
-char* var1335 /* : NativeString */;
-long var1336 /* : Int */;
-val* var1337 /* : String */;
-short int var1338 /* : Bool */;
-static val* varonce1339;
-val* var1340 /* : String */;
-char* var1341 /* : NativeString */;
-long var1342 /* : Int */;
-val* var1343 /* : String */;
-val* var1344 /* : RuntimeVariable */;
-static val* varonce1345;
-val* var1346 /* : String */;
-char* var1347 /* : NativeString */;
-long var1348 /* : Int */;
-val* var1349 /* : String */;
-short int var1350 /* : Bool */;
-static val* varonce1351;
-val* var1352 /* : String */;
-char* var1353 /* : NativeString */;
-long var1354 /* : Int */;
-val* var1355 /* : String */;
-long var1356 /* : Int */;
-val* var1357 /* : nullable Object */;
-static val* varonce1358;
-val* var1359 /* : String */;
-char* var1360 /* : NativeString */;
-long var1361 /* : Int */;
-val* var1362 /* : String */;
-val* var1363 /* : Array[Object] */;
-long var1364 /* : Int */;
-val* var1365 /* : NativeArray[Object] */;
-val* var1366 /* : String */;
-val* var1367 /* : RuntimeVariable */;
-static val* varonce1368;
-val* var1369 /* : String */;
-char* var1370 /* : NativeString */;
-long var1371 /* : Int */;
-val* var1372 /* : String */;
-val* var1373 /* : String */;
-static val* varonce1374;
-val* var1375 /* : String */;
-char* var1376 /* : NativeString */;
-long var1377 /* : Int */;
-val* var1378 /* : String */;
-static val* varonce1379;
-val* var1380 /* : String */;
-char* var1381 /* : NativeString */;
-long var1382 /* : Int */;
-val* var1383 /* : String */;
-val* var1384 /* : Location */;
-val* var1385 /* : String */;
-static val* varonce1386;
-val* var1387 /* : String */;
-char* var1388 /* : NativeString */;
-long var1389 /* : Int */;
-val* var1390 /* : String */;
-val* var1391 /* : Array[Object] */;
-long var1392 /* : Int */;
-val* var1393 /* : NativeArray[Object] */;
-val* var1394 /* : String */;
-static val* varonce1395;
-val* var1396 /* : String */;
-char* var1397 /* : NativeString */;
-long var1398 /* : Int */;
-val* var1399 /* : String */;
-val* var1400 /* : Array[Object] */;
-long var1401 /* : Int */;
-val* var1402 /* : NativeArray[Object] */;
-val* var1403 /* : String */;
-var_v = p0;
-var_mpropdef = p1;
-var_arguments = p2;
-var = ((val* (*)(val*))(var_mpropdef->class->vft[COLOR_model__MPropDef__mproperty]))(var_mpropdef) /* mproperty on <var_mpropdef:MMethodDef>*/;
-var1 = ((val* (*)(val*))(var->class->vft[COLOR_model__MProperty__name]))(var) /* name on <var:MProperty(MMethod)>*/;
-var_pname = var1;
-var2 = ((val* (*)(val*))(var_mpropdef->class->vft[COLOR_model__MPropDef__mclassdef]))(var_mpropdef) /* mclassdef on <var_mpropdef:MMethodDef>*/;
-var3 = ((val* (*)(val*))(var2->class->vft[COLOR_model__MClassDef__mclass]))(var2) /* mclass on <var2:MClassDef>*/;
-var4 = ((val* (*)(val*))(var3->class->vft[COLOR_model__MClass__name]))(var3) /* name on <var3:MClass>*/;
-var_cname = var4;
-var5 = ((val* (*)(val*))(var_mpropdef->class->vft[COLOR_model__MMethodDef__msignature]))(var_mpropdef) /* msignature on <var_mpropdef:MMethodDef>*/;
-if (var5 == NULL) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Reciever is null", "src/abstract_compiler.nit", 1345);
-exit(1);
-} else {
-var6 = ((val* (*)(val*))(var5->class->vft[COLOR_model__MSignature__return_mtype]))(var5) /* return_mtype on <var5:nullable MSignature>*/;
-}
-var_ret = var6;
-var7 = NULL;
-if (var_ret == NULL) {
-var8 = 0; /* is null */
-} else {
-var8 = 1; /* arg is null and recv is not */
+long var15 /* : Int */;
+short int var17 /* : Bool */;
+int cltype;
+int idtype;
+const char* var_class_name;
+long var18 /* : Int */;
+long var_vararg_len /* var vararg_len: Int */;
+long var19 /* : Int */;
+short int var20 /* : Bool */;
+short int var22 /* : Bool */;
+int cltype23;
+int idtype24;
+const char* var_class_name25;
+short int var26 /* : Bool */;
+long var27 /* : Int */;
+long var28 /* : Int */;
+long var_i /* var i: Int */;
+long var29 /* : Int */;
+long var_ /* var : Int */;
+short int var30 /* : Bool */;
+short int var32 /* : Bool */;
+int cltype33;
+int idtype34;
+const char* var_class_name35;
+short int var36 /* : Bool */;
+short int var37 /* : Bool */;
+short int var38 /* : Bool */;
+short int var40 /* : Bool */;
+val* var41 /* : nullable Object */;
+val* var_ne /* var ne: AExpr */;
+short int var42 /* : Bool */;
+int cltype43;
+int idtype44;
+val* var45 /* : AExpr */;
+val* var47 /* : AExpr */;
+val* var48 /* : null */;
+val* var49 /* : RuntimeVariable */;
+val* var_e /* var e: RuntimeVariable */;
+val* var50 /* : Array[RuntimeVariable] */;
+val* var_vararg /* var vararg: Array[RuntimeVariable] */;
+long var_j /* var j: Int */;
+long var51 /* : Int */;
+short int var53 /* : Bool */;
+int cltype54;
+int idtype55;
+const char* var_class_name56;
+long var57 /* : Int */;
+long var_58 /* var : Int */;
+short int var59 /* : Bool */;
+short int var61 /* : Bool */;
+int cltype62;
+int idtype63;
+const char* var_class_name64;
+short int var65 /* : Bool */;
+val* var66 /* : nullable Object */;
+val* var67 /* : null */;
+val* var68 /* : RuntimeVariable */;
+val* var_e69 /* var e: RuntimeVariable */;
+long var70 /* : Int */;
+long var71 /* : Int */;
+val* var73 /* : Array[MParameter] */;
+val* var75 /* : Array[MParameter] */;
+val* var76 /* : nullable Object */;
+val* var77 /* : MType */;
+val* var79 /* : MType */;
+val* var_elttype /* var elttype: MType */;
+val* var80 /* : RuntimeVariable */;
+val* var_arg /* var arg: RuntimeVariable */;
+long var_j81 /* var j: Int */;
+short int var82 /* : Bool */;
+short int var84 /* : Bool */;
+int cltype85;
+int idtype86;
+const char* var_class_name87;
+short int var88 /* : Bool */;
+long var89 /* : Int */;
+short int var91 /* : Bool */;
+int cltype92;
+int idtype93;
+const char* var_class_name94;
+long var95 /* : Int */;
+val* var96 /* : nullable Object */;
+val* var97 /* : null */;
+val* var98 /* : RuntimeVariable */;
+val* var_e99 /* var e: RuntimeVariable */;
+long var100 /* : Int */;
+long var101 /* : Int */;
+var_mpropdef = p0;
+var_recv = p1;
+var_args = p2;
+{
+{ /* Inline model#MMethodDef#new_msignature (var_mpropdef) on <var_mpropdef:MMethodDef> */
+var4 = var_mpropdef->attrs[COLOR_model__MMethodDef___new_msignature].val; /* _new_msignature on <var_mpropdef:MMethodDef> */
+var2 = var4;
+RET_LABEL3:(void)0;
 }
-if (var8){
-var9 = ((val* (*)(val*))(var_arguments->class->vft[COLOR_abstract_collection__Collection__first]))(var_arguments) /* first on <var_arguments:Array[RuntimeVariable]>*/;
-var10 = ((val* (*)(val*, val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__resolve_for]))(var_v, var_ret, var9) /* resolve_for on <var_v:AbstractCompilerVisitor>*/;
-var_ret = var10;
-} else {
 }
-if (varonce) {
-var12 = varonce;
+if (var2!=NULL) {
+var1 = var2;
 } else {
-var13 = "==";
-var14 = 2;
-var15 = string__NativeString__to_s_with_length(var13, var14);
-var12 = var15;
-varonce = var12;
+{
+{ /* Inline model#MMethodDef#msignature (var_mpropdef) on <var_mpropdef:MMethodDef> */
+var7 = var_mpropdef->attrs[COLOR_model__MMethodDef___msignature].val; /* _msignature on <var_mpropdef:MMethodDef> */
+var5 = var7;
+RET_LABEL6:(void)0;
 }
-var16 = ((short int (*)(val*, val*))(var_pname->class->vft[COLOR_kernel__Object___33d_61d]))(var_pname, var12) /* != on <var_pname:String>*/;
-var_ = var16;
-if (var16){
-if (varonce17) {
-var18 = varonce17;
-} else {
-var19 = "!=";
-var20 = 2;
-var21 = string__NativeString__to_s_with_length(var19, var20);
-var18 = var21;
-varonce17 = var18;
 }
-var22 = ((short int (*)(val*, val*))(var_pname->class->vft[COLOR_kernel__Object___33d_61d]))(var_pname, var18) /* != on <var_pname:String>*/;
-var11 = var22;
-} else {
-var11 = var_;
+if (unlikely(var5 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Cast failed");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 1113);
+show_backtrace(1);
 }
-if (var11){
-((void (*)(val*, val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__adapt_signature]))(var_v, var_mpropdef, var_arguments) /* adapt_signature on <var_v:AbstractCompilerVisitor>*/;
-} else {
+var1 = var5;
 }
-if (varonce23) {
-var24 = varonce23;
-} else {
-var25 = "Int";
-var26 = 3;
-var27 = string__NativeString__to_s_with_length(var25, var26);
-var24 = var27;
-varonce23 = var24;
+var_msignature = var1;
+var8 = NEW_array__Array(&type_array__Arrayabstract_compiler__RuntimeVariable);
+{
+((void (*)(val*))(var8->class->vft[COLOR_kernel__Object__init]))(var8) /* init on <var8:Array[RuntimeVariable]>*/;
 }
-var28 = ((short int (*)(val*, val*))(var_cname->class->vft[COLOR_kernel__Object___61d_61d]))(var_cname, var24) /* == on <var_cname:String>*/;
-if (var28){
-if (varonce29) {
-var30 = varonce29;
-} else {
-var31 = "output";
-var32 = 6;
-var33 = string__NativeString__to_s_with_length(var31, var32);
-var30 = var33;
-varonce29 = var30;
+var_res = var8;
+{
+array__Array__add(var_res, var_recv); /* Direct call array#Array#add on <var_res:Array[RuntimeVariable]>*/
 }
-var34 = ((short int (*)(val*, val*))(var_pname->class->vft[COLOR_kernel__Object___61d_61d]))(var_pname, var30) /* == on <var_pname:String>*/;
-if (var34){
-if (varonce35) {
-var36 = varonce35;
-} else {
-var37 = "printf(\"%ld\\n\", ";
-var38 = 16;
-var39 = string__NativeString__to_s_with_length(var37, var38);
-var36 = var39;
-varonce35 = var36;
-}
-var40 = ((val* (*)(val*))(var_arguments->class->vft[COLOR_abstract_collection__Collection__first]))(var_arguments) /* first on <var_arguments:Array[RuntimeVariable]>*/;
-if (varonce41) {
-var42 = varonce41;
-} else {
-var43 = ");";
-var44 = 2;
-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]>*/;
-CHECK_NEW_array__Array(var46);
-}
-var49 = ((val* (*)(val*))(var46->class->vft[COLOR_string__Object__to_s]))(var46) /* to_s on <var46:Array[Object]>*/;
-((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(var_v, var49) /* add on <var_v:AbstractCompilerVisitor>*/;
-goto RET_LABEL;
-} else {
-if (varonce50) {
-var51 = varonce50;
-} else {
-var52 = "object_id";
-var53 = 9;
-var54 = string__NativeString__to_s_with_length(var52, var53);
-var51 = var54;
-varonce50 = var51;
+{
+var9 = ((short int (*)(val*))(var_args->class->vft[COLOR_abstract_collection__Collection__is_empty]))(var_args) /* is_empty on <var_args:SequenceRead[AExpr]>*/;
 }
-var55 = ((short int (*)(val*, val*))(var_pname->class->vft[COLOR_kernel__Object___61d_61d]))(var_pname, var51) /* == on <var_pname:String>*/;
-if (var55){
-var56 = ((val* (*)(val*))(var_arguments->class->vft[COLOR_abstract_collection__Collection__first]))(var_arguments) /* first on <var_arguments:Array[RuntimeVariable]>*/;
-((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__ret]))(var_v, var56) /* ret on <var_v:AbstractCompilerVisitor>*/;
+if (var9){
+var = var_res;
 goto RET_LABEL;
 } else {
-if (varonce57) {
-var58 = varonce57;
-} else {
-var59 = "+";
-var60 = 1;
-var61 = string__NativeString__to_s_with_length(var59, var60);
-var58 = var61;
-varonce57 = var58;
 }
-var62 = ((short int (*)(val*, val*))(var_pname->class->vft[COLOR_kernel__Object___61d_61d]))(var_pname, var58) /* == on <var_pname:String>*/;
-if (var62){
-var63 = 0;
-var64 = ((val* (*)(val*, long))(var_arguments->class->vft[COLOR_abstract_collection__SequenceRead___91d_93d]))(var_arguments, var63) /* [] on <var_arguments:Array[RuntimeVariable]>*/;
-if (varonce65) {
-var66 = varonce65;
-} else {
-var67 = " + ";
-var68 = 3;
-var69 = string__NativeString__to_s_with_length(var67, var68);
-var66 = var69;
-varonce65 = var66;
+{
+{ /* Inline model#MSignature#vararg_rank (var_msignature) on <var_msignature:MSignature> */
+var12 = var_msignature->attrs[COLOR_model__MSignature___vararg_rank].l; /* _vararg_rank on <var_msignature:MSignature> */
+var10 = var12;
+RET_LABEL11:(void)0;
 }
-var70 = 1;
-var71 = ((val* (*)(val*, long))(var_arguments->class->vft[COLOR_abstract_collection__SequenceRead___91d_93d]))(var_arguments, var70) /* [] on <var_arguments:Array[RuntimeVariable]>*/;
-var72 = NEW_array__Array(&type_array__Arraykernel__Object);
-{ /* var72 = array_instance Array[Object] */
-var73 = 3;
-var74 = NEW_array__NativeArray(var73, &type_array__NativeArraykernel__Object);
-((struct instance_array__NativeArray*)var74)->values[0] = (val*) var64;
-((struct instance_array__NativeArray*)var74)->values[1] = (val*) var66;
-((struct instance_array__NativeArray*)var74)->values[2] = (val*) var71;
-((void (*)(val*, val*, long))(var72->class->vft[COLOR_array__Array__with_native]))(var72, var74, var73) /* with_native on <var72:Array[Object]>*/;
-CHECK_NEW_array__Array(var72);
-}
-var75 = ((val* (*)(val*))(var72->class->vft[COLOR_string__Object__to_s]))(var72) /* to_s on <var72:Array[Object]>*/;
-if (var_ret == NULL) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "src/abstract_compiler.nit", 1360);
-exit(1);
-}
-var76 = ((val* (*)(val*, val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__new_expr]))(var_v, var75, var_ret) /* new_expr on <var_v:AbstractCompilerVisitor>*/;
-((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__ret]))(var_v, var76) /* ret on <var_v:AbstractCompilerVisitor>*/;
-goto RET_LABEL;
-} else {
-if (varonce77) {
-var78 = varonce77;
-} else {
-var79 = "-";
-var80 = 1;
-var81 = string__NativeString__to_s_with_length(var79, var80);
-var78 = var81;
-varonce77 = var78;
 }
-var82 = ((short int (*)(val*, val*))(var_pname->class->vft[COLOR_kernel__Object___61d_61d]))(var_pname, var78) /* == on <var_pname:String>*/;
-if (var82){
-var83 = 0;
-var84 = ((val* (*)(val*, long))(var_arguments->class->vft[COLOR_abstract_collection__SequenceRead___91d_93d]))(var_arguments, var83) /* [] on <var_arguments:Array[RuntimeVariable]>*/;
-if (varonce85) {
-var86 = varonce85;
-} else {
-var87 = " - ";
-var88 = 3;
-var89 = string__NativeString__to_s_with_length(var87, var88);
-var86 = var89;
-varonce85 = var86;
-}
-var90 = 1;
-var91 = ((val* (*)(val*, long))(var_arguments->class->vft[COLOR_abstract_collection__SequenceRead___91d_93d]))(var_arguments, var90) /* [] on <var_arguments:Array[RuntimeVariable]>*/;
-var92 = NEW_array__Array(&type_array__Arraykernel__Object);
-{ /* var92 = array_instance Array[Object] */
-var93 = 3;
-var94 = NEW_array__NativeArray(var93, &type_array__NativeArraykernel__Object);
-((struct instance_array__NativeArray*)var94)->values[0] = (val*) var84;
-((struct instance_array__NativeArray*)var94)->values[1] = (val*) var86;
-((struct instance_array__NativeArray*)var94)->values[2] = (val*) var91;
-((void (*)(val*, val*, long))(var92->class->vft[COLOR_array__Array__with_native]))(var92, var94, var93) /* with_native on <var92:Array[Object]>*/;
-CHECK_NEW_array__Array(var92);
-}
-var95 = ((val* (*)(val*))(var92->class->vft[COLOR_string__Object__to_s]))(var92) /* to_s on <var92:Array[Object]>*/;
-if (var_ret == NULL) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "src/abstract_compiler.nit", 1363);
-exit(1);
-}
-var96 = ((val* (*)(val*, val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__new_expr]))(var_v, var95, var_ret) /* new_expr on <var_v:AbstractCompilerVisitor>*/;
-((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__ret]))(var_v, var96) /* ret on <var_v:AbstractCompilerVisitor>*/;
-goto RET_LABEL;
-} else {
-if (varonce97) {
-var98 = varonce97;
-} else {
-var99 = "unary -";
-var100 = 7;
-var101 = string__NativeString__to_s_with_length(var99, var100);
-var98 = var101;
-varonce97 = var98;
-}
-var102 = ((short int (*)(val*, val*))(var_pname->class->vft[COLOR_kernel__Object___61d_61d]))(var_pname, var98) /* == on <var_pname:String>*/;
-if (var102){
-if (varonce103) {
-var104 = varonce103;
-} else {
-var105 = "-";
-var106 = 1;
-var107 = string__NativeString__to_s_with_length(var105, var106);
-var104 = var107;
-varonce103 = var104;
-}
-var108 = 0;
-var109 = ((val* (*)(val*, long))(var_arguments->class->vft[COLOR_abstract_collection__SequenceRead___91d_93d]))(var_arguments, var108) /* [] on <var_arguments:Array[RuntimeVariable]>*/;
-var110 = NEW_array__Array(&type_array__Arraykernel__Object);
-{ /* var110 = array_instance Array[Object] */
-var111 = 2;
-var112 = NEW_array__NativeArray(var111, &type_array__NativeArraykernel__Object);
-((struct instance_array__NativeArray*)var112)->values[0] = (val*) var104;
-((struct instance_array__NativeArray*)var112)->values[1] = (val*) var109;
-((void (*)(val*, val*, long))(var110->class->vft[COLOR_array__Array__with_native]))(var110, var112, var111) /* with_native on <var110:Array[Object]>*/;
-CHECK_NEW_array__Array(var110);
-}
-var113 = ((val* (*)(val*))(var110->class->vft[COLOR_string__Object__to_s]))(var110) /* to_s on <var110:Array[Object]>*/;
-if (var_ret == NULL) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "src/abstract_compiler.nit", 1366);
-exit(1);
-}
-var114 = ((val* (*)(val*, val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__new_expr]))(var_v, var113, var_ret) /* new_expr on <var_v:AbstractCompilerVisitor>*/;
-((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__ret]))(var_v, var114) /* ret on <var_v:AbstractCompilerVisitor>*/;
-goto RET_LABEL;
-} else {
-if (varonce115) {
-var116 = varonce115;
-} else {
-var117 = "succ";
-var118 = 4;
-var119 = string__NativeString__to_s_with_length(var117, var118);
-var116 = var119;
-varonce115 = var116;
+var_vararg_rank = var10;
+{
+var13 = ((long (*)(val*))(var_args->class->vft[COLOR_abstract_collection__Collection__length]))(var_args) /* length on <var_args:SequenceRead[AExpr]>*/;
 }
-var120 = ((short int (*)(val*, val*))(var_pname->class->vft[COLOR_kernel__Object___61d_61d]))(var_pname, var116) /* == on <var_pname:String>*/;
-if (var120){
-var121 = 0;
-var122 = ((val* (*)(val*, long))(var_arguments->class->vft[COLOR_abstract_collection__SequenceRead___91d_93d]))(var_arguments, var121) /* [] on <var_arguments:Array[RuntimeVariable]>*/;
-if (varonce123) {
-var124 = varonce123;
-} else {
-var125 = "+1";
-var126 = 2;
-var127 = string__NativeString__to_s_with_length(var125, var126);
-var124 = var127;
-varonce123 = var124;
+{
+var14 = model__MSignature__arity(var_msignature);
 }
-var128 = NEW_array__Array(&type_array__Arraykernel__Object);
-{ /* var128 = array_instance Array[Object] */
-var129 = 2;
-var130 = NEW_array__NativeArray(var129, &type_array__NativeArraykernel__Object);
-((struct instance_array__NativeArray*)var130)->values[0] = (val*) var122;
-((struct instance_array__NativeArray*)var130)->values[1] = (val*) var124;
-((void (*)(val*, val*, long))(var128->class->vft[COLOR_array__Array__with_native]))(var128, var130, var129) /* with_native on <var128:Array[Object]>*/;
-CHECK_NEW_array__Array(var128);
-}
-var131 = ((val* (*)(val*))(var128->class->vft[COLOR_string__Object__to_s]))(var128) /* to_s on <var128:Array[Object]>*/;
-if (var_ret == NULL) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "src/abstract_compiler.nit", 1369);
-exit(1);
-}
-var132 = ((val* (*)(val*, val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__new_expr]))(var_v, var131, var_ret) /* new_expr on <var_v:AbstractCompilerVisitor>*/;
-((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__ret]))(var_v, var132) /* ret on <var_v:AbstractCompilerVisitor>*/;
-goto RET_LABEL;
-} else {
-if (varonce133) {
-var134 = varonce133;
-} else {
-var135 = "prec";
-var136 = 4;
-var137 = string__NativeString__to_s_with_length(var135, var136);
-var134 = var137;
-varonce133 = var134;
+{
+{ /* Inline kernel#Int#- (var13,var14) on <var13:Int> */
+/* Covariant cast for argument 0 (i) <var14:Int> isa OTHER */
+/* <var14:Int> isa OTHER */
+var17 = 1; /* easy <var14:Int> isa OTHER*/
+if (unlikely(!var17)) {
+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);
 }
-var138 = ((short int (*)(val*, val*))(var_pname->class->vft[COLOR_kernel__Object___61d_61d]))(var_pname, var134) /* == on <var_pname:String>*/;
-if (var138){
-var139 = 0;
-var140 = ((val* (*)(val*, long))(var_arguments->class->vft[COLOR_abstract_collection__SequenceRead___91d_93d]))(var_arguments, var139) /* [] on <var_arguments:Array[RuntimeVariable]>*/;
-if (varonce141) {
-var142 = varonce141;
-} else {
-var143 = "-1";
-var144 = 2;
-var145 = string__NativeString__to_s_with_length(var143, var144);
-var142 = var145;
-varonce141 = var142;
+var18 = var13 - var14;
+var15 = var18;
+goto RET_LABEL16;
+RET_LABEL16:(void)0;
 }
-var146 = NEW_array__Array(&type_array__Arraykernel__Object);
-{ /* var146 = array_instance Array[Object] */
-var147 = 2;
-var148 = NEW_array__NativeArray(var147, &type_array__NativeArraykernel__Object);
-((struct instance_array__NativeArray*)var148)->values[0] = (val*) var140;
-((struct instance_array__NativeArray*)var148)->values[1] = (val*) var142;
-((void (*)(val*, val*, long))(var146->class->vft[COLOR_array__Array__with_native]))(var146, var148, var147) /* with_native on <var146:Array[Object]>*/;
-CHECK_NEW_array__Array(var146);
-}
-var149 = ((val* (*)(val*))(var146->class->vft[COLOR_string__Object__to_s]))(var146) /* to_s on <var146:Array[Object]>*/;
-if (var_ret == NULL) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "src/abstract_compiler.nit", 1372);
-exit(1);
-}
-var150 = ((val* (*)(val*, val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__new_expr]))(var_v, var149, var_ret) /* new_expr on <var_v:AbstractCompilerVisitor>*/;
-((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__ret]))(var_v, var150) /* ret on <var_v:AbstractCompilerVisitor>*/;
-goto RET_LABEL;
-} else {
-if (varonce151) {
-var152 = varonce151;
-} else {
-var153 = "*";
-var154 = 1;
-var155 = string__NativeString__to_s_with_length(var153, var154);
-var152 = var155;
-varonce151 = var152;
-}
-var156 = ((short int (*)(val*, val*))(var_pname->class->vft[COLOR_kernel__Object___61d_61d]))(var_pname, var152) /* == on <var_pname:String>*/;
-if (var156){
-var157 = 0;
-var158 = ((val* (*)(val*, long))(var_arguments->class->vft[COLOR_abstract_collection__SequenceRead___91d_93d]))(var_arguments, var157) /* [] on <var_arguments:Array[RuntimeVariable]>*/;
-if (varonce159) {
-var160 = varonce159;
-} else {
-var161 = " * ";
-var162 = 3;
-var163 = string__NativeString__to_s_with_length(var161, var162);
-var160 = var163;
-varonce159 = var160;
-}
-var164 = 1;
-var165 = ((val* (*)(val*, long))(var_arguments->class->vft[COLOR_abstract_collection__SequenceRead___91d_93d]))(var_arguments, var164) /* [] on <var_arguments:Array[RuntimeVariable]>*/;
-var166 = NEW_array__Array(&type_array__Arraykernel__Object);
-{ /* var166 = array_instance Array[Object] */
-var167 = 3;
-var168 = NEW_array__NativeArray(var167, &type_array__NativeArraykernel__Object);
-((struct instance_array__NativeArray*)var168)->values[0] = (val*) var158;
-((struct instance_array__NativeArray*)var168)->values[1] = (val*) var160;
-((struct instance_array__NativeArray*)var168)->values[2] = (val*) var165;
-((void (*)(val*, val*, long))(var166->class->vft[COLOR_array__Array__with_native]))(var166, var168, var167) /* with_native on <var166:Array[Object]>*/;
-CHECK_NEW_array__Array(var166);
-}
-var169 = ((val* (*)(val*))(var166->class->vft[COLOR_string__Object__to_s]))(var166) /* to_s on <var166:Array[Object]>*/;
-if (var_ret == NULL) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "src/abstract_compiler.nit", 1375);
-exit(1);
-}
-var170 = ((val* (*)(val*, val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__new_expr]))(var_v, var169, var_ret) /* new_expr on <var_v:AbstractCompilerVisitor>*/;
-((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__ret]))(var_v, var170) /* ret on <var_v:AbstractCompilerVisitor>*/;
-goto RET_LABEL;
-} else {
-if (varonce171) {
-var172 = varonce171;
-} else {
-var173 = "/";
-var174 = 1;
-var175 = string__NativeString__to_s_with_length(var173, var174);
-var172 = var175;
-varonce171 = var172;
-}
-var176 = ((short int (*)(val*, val*))(var_pname->class->vft[COLOR_kernel__Object___61d_61d]))(var_pname, var172) /* == on <var_pname:String>*/;
-if (var176){
-var177 = 0;
-var178 = ((val* (*)(val*, long))(var_arguments->class->vft[COLOR_abstract_collection__SequenceRead___91d_93d]))(var_arguments, var177) /* [] on <var_arguments:Array[RuntimeVariable]>*/;
-if (varonce179) {
-var180 = varonce179;
-} else {
-var181 = " / ";
-var182 = 3;
-var183 = string__NativeString__to_s_with_length(var181, var182);
-var180 = var183;
-varonce179 = var180;
-}
-var184 = 1;
-var185 = ((val* (*)(val*, long))(var_arguments->class->vft[COLOR_abstract_collection__SequenceRead___91d_93d]))(var_arguments, var184) /* [] on <var_arguments:Array[RuntimeVariable]>*/;
-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*) var178;
-((struct instance_array__NativeArray*)var188)->values[1] = (val*) var180;
-((struct instance_array__NativeArray*)var188)->values[2] = (val*) var185;
-((void (*)(val*, val*, long))(var186->class->vft[COLOR_array__Array__with_native]))(var186, var188, var187) /* with_native on <var186:Array[Object]>*/;
-CHECK_NEW_array__Array(var186);
-}
-var189 = ((val* (*)(val*))(var186->class->vft[COLOR_string__Object__to_s]))(var186) /* to_s on <var186:Array[Object]>*/;
-if (var_ret == NULL) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "src/abstract_compiler.nit", 1378);
-exit(1);
-}
-var190 = ((val* (*)(val*, val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__new_expr]))(var_v, var189, var_ret) /* new_expr on <var_v:AbstractCompilerVisitor>*/;
-((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__ret]))(var_v, var190) /* ret on <var_v:AbstractCompilerVisitor>*/;
-goto RET_LABEL;
-} else {
-if (varonce191) {
-var192 = varonce191;
-} else {
-var193 = "%";
-var194 = 1;
-var195 = string__NativeString__to_s_with_length(var193, var194);
-var192 = var195;
-varonce191 = var192;
-}
-var196 = ((short int (*)(val*, val*))(var_pname->class->vft[COLOR_kernel__Object___61d_61d]))(var_pname, var192) /* == on <var_pname:String>*/;
-if (var196){
-var197 = 0;
-var198 = ((val* (*)(val*, long))(var_arguments->class->vft[COLOR_abstract_collection__SequenceRead___91d_93d]))(var_arguments, var197) /* [] on <var_arguments:Array[RuntimeVariable]>*/;
-if (varonce199) {
-var200 = varonce199;
-} else {
-var201 = " % ";
-var202 = 3;
-var203 = string__NativeString__to_s_with_length(var201, var202);
-var200 = var203;
-varonce199 = var200;
-}
-var204 = 1;
-var205 = ((val* (*)(val*, long))(var_arguments->class->vft[COLOR_abstract_collection__SequenceRead___91d_93d]))(var_arguments, var204) /* [] on <var_arguments:Array[RuntimeVariable]>*/;
-var206 = NEW_array__Array(&type_array__Arraykernel__Object);
-{ /* var206 = array_instance Array[Object] */
-var207 = 3;
-var208 = NEW_array__NativeArray(var207, &type_array__NativeArraykernel__Object);
-((struct instance_array__NativeArray*)var208)->values[0] = (val*) var198;
-((struct instance_array__NativeArray*)var208)->values[1] = (val*) var200;
-((struct instance_array__NativeArray*)var208)->values[2] = (val*) var205;
-((void (*)(val*, val*, long))(var206->class->vft[COLOR_array__Array__with_native]))(var206, var208, var207) /* with_native on <var206:Array[Object]>*/;
-CHECK_NEW_array__Array(var206);
-}
-var209 = ((val* (*)(val*))(var206->class->vft[COLOR_string__Object__to_s]))(var206) /* to_s on <var206:Array[Object]>*/;
-if (var_ret == NULL) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "src/abstract_compiler.nit", 1381);
-exit(1);
-}
-var210 = ((val* (*)(val*, val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__new_expr]))(var_v, var209, var_ret) /* new_expr on <var_v:AbstractCompilerVisitor>*/;
-((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__ret]))(var_v, var210) /* ret on <var_v:AbstractCompilerVisitor>*/;
-goto RET_LABEL;
-} else {
-if (varonce211) {
-var212 = varonce211;
-} else {
-var213 = "lshift";
-var214 = 6;
-var215 = string__NativeString__to_s_with_length(var213, var214);
-var212 = var215;
-varonce211 = var212;
-}
-var216 = ((short int (*)(val*, val*))(var_pname->class->vft[COLOR_kernel__Object___61d_61d]))(var_pname, var212) /* == on <var_pname:String>*/;
-if (var216){
-var217 = 0;
-var218 = ((val* (*)(val*, long))(var_arguments->class->vft[COLOR_abstract_collection__SequenceRead___91d_93d]))(var_arguments, var217) /* [] on <var_arguments:Array[RuntimeVariable]>*/;
-if (varonce219) {
-var220 = varonce219;
-} else {
-var221 = " << ";
-var222 = 4;
-var223 = string__NativeString__to_s_with_length(var221, var222);
-var220 = var223;
-varonce219 = var220;
-}
-var224 = 1;
-var225 = ((val* (*)(val*, long))(var_arguments->class->vft[COLOR_abstract_collection__SequenceRead___91d_93d]))(var_arguments, var224) /* [] on <var_arguments:Array[RuntimeVariable]>*/;
-var226 = NEW_array__Array(&type_array__Arraykernel__Object);
-{ /* var226 = array_instance Array[Object] */
-var227 = 3;
-var228 = NEW_array__NativeArray(var227, &type_array__NativeArraykernel__Object);
-((struct instance_array__NativeArray*)var228)->values[0] = (val*) var218;
-((struct instance_array__NativeArray*)var228)->values[1] = (val*) var220;
-((struct instance_array__NativeArray*)var228)->values[2] = (val*) var225;
-((void (*)(val*, val*, long))(var226->class->vft[COLOR_array__Array__with_native]))(var226, var228, var227) /* with_native on <var226:Array[Object]>*/;
-CHECK_NEW_array__Array(var226);
-}
-var229 = ((val* (*)(val*))(var226->class->vft[COLOR_string__Object__to_s]))(var226) /* to_s on <var226:Array[Object]>*/;
-if (var_ret == NULL) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "src/abstract_compiler.nit", 1384);
-exit(1);
-}
-var230 = ((val* (*)(val*, val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__new_expr]))(var_v, var229, var_ret) /* new_expr on <var_v:AbstractCompilerVisitor>*/;
-((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__ret]))(var_v, var230) /* ret on <var_v:AbstractCompilerVisitor>*/;
-goto RET_LABEL;
-} else {
-if (varonce231) {
-var232 = varonce231;
-} else {
-var233 = "rshift";
-var234 = 6;
-var235 = string__NativeString__to_s_with_length(var233, var234);
-var232 = var235;
-varonce231 = var232;
 }
-var236 = ((short int (*)(val*, val*))(var_pname->class->vft[COLOR_kernel__Object___61d_61d]))(var_pname, var232) /* == on <var_pname:String>*/;
-if (var236){
-var237 = 0;
-var238 = ((val* (*)(val*, long))(var_arguments->class->vft[COLOR_abstract_collection__SequenceRead___91d_93d]))(var_arguments, var237) /* [] on <var_arguments:Array[RuntimeVariable]>*/;
-if (varonce239) {
-var240 = varonce239;
-} else {
-var241 = " >> ";
-var242 = 4;
-var243 = string__NativeString__to_s_with_length(var241, var242);
-var240 = var243;
-varonce239 = var240;
+var_vararg_len = var15;
+var19 = 0;
+{
+{ /* Inline kernel#Int#< (var_vararg_len,var19) on <var_vararg_len:Int> */
+/* Covariant cast for argument 0 (i) <var19:Int> isa OTHER */
+/* <var19:Int> isa OTHER */
+var22 = 1; /* easy <var19:Int> isa OTHER*/
+if (unlikely(!var22)) {
+var_class_name25 = type_kernel__Int.name;
+PRINT_ERROR("Runtime error: Cast failed. Expected `%s`, got `%s`", "OTHER", var_class_name25);
+PRINT_ERROR(" (%s:%d)\n", "../lib/standard/kernel.nit", 371);
+show_backtrace(1);
 }
-var244 = 1;
-var245 = ((val* (*)(val*, long))(var_arguments->class->vft[COLOR_abstract_collection__SequenceRead___91d_93d]))(var_arguments, var244) /* [] on <var_arguments:Array[RuntimeVariable]>*/;
-var246 = NEW_array__Array(&type_array__Arraykernel__Object);
-{ /* var246 = array_instance Array[Object] */
-var247 = 3;
-var248 = NEW_array__NativeArray(var247, &type_array__NativeArraykernel__Object);
-((struct instance_array__NativeArray*)var248)->values[0] = (val*) var238;
-((struct instance_array__NativeArray*)var248)->values[1] = (val*) var240;
-((struct instance_array__NativeArray*)var248)->values[2] = (val*) var245;
-((void (*)(val*, val*, long))(var246->class->vft[COLOR_array__Array__with_native]))(var246, var248, var247) /* with_native on <var246:Array[Object]>*/;
-CHECK_NEW_array__Array(var246);
-}
-var249 = ((val* (*)(val*))(var246->class->vft[COLOR_string__Object__to_s]))(var246) /* to_s on <var246:Array[Object]>*/;
-if (var_ret == NULL) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "src/abstract_compiler.nit", 1387);
-exit(1);
-}
-var250 = ((val* (*)(val*, val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__new_expr]))(var_v, var249, var_ret) /* new_expr on <var_v:AbstractCompilerVisitor>*/;
-((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__ret]))(var_v, var250) /* ret on <var_v:AbstractCompilerVisitor>*/;
-goto RET_LABEL;
-} else {
-if (varonce251) {
-var252 = varonce251;
-} else {
-var253 = "==";
-var254 = 2;
-var255 = string__NativeString__to_s_with_length(var253, var254);
-var252 = var255;
-varonce251 = var252;
-}
-var256 = ((short int (*)(val*, val*))(var_pname->class->vft[COLOR_kernel__Object___61d_61d]))(var_pname, var252) /* == on <var_pname:String>*/;
-if (var256){
-var257 = 0;
-var258 = ((val* (*)(val*, long))(var_arguments->class->vft[COLOR_abstract_collection__SequenceRead___91d_93d]))(var_arguments, var257) /* [] on <var_arguments:Array[RuntimeVariable]>*/;
-var259 = 1;
-var260 = ((val* (*)(val*, long))(var_arguments->class->vft[COLOR_abstract_collection__SequenceRead___91d_93d]))(var_arguments, var259) /* [] on <var_arguments:Array[RuntimeVariable]>*/;
-var261 = ((val* (*)(val*, val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__equal_test]))(var_v, var258, var260) /* equal_test on <var_v:AbstractCompilerVisitor>*/;
-((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__ret]))(var_v, var261) /* ret on <var_v:AbstractCompilerVisitor>*/;
-goto RET_LABEL;
-} else {
-if (varonce262) {
-var263 = varonce262;
-} else {
-var264 = "!=";
-var265 = 2;
-var266 = string__NativeString__to_s_with_length(var264, var265);
-var263 = var266;
-varonce262 = var263;
-}
-var267 = ((short int (*)(val*, val*))(var_pname->class->vft[COLOR_kernel__Object___61d_61d]))(var_pname, var263) /* == on <var_pname:String>*/;
-if (var267){
-var268 = 0;
-var269 = ((val* (*)(val*, long))(var_arguments->class->vft[COLOR_abstract_collection__SequenceRead___91d_93d]))(var_arguments, var268) /* [] on <var_arguments:Array[RuntimeVariable]>*/;
-var270 = 1;
-var271 = ((val* (*)(val*, long))(var_arguments->class->vft[COLOR_abstract_collection__SequenceRead___91d_93d]))(var_arguments, var270) /* [] on <var_arguments:Array[RuntimeVariable]>*/;
-var272 = ((val* (*)(val*, val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__equal_test]))(var_v, var269, var271) /* equal_test on <var_v:AbstractCompilerVisitor>*/;
-var_res = var272;
-if (varonce273) {
-var274 = varonce273;
-} else {
-var275 = "!";
-var276 = 1;
-var277 = string__NativeString__to_s_with_length(var275, var276);
-var274 = var277;
-varonce273 = var274;
-}
-var278 = NEW_array__Array(&type_array__Arraykernel__Object);
-{ /* var278 = array_instance Array[Object] */
-var279 = 2;
-var280 = NEW_array__NativeArray(var279, &type_array__NativeArraykernel__Object);
-((struct instance_array__NativeArray*)var280)->values[0] = (val*) var274;
-((struct instance_array__NativeArray*)var280)->values[1] = (val*) var_res;
-((void (*)(val*, val*, long))(var278->class->vft[COLOR_array__Array__with_native]))(var278, var280, var279) /* with_native on <var278:Array[Object]>*/;
-CHECK_NEW_array__Array(var278);
-}
-var281 = ((val* (*)(val*))(var278->class->vft[COLOR_string__Object__to_s]))(var278) /* to_s on <var278:Array[Object]>*/;
-if (var_ret == NULL) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "src/abstract_compiler.nit", 1394);
-exit(1);
-}
-var282 = ((val* (*)(val*, val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__new_expr]))(var_v, var281, var_ret) /* new_expr on <var_v:AbstractCompilerVisitor>*/;
-((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__ret]))(var_v, var282) /* ret on <var_v:AbstractCompilerVisitor>*/;
-goto RET_LABEL;
-} else {
-if (varonce283) {
-var284 = varonce283;
-} else {
-var285 = "<";
-var286 = 1;
-var287 = string__NativeString__to_s_with_length(var285, var286);
-var284 = var287;
-varonce283 = var284;
-}
-var288 = ((short int (*)(val*, val*))(var_pname->class->vft[COLOR_kernel__Object___61d_61d]))(var_pname, var284) /* == on <var_pname:String>*/;
-if (var288){
-var289 = 0;
-var290 = ((val* (*)(val*, long))(var_arguments->class->vft[COLOR_abstract_collection__SequenceRead___91d_93d]))(var_arguments, var289) /* [] on <var_arguments:Array[RuntimeVariable]>*/;
-if (varonce291) {
-var292 = varonce291;
-} else {
-var293 = " < ";
-var294 = 3;
-var295 = string__NativeString__to_s_with_length(var293, var294);
-var292 = var295;
-varonce291 = var292;
-}
-var296 = 1;
-var297 = ((val* (*)(val*, long))(var_arguments->class->vft[COLOR_abstract_collection__SequenceRead___91d_93d]))(var_arguments, var296) /* [] on <var_arguments:Array[RuntimeVariable]>*/;
-var298 = NEW_array__Array(&type_array__Arraykernel__Object);
-{ /* var298 = array_instance Array[Object] */
-var299 = 3;
-var300 = NEW_array__NativeArray(var299, &type_array__NativeArraykernel__Object);
-((struct instance_array__NativeArray*)var300)->values[0] = (val*) var290;
-((struct instance_array__NativeArray*)var300)->values[1] = (val*) var292;
-((struct instance_array__NativeArray*)var300)->values[2] = (val*) var297;
-((void (*)(val*, val*, long))(var298->class->vft[COLOR_array__Array__with_native]))(var298, var300, var299) /* with_native on <var298:Array[Object]>*/;
-CHECK_NEW_array__Array(var298);
-}
-var301 = ((val* (*)(val*))(var298->class->vft[COLOR_string__Object__to_s]))(var298) /* to_s on <var298:Array[Object]>*/;
-if (var_ret == NULL) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "src/abstract_compiler.nit", 1397);
-exit(1);
-}
-var302 = ((val* (*)(val*, val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__new_expr]))(var_v, var301, var_ret) /* new_expr on <var_v:AbstractCompilerVisitor>*/;
-((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__ret]))(var_v, var302) /* ret on <var_v:AbstractCompilerVisitor>*/;
-goto RET_LABEL;
-} else {
-if (varonce303) {
-var304 = varonce303;
-} else {
-var305 = ">";
-var306 = 1;
-var307 = string__NativeString__to_s_with_length(var305, var306);
-var304 = var307;
-varonce303 = var304;
-}
-var308 = ((short int (*)(val*, val*))(var_pname->class->vft[COLOR_kernel__Object___61d_61d]))(var_pname, var304) /* == on <var_pname:String>*/;
-if (var308){
-var309 = 0;
-var310 = ((val* (*)(val*, long))(var_arguments->class->vft[COLOR_abstract_collection__SequenceRead___91d_93d]))(var_arguments, var309) /* [] on <var_arguments:Array[RuntimeVariable]>*/;
-if (varonce311) {
-var312 = varonce311;
-} else {
-var313 = " > ";
-var314 = 3;
-var315 = string__NativeString__to_s_with_length(var313, var314);
-var312 = var315;
-varonce311 = var312;
-}
-var316 = 1;
-var317 = ((val* (*)(val*, long))(var_arguments->class->vft[COLOR_abstract_collection__SequenceRead___91d_93d]))(var_arguments, var316) /* [] on <var_arguments:Array[RuntimeVariable]>*/;
-var318 = NEW_array__Array(&type_array__Arraykernel__Object);
-{ /* var318 = array_instance Array[Object] */
-var319 = 3;
-var320 = NEW_array__NativeArray(var319, &type_array__NativeArraykernel__Object);
-((struct instance_array__NativeArray*)var320)->values[0] = (val*) var310;
-((struct instance_array__NativeArray*)var320)->values[1] = (val*) var312;
-((struct instance_array__NativeArray*)var320)->values[2] = (val*) var317;
-((void (*)(val*, val*, long))(var318->class->vft[COLOR_array__Array__with_native]))(var318, var320, var319) /* with_native on <var318:Array[Object]>*/;
-CHECK_NEW_array__Array(var318);
-}
-var321 = ((val* (*)(val*))(var318->class->vft[COLOR_string__Object__to_s]))(var318) /* to_s on <var318:Array[Object]>*/;
-if (var_ret == NULL) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "src/abstract_compiler.nit", 1400);
-exit(1);
-}
-var322 = ((val* (*)(val*, val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__new_expr]))(var_v, var321, var_ret) /* new_expr on <var_v:AbstractCompilerVisitor>*/;
-((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__ret]))(var_v, var322) /* ret on <var_v:AbstractCompilerVisitor>*/;
-goto RET_LABEL;
-} else {
-if (varonce323) {
-var324 = varonce323;
-} else {
-var325 = "<=";
-var326 = 2;
-var327 = string__NativeString__to_s_with_length(var325, var326);
-var324 = var327;
-varonce323 = var324;
+var26 = var_vararg_len < var19;
+var20 = var26;
+goto RET_LABEL21;
+RET_LABEL21:(void)0;
 }
-var328 = ((short int (*)(val*, val*))(var_pname->class->vft[COLOR_kernel__Object___61d_61d]))(var_pname, var324) /* == on <var_pname:String>*/;
-if (var328){
-var329 = 0;
-var330 = ((val* (*)(val*, long))(var_arguments->class->vft[COLOR_abstract_collection__SequenceRead___91d_93d]))(var_arguments, var329) /* [] on <var_arguments:Array[RuntimeVariable]>*/;
-if (varonce331) {
-var332 = varonce331;
-} else {
-var333 = " <= ";
-var334 = 4;
-var335 = string__NativeString__to_s_with_length(var333, var334);
-var332 = var335;
-varonce331 = var332;
 }
-var336 = 1;
-var337 = ((val* (*)(val*, long))(var_arguments->class->vft[COLOR_abstract_collection__SequenceRead___91d_93d]))(var_arguments, var336) /* [] on <var_arguments:Array[RuntimeVariable]>*/;
-var338 = NEW_array__Array(&type_array__Arraykernel__Object);
-{ /* var338 = array_instance Array[Object] */
-var339 = 3;
-var340 = NEW_array__NativeArray(var339, &type_array__NativeArraykernel__Object);
-((struct instance_array__NativeArray*)var340)->values[0] = (val*) var330;
-((struct instance_array__NativeArray*)var340)->values[1] = (val*) var332;
-((struct instance_array__NativeArray*)var340)->values[2] = (val*) var337;
-((void (*)(val*, val*, long))(var338->class->vft[COLOR_array__Array__with_native]))(var338, var340, var339) /* with_native on <var338:Array[Object]>*/;
-CHECK_NEW_array__Array(var338);
-}
-var341 = ((val* (*)(val*))(var338->class->vft[COLOR_string__Object__to_s]))(var338) /* to_s on <var338:Array[Object]>*/;
-if (var_ret == NULL) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "src/abstract_compiler.nit", 1403);
-exit(1);
-}
-var342 = ((val* (*)(val*, val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__new_expr]))(var_v, var341, var_ret) /* new_expr on <var_v:AbstractCompilerVisitor>*/;
-((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__ret]))(var_v, var342) /* ret on <var_v:AbstractCompilerVisitor>*/;
-goto RET_LABEL;
-} else {
-if (varonce343) {
-var344 = varonce343;
+if (var20){
+var27 = 0;
+var_vararg_len = var27;
 } else {
-var345 = ">=";
-var346 = 2;
-var347 = string__NativeString__to_s_with_length(var345, var346);
-var344 = var347;
-varonce343 = var344;
 }
-var348 = ((short int (*)(val*, val*))(var_pname->class->vft[COLOR_kernel__Object___61d_61d]))(var_pname, var344) /* == on <var_pname:String>*/;
-if (var348){
-var349 = 0;
-var350 = ((val* (*)(val*, long))(var_arguments->class->vft[COLOR_abstract_collection__SequenceRead___91d_93d]))(var_arguments, var349) /* [] on <var_arguments:Array[RuntimeVariable]>*/;
-if (varonce351) {
-var352 = varonce351;
-} else {
-var353 = " >= ";
-var354 = 4;
-var355 = string__NativeString__to_s_with_length(var353, var354);
-var352 = var355;
-varonce351 = var352;
+var28 = 0;
+var_i = var28;
+{
+var29 = model__MSignature__arity(var_msignature);
 }
-var356 = 1;
-var357 = ((val* (*)(val*, long))(var_arguments->class->vft[COLOR_abstract_collection__SequenceRead___91d_93d]))(var_arguments, var356) /* [] on <var_arguments:Array[RuntimeVariable]>*/;
-var358 = NEW_array__Array(&type_array__Arraykernel__Object);
-{ /* var358 = array_instance Array[Object] */
-var359 = 3;
-var360 = NEW_array__NativeArray(var359, &type_array__NativeArraykernel__Object);
-((struct instance_array__NativeArray*)var360)->values[0] = (val*) var350;
-((struct instance_array__NativeArray*)var360)->values[1] = (val*) var352;
-((struct instance_array__NativeArray*)var360)->values[2] = (val*) var357;
-((void (*)(val*, val*, long))(var358->class->vft[COLOR_array__Array__with_native]))(var358, var360, var359) /* with_native on <var358:Array[Object]>*/;
-CHECK_NEW_array__Array(var358);
-}
-var361 = ((val* (*)(val*))(var358->class->vft[COLOR_string__Object__to_s]))(var358) /* to_s on <var358:Array[Object]>*/;
-if (var_ret == NULL) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "src/abstract_compiler.nit", 1406);
-exit(1);
-}
-var362 = ((val* (*)(val*, val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__new_expr]))(var_v, var361, var_ret) /* new_expr on <var_v:AbstractCompilerVisitor>*/;
-((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__ret]))(var_v, var362) /* ret on <var_v:AbstractCompilerVisitor>*/;
-goto RET_LABEL;
-} else {
-if (varonce363) {
-var364 = varonce363;
-} else {
-var365 = "to_f";
-var366 = 4;
-var367 = string__NativeString__to_s_with_length(var365, var366);
-var364 = var367;
-varonce363 = var364;
-}
-var368 = ((short int (*)(val*, val*))(var_pname->class->vft[COLOR_kernel__Object___61d_61d]))(var_pname, var364) /* == on <var_pname:String>*/;
-if (var368){
-if (varonce369) {
-var370 = varonce369;
-} else {
-var371 = "(double)";
-var372 = 8;
-var373 = string__NativeString__to_s_with_length(var371, var372);
-var370 = var373;
-varonce369 = var370;
-}
-var374 = 0;
-var375 = ((val* (*)(val*, long))(var_arguments->class->vft[COLOR_abstract_collection__SequenceRead___91d_93d]))(var_arguments, var374) /* [] on <var_arguments:Array[RuntimeVariable]>*/;
-var376 = NEW_array__Array(&type_array__Arraykernel__Object);
-{ /* var376 = array_instance Array[Object] */
-var377 = 2;
-var378 = NEW_array__NativeArray(var377, &type_array__NativeArraykernel__Object);
-((struct instance_array__NativeArray*)var378)->values[0] = (val*) var370;
-((struct instance_array__NativeArray*)var378)->values[1] = (val*) var375;
-((void (*)(val*, val*, long))(var376->class->vft[COLOR_array__Array__with_native]))(var376, var378, var377) /* with_native on <var376:Array[Object]>*/;
-CHECK_NEW_array__Array(var376);
-}
-var379 = ((val* (*)(val*))(var376->class->vft[COLOR_string__Object__to_s]))(var376) /* to_s on <var376:Array[Object]>*/;
-if (var_ret == NULL) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "src/abstract_compiler.nit", 1409);
-exit(1);
-}
-var380 = ((val* (*)(val*, val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__new_expr]))(var_v, var379, var_ret) /* new_expr on <var_v:AbstractCompilerVisitor>*/;
-((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__ret]))(var_v, var380) /* ret on <var_v:AbstractCompilerVisitor>*/;
-goto RET_LABEL;
-} else {
-if (varonce381) {
-var382 = varonce381;
-} else {
-var383 = "ascii";
-var384 = 5;
-var385 = string__NativeString__to_s_with_length(var383, var384);
-var382 = var385;
-varonce381 = var382;
-}
-var386 = ((short int (*)(val*, val*))(var_pname->class->vft[COLOR_kernel__Object___61d_61d]))(var_pname, var382) /* == on <var_pname:String>*/;
-if (var386){
-var387 = 0;
-var388 = ((val* (*)(val*, long))(var_arguments->class->vft[COLOR_abstract_collection__SequenceRead___91d_93d]))(var_arguments, var387) /* [] on <var_arguments:Array[RuntimeVariable]>*/;
-var389 = NEW_array__Array(&type_array__Arraykernel__Object);
-{ /* var389 = array_instance Array[Object] */
-var390 = 1;
-var391 = NEW_array__NativeArray(var390, &type_array__NativeArraykernel__Object);
-((struct instance_array__NativeArray*)var391)->values[0] = (val*) var388;
-((void (*)(val*, val*, long))(var389->class->vft[COLOR_array__Array__with_native]))(var389, var391, var390) /* with_native on <var389:Array[Object]>*/;
-CHECK_NEW_array__Array(var389);
-}
-var392 = ((val* (*)(val*))(var389->class->vft[COLOR_string__Object__to_s]))(var389) /* to_s on <var389:Array[Object]>*/;
-if (var_ret == NULL) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "src/abstract_compiler.nit", 1412);
-exit(1);
-}
-var393 = ((val* (*)(val*, val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__new_expr]))(var_v, var392, var_ret) /* new_expr on <var_v:AbstractCompilerVisitor>*/;
-((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__ret]))(var_v, var393) /* ret on <var_v:AbstractCompilerVisitor>*/;
-goto RET_LABEL;
+var_ = var29;
+for(;;) {
+{
+{ /* Inline kernel#Int#< (var_i,var_) on <var_i:Int> */
+/* Covariant cast for argument 0 (i) <var_:Int> isa OTHER */
+/* <var_:Int> isa OTHER */
+var32 = 1; /* easy <var_:Int> isa OTHER*/
+if (unlikely(!var32)) {
+var_class_name35 = type_kernel__Int.name;
+PRINT_ERROR("Runtime error: Cast failed. Expected `%s`, got `%s`", "OTHER", var_class_name35);
+PRINT_ERROR(" (%s:%d)\n", "../lib/standard/kernel.nit", 371);
+show_backtrace(1);
+}
+var36 = var_i < var_;
+var30 = var36;
+goto RET_LABEL31;
+RET_LABEL31:(void)0;
+}
+}
+if (var30){
+{
+{ /* Inline kernel#Int#== (var_i,var_vararg_rank) on <var_i:Int> */
+var40 = var_i == var_vararg_rank;
+var38 = var40;
+goto RET_LABEL39;
+RET_LABEL39:(void)0;
+}
+var37 = var38;
+}
+if (var37){
+{
+var41 = ((val* (*)(val*, long))(var_args->class->vft[COLOR_abstract_collection__SequenceRead___91d_93d]))(var_args, var_i) /* [] on <var_args:SequenceRead[AExpr]>*/;
+}
+var_ne = var41;
+/* <var_ne:AExpr> isa AVarargExpr */
+cltype43 = type_parser_nodes__AVarargExpr.color;
+idtype44 = type_parser_nodes__AVarargExpr.id;
+if(cltype43 >= var_ne->type->table_size) {
+var42 = 0;
+} else {
+var42 = var_ne->type->type_table[cltype43] == idtype44;
+}
+if (var42){
+{
+{ /* Inline parser_nodes#AVarargExpr#n_expr (var_ne) on <var_ne:AExpr(AVarargExpr)> */
+var47 = var_ne->attrs[COLOR_parser_nodes__AVarargExpr___n_expr].val; /* _n_expr on <var_ne:AExpr(AVarargExpr)> */
+if (unlikely(var47 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _n_expr");
+PRINT_ERROR(" (%s:%d)\n", "parser/parser_nodes.nit", 1902);
+show_backtrace(1);
+}
+var45 = var47;
+RET_LABEL46:(void)0;
+}
+}
+var48 = NULL;
+{
+var49 = abstract_compiler__AbstractCompilerVisitor__expr(self, var45, var48);
+}
+var_e = var49;
+{
+array__Array__add(var_res, var_e); /* Direct call array#Array#add on <var_res:Array[RuntimeVariable]>*/
+}
+goto BREAK_label;
 } else {
 }
+var50 = NEW_array__Array(&type_array__Arrayabstract_compiler__RuntimeVariable);
+{
+((void (*)(val*))(var50->class->vft[COLOR_kernel__Object__init]))(var50) /* init on <var50:Array[RuntimeVariable]>*/;
+}
+var_vararg = var50;
+var_j = var_vararg_rank;
+{
+{ /* Inline kernel#Int#+ (var_vararg_rank,var_vararg_len) on <var_vararg_rank:Int> */
+/* Covariant cast for argument 0 (i) <var_vararg_len:Int> isa OTHER */
+/* <var_vararg_len:Int> isa OTHER */
+var53 = 1; /* easy <var_vararg_len:Int> isa OTHER*/
+if (unlikely(!var53)) {
+var_class_name56 = type_kernel__Int.name;
+PRINT_ERROR("Runtime error: Cast failed. Expected `%s`, got `%s`", "OTHER", var_class_name56);
+PRINT_ERROR(" (%s:%d)\n", "../lib/standard/kernel.nit", 374);
+show_backtrace(1);
 }
+var57 = var_vararg_rank + var_vararg_len;
+var51 = var57;
+goto RET_LABEL52;
+RET_LABEL52:(void)0;
 }
 }
+var_58 = var51;
+for(;;) {
+{
+{ /* Inline kernel#Int#<= (var_j,var_58) on <var_j:Int> */
+/* Covariant cast for argument 0 (i) <var_58:Int> isa OTHER */
+/* <var_58:Int> isa OTHER */
+var61 = 1; /* easy <var_58:Int> isa OTHER*/
+if (unlikely(!var61)) {
+var_class_name64 = type_kernel__Int.name;
+PRINT_ERROR("Runtime error: Cast failed. Expected `%s`, got `%s`", "OTHER", var_class_name64);
+PRINT_ERROR(" (%s:%d)\n", "../lib/standard/kernel.nit", 370);
+show_backtrace(1);
+}
+var65 = var_j <= var_58;
+var59 = var65;
+goto RET_LABEL60;
+RET_LABEL60:(void)0;
+}
 }
+if (var59){
+{
+var66 = ((val* (*)(val*, long))(var_args->class->vft[COLOR_abstract_collection__SequenceRead___91d_93d]))(var_args, var_j) /* [] on <var_args:SequenceRead[AExpr]>*/;
 }
+var67 = NULL;
+{
+var68 = abstract_compiler__AbstractCompilerVisitor__expr(self, var66, var67);
 }
+var_e69 = var68;
+{
+array__Array__add(var_vararg, var_e69); /* Direct call array#Array#add on <var_vararg:Array[RuntimeVariable]>*/
 }
+var70 = 1;
+{
+var71 = kernel__Int__successor(var_j, var70);
 }
+var_j = var71;
+} else {
+goto BREAK_label72;
 }
 }
+BREAK_label72: (void)0;
+{
+{ /* Inline model#MSignature#mparameters (var_msignature) on <var_msignature:MSignature> */
+var75 = var_msignature->attrs[COLOR_model__MSignature___mparameters].val; /* _mparameters on <var_msignature:MSignature> */
+if (unlikely(var75 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _mparameters");
+PRINT_ERROR(" (%s:%d)\n", "model/model.nit", 1465);
+show_backtrace(1);
 }
+var73 = var75;
+RET_LABEL74:(void)0;
 }
 }
+{
+var76 = array__Array___91d_93d(var73, var_vararg_rank);
 }
+{
+{ /* Inline model#MParameter#mtype (var76) on <var76:nullable Object(MParameter)> */
+var79 = var76->attrs[COLOR_model__MParameter___mtype].val; /* _mtype on <var76:nullable Object(MParameter)> */
+if (unlikely(var79 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _mtype");
+PRINT_ERROR(" (%s:%d)\n", "model/model.nit", 1565);
+show_backtrace(1);
 }
+var77 = var79;
+RET_LABEL78:(void)0;
 }
 }
+var_elttype = var77;
+{
+var80 = separate_compiler__SeparateCompilerVisitor__vararg_instance(self, var_mpropdef, var_recv, var_vararg, var_elttype);
 }
+var_arg = var80;
+{
+array__Array__add(var_res, var_arg); /* Direct call array#Array#add on <var_res:Array[RuntimeVariable]>*/
 }
 } else {
-if (varonce394) {
-var395 = varonce394;
-} else {
-var396 = "Char";
-var397 = 4;
-var398 = string__NativeString__to_s_with_length(var396, var397);
-var395 = var398;
-varonce394 = var395;
+var_j81 = var_i;
+{
+{ /* Inline kernel#Int#> (var_i,var_vararg_rank) on <var_i:Int> */
+/* Covariant cast for argument 0 (i) <var_vararg_rank:Int> isa OTHER */
+/* <var_vararg_rank:Int> isa OTHER */
+var84 = 1; /* easy <var_vararg_rank:Int> isa OTHER*/
+if (unlikely(!var84)) {
+var_class_name87 = type_kernel__Int.name;
+PRINT_ERROR("Runtime error: Cast failed. Expected `%s`, got `%s`", "OTHER", var_class_name87);
+PRINT_ERROR(" (%s:%d)\n", "../lib/standard/kernel.nit", 373);
+show_backtrace(1);
+}
+var88 = var_i > var_vararg_rank;
+var82 = var88;
+goto RET_LABEL83;
+RET_LABEL83:(void)0;
 }
-var399 = ((short int (*)(val*, val*))(var_cname->class->vft[COLOR_kernel__Object___61d_61d]))(var_cname, var395) /* == on <var_cname:String>*/;
-if (var399){
-if (varonce400) {
-var401 = varonce400;
-} else {
-var402 = "output";
-var403 = 6;
-var404 = string__NativeString__to_s_with_length(var402, var403);
-var401 = var404;
-varonce400 = var401;
 }
-var405 = ((short int (*)(val*, val*))(var_pname->class->vft[COLOR_kernel__Object___61d_61d]))(var_pname, var401) /* == on <var_pname:String>*/;
-if (var405){
-if (varonce406) {
-var407 = varonce406;
+if (var82){
+{
+{ /* Inline kernel#Int#+ (var_j81,var_vararg_len) on <var_j81:Int> */
+/* Covariant cast for argument 0 (i) <var_vararg_len:Int> isa OTHER */
+/* <var_vararg_len:Int> isa OTHER */
+var91 = 1; /* easy <var_vararg_len:Int> isa OTHER*/
+if (unlikely(!var91)) {
+var_class_name94 = type_kernel__Int.name;
+PRINT_ERROR("Runtime error: Cast failed. Expected `%s`, got `%s`", "OTHER", var_class_name94);
+PRINT_ERROR(" (%s:%d)\n", "../lib/standard/kernel.nit", 374);
+show_backtrace(1);
+}
+var95 = var_j81 + var_vararg_len;
+var89 = var95;
+goto RET_LABEL90;
+RET_LABEL90:(void)0;
+}
+}
+var_j81 = var89;
 } else {
-var408 = "printf(\"%c\", ";
-var409 = 13;
-var410 = string__NativeString__to_s_with_length(var408, var409);
-var407 = var410;
-varonce406 = var407;
 }
-var411 = ((val* (*)(val*))(var_arguments->class->vft[COLOR_abstract_collection__Collection__first]))(var_arguments) /* first on <var_arguments:Array[RuntimeVariable]>*/;
-if (varonce412) {
-var413 = varonce412;
+{
+var96 = ((val* (*)(val*, long))(var_args->class->vft[COLOR_abstract_collection__SequenceRead___91d_93d]))(var_args, var_j81) /* [] on <var_args:SequenceRead[AExpr]>*/;
+}
+var97 = NULL;
+{
+var98 = abstract_compiler__AbstractCompilerVisitor__expr(self, var96, var97);
+}
+var_e99 = var98;
+{
+array__Array__add(var_res, var_e99); /* Direct call array#Array#add on <var_res:Array[RuntimeVariable]>*/
+}
+}
+BREAK_label: (void)0;
+var100 = 1;
+{
+var101 = kernel__Int__successor(var_i, var100);
+}
+var_i = var101;
 } else {
-var414 = ");";
-var415 = 2;
-var416 = string__NativeString__to_s_with_length(var414, var415);
-var413 = var416;
-varonce412 = var413;
+goto BREAK_label102;
+}
 }
-var417 = NEW_array__Array(&type_array__Arraykernel__Object);
-{ /* var417 = array_instance Array[Object] */
-var418 = 3;
-var419 = NEW_array__NativeArray(var418, &type_array__NativeArraykernel__Object);
-((struct instance_array__NativeArray*)var419)->values[0] = (val*) var407;
-((struct instance_array__NativeArray*)var419)->values[1] = (val*) var411;
-((struct instance_array__NativeArray*)var419)->values[2] = (val*) var413;
-((void (*)(val*, val*, long))(var417->class->vft[COLOR_array__Array__with_native]))(var417, var419, var418) /* with_native on <var417:Array[Object]>*/;
-CHECK_NEW_array__Array(var417);
-}
-var420 = ((val* (*)(val*))(var417->class->vft[COLOR_string__Object__to_s]))(var417) /* to_s on <var417:Array[Object]>*/;
-((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(var_v, var420) /* add on <var_v:AbstractCompilerVisitor>*/;
+BREAK_label102: (void)0;
+var = var_res;
 goto RET_LABEL;
-} else {
-if (varonce421) {
-var422 = varonce421;
-} else {
-var423 = "object_id";
-var424 = 9;
-var425 = string__NativeString__to_s_with_length(var423, var424);
-var422 = var425;
-varonce421 = var422;
+RET_LABEL:;
+return var;
 }
-var426 = ((short int (*)(val*, val*))(var_pname->class->vft[COLOR_kernel__Object___61d_61d]))(var_pname, var422) /* == on <var_pname:String>*/;
-if (var426){
-if (varonce427) {
-var428 = varonce427;
-} else {
-var429 = "(long)";
-var430 = 6;
-var431 = string__NativeString__to_s_with_length(var429, var430);
-var428 = var431;
-varonce427 = var428;
+/* method abstract_compiler#AbstractCompilerVisitor#varargize for (self: Object, MMethodDef, RuntimeVariable, SequenceRead[AExpr]): Array[RuntimeVariable] */
+val* VIRTUAL_abstract_compiler__AbstractCompilerVisitor__varargize(val* self, val* p0, val* p1, val* p2) {
+val* var /* : Array[RuntimeVariable] */;
+val* var1 /* : Array[RuntimeVariable] */;
+var1 = abstract_compiler__AbstractCompilerVisitor__varargize(self, p0, p1, p2);
+var = var1;
+RET_LABEL:;
+return var;
 }
-var432 = ((val* (*)(val*))(var_arguments->class->vft[COLOR_abstract_collection__Collection__first]))(var_arguments) /* first on <var_arguments:Array[RuntimeVariable]>*/;
-var433 = NEW_array__Array(&type_array__Arraykernel__Object);
-{ /* var433 = array_instance Array[Object] */
-var434 = 2;
-var435 = NEW_array__NativeArray(var434, &type_array__NativeArraykernel__Object);
-((struct instance_array__NativeArray*)var435)->values[0] = (val*) var428;
-((struct instance_array__NativeArray*)var435)->values[1] = (val*) var432;
-((void (*)(val*, val*, long))(var433->class->vft[COLOR_array__Array__with_native]))(var433, var435, var434) /* with_native on <var433:Array[Object]>*/;
-CHECK_NEW_array__Array(var433);
-}
-var436 = ((val* (*)(val*))(var433->class->vft[COLOR_string__Object__to_s]))(var433) /* to_s on <var433:Array[Object]>*/;
-if (var_ret == NULL) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "src/abstract_compiler.nit", 1420);
-exit(1);
-}
-var437 = ((val* (*)(val*, val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__new_expr]))(var_v, var436, var_ret) /* new_expr on <var_v:AbstractCompilerVisitor>*/;
-((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__ret]))(var_v, var437) /* ret on <var_v:AbstractCompilerVisitor>*/;
+/* method abstract_compiler#AbstractCompilerVisitor#anchor for (self: AbstractCompilerVisitor, MType): MType */
+val* abstract_compiler__AbstractCompilerVisitor__anchor(val* self, val* p0) {
+val* var /* : MType */;
+val* var_mtype /* var mtype: MType */;
+short int var1 /* : Bool */;
+short int var2 /* : Bool */;
+val* var3 /* : AbstractCompiler */;
+val* var5 /* : AbstractCompiler */;
+val* var6 /* : MModule */;
+val* var8 /* : MModule */;
+val* var9 /* : nullable Frame */;
+val* var11 /* : nullable Frame */;
+val* var12 /* : MClassType */;
+val* var14 /* : MClassType */;
+val* var15 /* : MType */;
+var_mtype = p0;
+{
+var1 = ((short int (*)(val*))(var_mtype->class->vft[COLOR_model__MType__need_anchor]))(var_mtype) /* need_anchor on <var_mtype:MType>*/;
+}
+var2 = !var1;
+if (var2){
+var = var_mtype;
 goto RET_LABEL;
 } else {
-if (varonce438) {
-var439 = varonce438;
-} else {
-var440 = "+";
-var441 = 1;
-var442 = string__NativeString__to_s_with_length(var440, var441);
-var439 = var442;
-varonce438 = var439;
-}
-var443 = ((short int (*)(val*, val*))(var_pname->class->vft[COLOR_kernel__Object___61d_61d]))(var_pname, var439) /* == on <var_pname:String>*/;
-if (var443){
-var444 = 0;
-var445 = ((val* (*)(val*, long))(var_arguments->class->vft[COLOR_abstract_collection__SequenceRead___91d_93d]))(var_arguments, var444) /* [] on <var_arguments:Array[RuntimeVariable]>*/;
-if (varonce446) {
-var447 = varonce446;
-} else {
-var448 = " + ";
-var449 = 3;
-var450 = string__NativeString__to_s_with_length(var448, var449);
-var447 = var450;
-varonce446 = var447;
-}
-var451 = 1;
-var452 = ((val* (*)(val*, long))(var_arguments->class->vft[COLOR_abstract_collection__SequenceRead___91d_93d]))(var_arguments, var451) /* [] on <var_arguments:Array[RuntimeVariable]>*/;
-var453 = NEW_array__Array(&type_array__Arraykernel__Object);
-{ /* var453 = array_instance Array[Object] */
-var454 = 3;
-var455 = NEW_array__NativeArray(var454, &type_array__NativeArraykernel__Object);
-((struct instance_array__NativeArray*)var455)->values[0] = (val*) var445;
-((struct instance_array__NativeArray*)var455)->values[1] = (val*) var447;
-((struct instance_array__NativeArray*)var455)->values[2] = (val*) var452;
-((void (*)(val*, val*, long))(var453->class->vft[COLOR_array__Array__with_native]))(var453, var455, var454) /* with_native on <var453:Array[Object]>*/;
-CHECK_NEW_array__Array(var453);
-}
-var456 = ((val* (*)(val*))(var453->class->vft[COLOR_string__Object__to_s]))(var453) /* to_s on <var453:Array[Object]>*/;
-if (var_ret == NULL) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "src/abstract_compiler.nit", 1423);
-exit(1);
-}
-var457 = ((val* (*)(val*, val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__new_expr]))(var_v, var456, var_ret) /* new_expr on <var_v:AbstractCompilerVisitor>*/;
-((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__ret]))(var_v, var457) /* ret on <var_v:AbstractCompilerVisitor>*/;
-goto RET_LABEL;
+}
+{
+{ /* Inline abstract_compiler#AbstractCompilerVisitor#compiler (self) on <self:AbstractCompilerVisitor> */
+var5 = self->attrs[COLOR_abstract_compiler__AbstractCompilerVisitor___compiler].val; /* _compiler on <self:AbstractCompilerVisitor> */
+if (unlikely(var5 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _compiler");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 1041);
+show_backtrace(1);
+}
+var3 = var5;
+RET_LABEL4:(void)0;
+}
+}
+{
+{ /* Inline abstract_compiler#AbstractCompiler#mainmodule (var3) on <var3:AbstractCompiler> */
+var8 = var3->attrs[COLOR_abstract_compiler__AbstractCompiler___mainmodule].val; /* _mainmodule on <var3:AbstractCompiler> */
+if (unlikely(var8 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _mainmodule");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 463);
+show_backtrace(1);
+}
+var6 = var8;
+RET_LABEL7:(void)0;
+}
+}
+{
+{ /* Inline abstract_compiler#AbstractCompilerVisitor#frame (self) on <self:AbstractCompilerVisitor> */
+var11 = self->attrs[COLOR_abstract_compiler__AbstractCompilerVisitor___frame].val; /* _frame on <self:AbstractCompilerVisitor> */
+var9 = var11;
+RET_LABEL10:(void)0;
+}
+}
+if (var9 == NULL) {
+PRINT_ERROR("Runtime error: %s", "Receiver is null");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 1155);
+show_backtrace(1);
 } else {
-if (varonce458) {
-var459 = varonce458;
-} else {
-var460 = "-";
-var461 = 1;
-var462 = string__NativeString__to_s_with_length(var460, var461);
-var459 = var462;
-varonce458 = var459;
-}
-var463 = ((short int (*)(val*, val*))(var_pname->class->vft[COLOR_kernel__Object___61d_61d]))(var_pname, var459) /* == on <var_pname:String>*/;
-if (var463){
-var464 = 0;
-var465 = ((val* (*)(val*, long))(var_arguments->class->vft[COLOR_abstract_collection__SequenceRead___91d_93d]))(var_arguments, var464) /* [] on <var_arguments:Array[RuntimeVariable]>*/;
-if (varonce466) {
-var467 = varonce466;
-} else {
-var468 = " - ";
-var469 = 3;
-var470 = string__NativeString__to_s_with_length(var468, var469);
-var467 = var470;
-varonce466 = var467;
-}
-var471 = 1;
-var472 = ((val* (*)(val*, long))(var_arguments->class->vft[COLOR_abstract_collection__SequenceRead___91d_93d]))(var_arguments, var471) /* [] on <var_arguments:Array[RuntimeVariable]>*/;
-var473 = NEW_array__Array(&type_array__Arraykernel__Object);
-{ /* var473 = array_instance Array[Object] */
-var474 = 3;
-var475 = NEW_array__NativeArray(var474, &type_array__NativeArraykernel__Object);
-((struct instance_array__NativeArray*)var475)->values[0] = (val*) var465;
-((struct instance_array__NativeArray*)var475)->values[1] = (val*) var467;
-((struct instance_array__NativeArray*)var475)->values[2] = (val*) var472;
-((void (*)(val*, val*, long))(var473->class->vft[COLOR_array__Array__with_native]))(var473, var475, var474) /* with_native on <var473:Array[Object]>*/;
-CHECK_NEW_array__Array(var473);
-}
-var476 = ((val* (*)(val*))(var473->class->vft[COLOR_string__Object__to_s]))(var473) /* to_s on <var473:Array[Object]>*/;
-if (var_ret == NULL) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "src/abstract_compiler.nit", 1426);
-exit(1);
-}
-var477 = ((val* (*)(val*, val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__new_expr]))(var_v, var476, var_ret) /* new_expr on <var_v:AbstractCompilerVisitor>*/;
-((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__ret]))(var_v, var477) /* ret on <var_v:AbstractCompilerVisitor>*/;
+{ /* Inline abstract_compiler#Frame#receiver (var9) on <var9:nullable Frame> */
+if (unlikely(var9 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Receiver is null");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 1685);
+show_backtrace(1);
+}
+var14 = var9->attrs[COLOR_abstract_compiler__Frame___receiver].val; /* _receiver on <var9:nullable Frame> */
+if (unlikely(var14 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _receiver");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 1685);
+show_backtrace(1);
+}
+var12 = var14;
+RET_LABEL13:(void)0;
+}
+}
+{
+var15 = ((val* (*)(val*, val*, val*))(var_mtype->class->vft[COLOR_model__MType__anchor_to]))(var_mtype, var6, var12) /* anchor_to on <var_mtype:MType>*/;
+}
+var = var15;
 goto RET_LABEL;
-} else {
-if (varonce478) {
-var479 = varonce478;
-} else {
-var480 = "==";
-var481 = 2;
-var482 = string__NativeString__to_s_with_length(var480, var481);
-var479 = var482;
-varonce478 = var479;
-}
-var483 = ((short int (*)(val*, val*))(var_pname->class->vft[COLOR_kernel__Object___61d_61d]))(var_pname, var479) /* == on <var_pname:String>*/;
-if (var483){
-var484 = 0;
-var485 = ((val* (*)(val*, long))(var_arguments->class->vft[COLOR_abstract_collection__SequenceRead___91d_93d]))(var_arguments, var484) /* [] on <var_arguments:Array[RuntimeVariable]>*/;
-var486 = 1;
-var487 = ((val* (*)(val*, long))(var_arguments->class->vft[COLOR_abstract_collection__SequenceRead___91d_93d]))(var_arguments, var486) /* [] on <var_arguments:Array[RuntimeVariable]>*/;
-var488 = ((val* (*)(val*, val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__equal_test]))(var_v, var485, var487) /* equal_test on <var_v:AbstractCompilerVisitor>*/;
-((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__ret]))(var_v, var488) /* ret on <var_v:AbstractCompilerVisitor>*/;
+RET_LABEL:;
+return var;
+}
+/* method abstract_compiler#AbstractCompilerVisitor#anchor for (self: Object, MType): MType */
+val* VIRTUAL_abstract_compiler__AbstractCompilerVisitor__anchor(val* self, val* p0) {
+val* var /* : MType */;
+val* var1 /* : MType */;
+var1 = abstract_compiler__AbstractCompilerVisitor__anchor(self, p0);
+var = var1;
+RET_LABEL:;
+return var;
+}
+/* method abstract_compiler#AbstractCompilerVisitor#resolve_for for (self: AbstractCompilerVisitor, MType, RuntimeVariable): MType */
+val* abstract_compiler__AbstractCompilerVisitor__resolve_for(val* self, val* p0, val* p1) {
+val* var /* : MType */;
+val* var_mtype /* var mtype: MType */;
+val* var_recv /* var recv: RuntimeVariable */;
+short int var1 /* : Bool */;
+short int var2 /* : Bool */;
+val* var3 /* : MType */;
+val* var5 /* : MType */;
+val* var6 /* : nullable Frame */;
+val* var8 /* : nullable Frame */;
+val* var9 /* : MClassType */;
+val* var11 /* : MClassType */;
+val* var12 /* : AbstractCompiler */;
+val* var14 /* : AbstractCompiler */;
+val* var15 /* : MModule */;
+val* var17 /* : MModule */;
+short int var18 /* : Bool */;
+val* var19 /* : MType */;
+var_mtype = p0;
+var_recv = p1;
+{
+var1 = ((short int (*)(val*))(var_mtype->class->vft[COLOR_model__MType__need_anchor]))(var_mtype) /* need_anchor on <var_mtype:MType>*/;
+}
+var2 = !var1;
+if (var2){
+var = var_mtype;
 goto RET_LABEL;
 } else {
-if (varonce489) {
-var490 = varonce489;
+}
+{
+{ /* Inline abstract_compiler#RuntimeVariable#mcasttype (var_recv) on <var_recv:RuntimeVariable> */
+var5 = var_recv->attrs[COLOR_abstract_compiler__RuntimeVariable___mcasttype].val; /* _mcasttype on <var_recv:RuntimeVariable> */
+if (unlikely(var5 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _mcasttype");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 1637);
+show_backtrace(1);
+}
+var3 = var5;
+RET_LABEL4:(void)0;
+}
+}
+{
+{ /* Inline abstract_compiler#AbstractCompilerVisitor#frame (self) on <self:AbstractCompilerVisitor> */
+var8 = self->attrs[COLOR_abstract_compiler__AbstractCompilerVisitor___frame].val; /* _frame on <self:AbstractCompilerVisitor> */
+var6 = var8;
+RET_LABEL7:(void)0;
+}
+}
+if (var6 == NULL) {
+PRINT_ERROR("Runtime error: %s", "Receiver is null");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 1161);
+show_backtrace(1);
 } else {
-var491 = "!=";
-var492 = 2;
-var493 = string__NativeString__to_s_with_length(var491, var492);
-var490 = var493;
-varonce489 = var490;
+{ /* Inline abstract_compiler#Frame#receiver (var6) on <var6:nullable Frame> */
+if (unlikely(var6 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Receiver is null");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 1685);
+show_backtrace(1);
+}
+var11 = var6->attrs[COLOR_abstract_compiler__Frame___receiver].val; /* _receiver on <var6:nullable Frame> */
+if (unlikely(var11 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _receiver");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 1685);
+show_backtrace(1);
+}
+var9 = var11;
+RET_LABEL10:(void)0;
+}
+}
+{
+{ /* Inline abstract_compiler#AbstractCompilerVisitor#compiler (self) on <self:AbstractCompilerVisitor> */
+var14 = self->attrs[COLOR_abstract_compiler__AbstractCompilerVisitor___compiler].val; /* _compiler on <self:AbstractCompilerVisitor> */
+if (unlikely(var14 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _compiler");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 1041);
+show_backtrace(1);
+}
+var12 = var14;
+RET_LABEL13:(void)0;
+}
+}
+{
+{ /* Inline abstract_compiler#AbstractCompiler#mainmodule (var12) on <var12:AbstractCompiler> */
+var17 = var12->attrs[COLOR_abstract_compiler__AbstractCompiler___mainmodule].val; /* _mainmodule on <var12:AbstractCompiler> */
+if (unlikely(var17 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _mainmodule");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 463);
+show_backtrace(1);
+}
+var15 = var17;
+RET_LABEL16:(void)0;
+}
+}
+var18 = 1;
+{
+var19 = ((val* (*)(val*, val*, val*, val*, short int))(var_mtype->class->vft[COLOR_model__MType__resolve_for]))(var_mtype, var3, var9, var15, var18) /* resolve_for on <var_mtype:MType>*/;
+}
+var = var19;
+goto RET_LABEL;
+RET_LABEL:;
+return var;
+}
+/* method abstract_compiler#AbstractCompilerVisitor#resolve_for for (self: Object, MType, RuntimeVariable): MType */
+val* VIRTUAL_abstract_compiler__AbstractCompilerVisitor__resolve_for(val* self, val* p0, val* p1) {
+val* var /* : MType */;
+val* var1 /* : MType */;
+var1 = abstract_compiler__AbstractCompilerVisitor__resolve_for(self, p0, p1);
+var = var1;
+RET_LABEL:;
+return var;
+}
+/* method abstract_compiler#AbstractCompilerVisitor#autoadapt for (self: AbstractCompilerVisitor, RuntimeVariable, MType): RuntimeVariable */
+val* abstract_compiler__AbstractCompilerVisitor__autoadapt(val* self, val* p0, val* p1) {
+val* var /* : RuntimeVariable */;
+val* var_value /* var value: RuntimeVariable */;
+val* var_mtype /* var mtype: MType */;
+val* var1 /* : MType */;
+val* var2 /* : MType */;
+val* var4 /* : MType */;
+val* var_valmtype /* var valmtype: MType */;
+val* var5 /* : AbstractCompiler */;
+val* var7 /* : AbstractCompiler */;
+val* var8 /* : MModule */;
+val* var10 /* : MModule */;
+val* var11 /* : null */;
+short int var12 /* : Bool */;
+short int var13 /* : Bool */;
+short int var14 /* : Bool */;
+int cltype;
+int idtype;
+short int var_ /* var : Bool */;
+val* var15 /* : MType */;
+val* var17 /* : MType */;
+val* var18 /* : AbstractCompiler */;
+val* var20 /* : AbstractCompiler */;
+val* var21 /* : MModule */;
+val* var23 /* : MModule */;
+val* var24 /* : null */;
+short int var25 /* : Bool */;
+val* var26 /* : RuntimeVariable */;
+val* var27 /* : String */;
+val* var29 /* : String */;
+val* var30 /* : MType */;
+val* var32 /* : MType */;
+val* var_res /* var res: RuntimeVariable */;
+val* var33 /* : RuntimeVariable */;
+val* var34 /* : String */;
+val* var36 /* : String */;
+val* var_res37 /* var res: RuntimeVariable */;
+var_value = p0;
+var_mtype = p1;
+{
+var1 = abstract_compiler__AbstractCompilerVisitor__anchor(self, var_mtype);
+}
+var_mtype = var1;
+{
+{ /* Inline abstract_compiler#RuntimeVariable#mcasttype (var_value) on <var_value:RuntimeVariable> */
+var4 = var_value->attrs[COLOR_abstract_compiler__RuntimeVariable___mcasttype].val; /* _mcasttype on <var_value:RuntimeVariable> */
+if (unlikely(var4 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _mcasttype");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 1637);
+show_backtrace(1);
+}
+var2 = var4;
+RET_LABEL3:(void)0;
 }
-var494 = ((short int (*)(val*, val*))(var_pname->class->vft[COLOR_kernel__Object___61d_61d]))(var_pname, var490) /* == on <var_pname:String>*/;
-if (var494){
-var495 = 0;
-var496 = ((val* (*)(val*, long))(var_arguments->class->vft[COLOR_abstract_collection__SequenceRead___91d_93d]))(var_arguments, var495) /* [] on <var_arguments:Array[RuntimeVariable]>*/;
-var497 = 1;
-var498 = ((val* (*)(val*, long))(var_arguments->class->vft[COLOR_abstract_collection__SequenceRead___91d_93d]))(var_arguments, var497) /* [] on <var_arguments:Array[RuntimeVariable]>*/;
-var499 = ((val* (*)(val*, val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__equal_test]))(var_v, var496, var498) /* equal_test on <var_v:AbstractCompilerVisitor>*/;
-var_res500 = var499;
-if (varonce501) {
-var502 = varonce501;
-} else {
-var503 = "!";
-var504 = 1;
-var505 = string__NativeString__to_s_with_length(var503, var504);
-var502 = var505;
-varonce501 = var502;
-}
-var506 = NEW_array__Array(&type_array__Arraykernel__Object);
-{ /* var506 = array_instance Array[Object] */
-var507 = 2;
-var508 = NEW_array__NativeArray(var507, &type_array__NativeArraykernel__Object);
-((struct instance_array__NativeArray*)var508)->values[0] = (val*) var502;
-((struct instance_array__NativeArray*)var508)->values[1] = (val*) var_res500;
-((void (*)(val*, val*, long))(var506->class->vft[COLOR_array__Array__with_native]))(var506, var508, var507) /* with_native on <var506:Array[Object]>*/;
-CHECK_NEW_array__Array(var506);
-}
-var509 = ((val* (*)(val*))(var506->class->vft[COLOR_string__Object__to_s]))(var506) /* to_s on <var506:Array[Object]>*/;
-if (var_ret == NULL) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "src/abstract_compiler.nit", 1433);
-exit(1);
-}
-var510 = ((val* (*)(val*, val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__new_expr]))(var_v, var509, var_ret) /* new_expr on <var_v:AbstractCompilerVisitor>*/;
-((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__ret]))(var_v, var510) /* ret on <var_v:AbstractCompilerVisitor>*/;
-goto RET_LABEL;
-} else {
-if (varonce511) {
-var512 = varonce511;
-} else {
-var513 = "succ";
-var514 = 4;
-var515 = string__NativeString__to_s_with_length(var513, var514);
-var512 = var515;
-varonce511 = var512;
 }
-var516 = ((short int (*)(val*, val*))(var_pname->class->vft[COLOR_kernel__Object___61d_61d]))(var_pname, var512) /* == on <var_pname:String>*/;
-if (var516){
-var517 = 0;
-var518 = ((val* (*)(val*, long))(var_arguments->class->vft[COLOR_abstract_collection__SequenceRead___91d_93d]))(var_arguments, var517) /* [] on <var_arguments:Array[RuntimeVariable]>*/;
-if (varonce519) {
-var520 = varonce519;
-} else {
-var521 = "+1";
-var522 = 2;
-var523 = string__NativeString__to_s_with_length(var521, var522);
-var520 = var523;
-varonce519 = var520;
+var_valmtype = var2;
+{
+{ /* Inline abstract_compiler#AbstractCompilerVisitor#compiler (self) on <self:AbstractCompilerVisitor> */
+var7 = self->attrs[COLOR_abstract_compiler__AbstractCompilerVisitor___compiler].val; /* _compiler on <self:AbstractCompilerVisitor> */
+if (unlikely(var7 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _compiler");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 1041);
+show_backtrace(1);
 }
-var524 = NEW_array__Array(&type_array__Arraykernel__Object);
-{ /* var524 = array_instance Array[Object] */
-var525 = 2;
-var526 = NEW_array__NativeArray(var525, &type_array__NativeArraykernel__Object);
-((struct instance_array__NativeArray*)var526)->values[0] = (val*) var518;
-((struct instance_array__NativeArray*)var526)->values[1] = (val*) var520;
-((void (*)(val*, val*, long))(var524->class->vft[COLOR_array__Array__with_native]))(var524, var526, var525) /* with_native on <var524:Array[Object]>*/;
-CHECK_NEW_array__Array(var524);
-}
-var527 = ((val* (*)(val*))(var524->class->vft[COLOR_string__Object__to_s]))(var524) /* to_s on <var524:Array[Object]>*/;
-if (var_ret == NULL) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "src/abstract_compiler.nit", 1436);
-exit(1);
-}
-var528 = ((val* (*)(val*, val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__new_expr]))(var_v, var527, var_ret) /* new_expr on <var_v:AbstractCompilerVisitor>*/;
-((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__ret]))(var_v, var528) /* ret on <var_v:AbstractCompilerVisitor>*/;
-goto RET_LABEL;
-} else {
-if (varonce529) {
-var530 = varonce529;
-} else {
-var531 = "prec";
-var532 = 4;
-var533 = string__NativeString__to_s_with_length(var531, var532);
-var530 = var533;
-varonce529 = var530;
+var5 = var7;
+RET_LABEL6:(void)0;
 }
-var534 = ((short int (*)(val*, val*))(var_pname->class->vft[COLOR_kernel__Object___61d_61d]))(var_pname, var530) /* == on <var_pname:String>*/;
-if (var534){
-var535 = 0;
-var536 = ((val* (*)(val*, long))(var_arguments->class->vft[COLOR_abstract_collection__SequenceRead___91d_93d]))(var_arguments, var535) /* [] on <var_arguments:Array[RuntimeVariable]>*/;
-if (varonce537) {
-var538 = varonce537;
-} else {
-var539 = "-1";
-var540 = 2;
-var541 = string__NativeString__to_s_with_length(var539, var540);
-var538 = var541;
-varonce537 = var538;
-}
-var542 = NEW_array__Array(&type_array__Arraykernel__Object);
-{ /* var542 = array_instance Array[Object] */
-var543 = 2;
-var544 = NEW_array__NativeArray(var543, &type_array__NativeArraykernel__Object);
-((struct instance_array__NativeArray*)var544)->values[0] = (val*) var536;
-((struct instance_array__NativeArray*)var544)->values[1] = (val*) var538;
-((void (*)(val*, val*, long))(var542->class->vft[COLOR_array__Array__with_native]))(var542, var544, var543) /* with_native on <var542:Array[Object]>*/;
-CHECK_NEW_array__Array(var542);
-}
-var545 = ((val* (*)(val*))(var542->class->vft[COLOR_string__Object__to_s]))(var542) /* to_s on <var542:Array[Object]>*/;
-if (var_ret == NULL) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "src/abstract_compiler.nit", 1439);
-exit(1);
-}
-var546 = ((val* (*)(val*, val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__new_expr]))(var_v, var545, var_ret) /* new_expr on <var_v:AbstractCompilerVisitor>*/;
-((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__ret]))(var_v, var546) /* ret on <var_v:AbstractCompilerVisitor>*/;
-goto RET_LABEL;
-} else {
-if (varonce547) {
-var548 = varonce547;
-} else {
-var549 = "<";
-var550 = 1;
-var551 = string__NativeString__to_s_with_length(var549, var550);
-var548 = var551;
-varonce547 = var548;
-}
-var552 = ((short int (*)(val*, val*))(var_pname->class->vft[COLOR_kernel__Object___61d_61d]))(var_pname, var548) /* == on <var_pname:String>*/;
-if (var552){
-var553 = 0;
-var554 = ((val* (*)(val*, long))(var_arguments->class->vft[COLOR_abstract_collection__SequenceRead___91d_93d]))(var_arguments, var553) /* [] on <var_arguments:Array[RuntimeVariable]>*/;
-if (varonce555) {
-var556 = varonce555;
-} else {
-var557 = " < ";
-var558 = 3;
-var559 = string__NativeString__to_s_with_length(var557, var558);
-var556 = var559;
-varonce555 = var556;
-}
-var560 = 1;
-var561 = ((val* (*)(val*, long))(var_arguments->class->vft[COLOR_abstract_collection__SequenceRead___91d_93d]))(var_arguments, var560) /* [] on <var_arguments:Array[RuntimeVariable]>*/;
-var562 = NEW_array__Array(&type_array__Arraykernel__Object);
-{ /* var562 = array_instance Array[Object] */
-var563 = 3;
-var564 = NEW_array__NativeArray(var563, &type_array__NativeArraykernel__Object);
-((struct instance_array__NativeArray*)var564)->values[0] = (val*) var554;
-((struct instance_array__NativeArray*)var564)->values[1] = (val*) var556;
-((struct instance_array__NativeArray*)var564)->values[2] = (val*) var561;
-((void (*)(val*, val*, long))(var562->class->vft[COLOR_array__Array__with_native]))(var562, var564, var563) /* with_native on <var562:Array[Object]>*/;
-CHECK_NEW_array__Array(var562);
-}
-var565 = ((val* (*)(val*))(var562->class->vft[COLOR_string__Object__to_s]))(var562) /* to_s on <var562:Array[Object]>*/;
-if (var_ret == NULL) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "src/abstract_compiler.nit", 1442);
-exit(1);
-}
-var566 = ((val* (*)(val*, val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__new_expr]))(var_v, var565, var_ret) /* new_expr on <var_v:AbstractCompilerVisitor>*/;
-((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__ret]))(var_v, var566) /* ret on <var_v:AbstractCompilerVisitor>*/;
-goto RET_LABEL;
-} else {
-if (varonce567) {
-var568 = varonce567;
-} else {
-var569 = ">";
-var570 = 1;
-var571 = string__NativeString__to_s_with_length(var569, var570);
-var568 = var571;
-varonce567 = var568;
-}
-var572 = ((short int (*)(val*, val*))(var_pname->class->vft[COLOR_kernel__Object___61d_61d]))(var_pname, var568) /* == on <var_pname:String>*/;
-if (var572){
-var573 = 0;
-var574 = ((val* (*)(val*, long))(var_arguments->class->vft[COLOR_abstract_collection__SequenceRead___91d_93d]))(var_arguments, var573) /* [] on <var_arguments:Array[RuntimeVariable]>*/;
-if (varonce575) {
-var576 = varonce575;
-} else {
-var577 = " > ";
-var578 = 3;
-var579 = string__NativeString__to_s_with_length(var577, var578);
-var576 = var579;
-varonce575 = var576;
-}
-var580 = 1;
-var581 = ((val* (*)(val*, long))(var_arguments->class->vft[COLOR_abstract_collection__SequenceRead___91d_93d]))(var_arguments, var580) /* [] on <var_arguments:Array[RuntimeVariable]>*/;
-var582 = NEW_array__Array(&type_array__Arraykernel__Object);
-{ /* var582 = array_instance Array[Object] */
-var583 = 3;
-var584 = NEW_array__NativeArray(var583, &type_array__NativeArraykernel__Object);
-((struct instance_array__NativeArray*)var584)->values[0] = (val*) var574;
-((struct instance_array__NativeArray*)var584)->values[1] = (val*) var576;
-((struct instance_array__NativeArray*)var584)->values[2] = (val*) var581;
-((void (*)(val*, val*, long))(var582->class->vft[COLOR_array__Array__with_native]))(var582, var584, var583) /* with_native on <var582:Array[Object]>*/;
-CHECK_NEW_array__Array(var582);
-}
-var585 = ((val* (*)(val*))(var582->class->vft[COLOR_string__Object__to_s]))(var582) /* to_s on <var582:Array[Object]>*/;
-if (var_ret == NULL) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "src/abstract_compiler.nit", 1445);
-exit(1);
-}
-var586 = ((val* (*)(val*, val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__new_expr]))(var_v, var585, var_ret) /* new_expr on <var_v:AbstractCompilerVisitor>*/;
-((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__ret]))(var_v, var586) /* ret on <var_v:AbstractCompilerVisitor>*/;
-goto RET_LABEL;
-} else {
-if (varonce587) {
-var588 = varonce587;
-} else {
-var589 = "<=";
-var590 = 2;
-var591 = string__NativeString__to_s_with_length(var589, var590);
-var588 = var591;
-varonce587 = var588;
 }
-var592 = ((short int (*)(val*, val*))(var_pname->class->vft[COLOR_kernel__Object___61d_61d]))(var_pname, var588) /* == on <var_pname:String>*/;
-if (var592){
-var593 = 0;
-var594 = ((val* (*)(val*, long))(var_arguments->class->vft[COLOR_abstract_collection__SequenceRead___91d_93d]))(var_arguments, var593) /* [] on <var_arguments:Array[RuntimeVariable]>*/;
-if (varonce595) {
-var596 = varonce595;
-} else {
-var597 = " <= ";
-var598 = 4;
-var599 = string__NativeString__to_s_with_length(var597, var598);
-var596 = var599;
-varonce595 = var596;
+{
+{ /* Inline abstract_compiler#AbstractCompiler#mainmodule (var5) on <var5:AbstractCompiler> */
+var10 = var5->attrs[COLOR_abstract_compiler__AbstractCompiler___mainmodule].val; /* _mainmodule on <var5:AbstractCompiler> */
+if (unlikely(var10 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _mainmodule");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 463);
+show_backtrace(1);
 }
-var600 = 1;
-var601 = ((val* (*)(val*, long))(var_arguments->class->vft[COLOR_abstract_collection__SequenceRead___91d_93d]))(var_arguments, var600) /* [] on <var_arguments:Array[RuntimeVariable]>*/;
-var602 = NEW_array__Array(&type_array__Arraykernel__Object);
-{ /* var602 = array_instance Array[Object] */
-var603 = 3;
-var604 = NEW_array__NativeArray(var603, &type_array__NativeArraykernel__Object);
-((struct instance_array__NativeArray*)var604)->values[0] = (val*) var594;
-((struct instance_array__NativeArray*)var604)->values[1] = (val*) var596;
-((struct instance_array__NativeArray*)var604)->values[2] = (val*) var601;
-((void (*)(val*, val*, long))(var602->class->vft[COLOR_array__Array__with_native]))(var602, var604, var603) /* with_native on <var602:Array[Object]>*/;
-CHECK_NEW_array__Array(var602);
+var8 = var10;
+RET_LABEL9:(void)0;
 }
-var605 = ((val* (*)(val*))(var602->class->vft[COLOR_string__Object__to_s]))(var602) /* to_s on <var602:Array[Object]>*/;
-if (var_ret == NULL) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "src/abstract_compiler.nit", 1448);
-exit(1);
 }
-var606 = ((val* (*)(val*, val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__new_expr]))(var_v, var605, var_ret) /* new_expr on <var_v:AbstractCompilerVisitor>*/;
-((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__ret]))(var_v, var606) /* ret on <var_v:AbstractCompilerVisitor>*/;
-goto RET_LABEL;
-} else {
-if (varonce607) {
-var608 = varonce607;
-} else {
-var609 = ">=";
-var610 = 2;
-var611 = string__NativeString__to_s_with_length(var609, var610);
-var608 = var611;
-varonce607 = var608;
-}
-var612 = ((short int (*)(val*, val*))(var_pname->class->vft[COLOR_kernel__Object___61d_61d]))(var_pname, var608) /* == on <var_pname:String>*/;
-if (var612){
-var613 = 0;
-var614 = ((val* (*)(val*, long))(var_arguments->class->vft[COLOR_abstract_collection__SequenceRead___91d_93d]))(var_arguments, var613) /* [] on <var_arguments:Array[RuntimeVariable]>*/;
-if (varonce615) {
-var616 = varonce615;
-} else {
-var617 = " >= ";
-var618 = 4;
-var619 = string__NativeString__to_s_with_length(var617, var618);
-var616 = var619;
-varonce615 = var616;
-}
-var620 = 1;
-var621 = ((val* (*)(val*, long))(var_arguments->class->vft[COLOR_abstract_collection__SequenceRead___91d_93d]))(var_arguments, var620) /* [] on <var_arguments:Array[RuntimeVariable]>*/;
-var622 = NEW_array__Array(&type_array__Arraykernel__Object);
-{ /* var622 = array_instance Array[Object] */
-var623 = 3;
-var624 = NEW_array__NativeArray(var623, &type_array__NativeArraykernel__Object);
-((struct instance_array__NativeArray*)var624)->values[0] = (val*) var614;
-((struct instance_array__NativeArray*)var624)->values[1] = (val*) var616;
-((struct instance_array__NativeArray*)var624)->values[2] = (val*) var621;
-((void (*)(val*, val*, long))(var622->class->vft[COLOR_array__Array__with_native]))(var622, var624, var623) /* with_native on <var622:Array[Object]>*/;
-CHECK_NEW_array__Array(var622);
-}
-var625 = ((val* (*)(val*))(var622->class->vft[COLOR_string__Object__to_s]))(var622) /* to_s on <var622:Array[Object]>*/;
-if (var_ret == NULL) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "src/abstract_compiler.nit", 1451);
-exit(1);
-}
-var626 = ((val* (*)(val*, val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__new_expr]))(var_v, var625, var_ret) /* new_expr on <var_v:AbstractCompilerVisitor>*/;
-((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__ret]))(var_v, var626) /* ret on <var_v:AbstractCompilerVisitor>*/;
-goto RET_LABEL;
-} else {
-if (varonce627) {
-var628 = varonce627;
-} else {
-var629 = "to_i";
-var630 = 4;
-var631 = string__NativeString__to_s_with_length(var629, var630);
-var628 = var631;
-varonce627 = var628;
+var11 = NULL;
+{
+var12 = model__MType__is_subtype(var_valmtype, var8, var11, var_mtype);
 }
-var632 = ((short int (*)(val*, val*))(var_pname->class->vft[COLOR_kernel__Object___61d_61d]))(var_pname, var628) /* == on <var_pname:String>*/;
-if (var632){
-var633 = 0;
-var634 = ((val* (*)(val*, long))(var_arguments->class->vft[COLOR_abstract_collection__SequenceRead___91d_93d]))(var_arguments, var633) /* [] on <var_arguments:Array[RuntimeVariable]>*/;
-if (varonce635) {
-var636 = varonce635;
-} else {
-var637 = "-\'0\'";
-var638 = 4;
-var639 = string__NativeString__to_s_with_length(var637, var638);
-var636 = var639;
-varonce635 = var636;
-}
-var640 = NEW_array__Array(&type_array__Arraykernel__Object);
-{ /* var640 = array_instance Array[Object] */
-var641 = 2;
-var642 = NEW_array__NativeArray(var641, &type_array__NativeArraykernel__Object);
-((struct instance_array__NativeArray*)var642)->values[0] = (val*) var634;
-((struct instance_array__NativeArray*)var642)->values[1] = (val*) var636;
-((void (*)(val*, val*, long))(var640->class->vft[COLOR_array__Array__with_native]))(var640, var642, var641) /* with_native on <var640:Array[Object]>*/;
-CHECK_NEW_array__Array(var640);
-}
-var643 = ((val* (*)(val*))(var640->class->vft[COLOR_string__Object__to_s]))(var640) /* to_s on <var640:Array[Object]>*/;
-if (var_ret == NULL) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "src/abstract_compiler.nit", 1454);
-exit(1);
-}
-var644 = ((val* (*)(val*, val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__new_expr]))(var_v, var643, var_ret) /* new_expr on <var_v:AbstractCompilerVisitor>*/;
-((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__ret]))(var_v, var644) /* ret on <var_v:AbstractCompilerVisitor>*/;
+if (var12){
+var = var_value;
 goto RET_LABEL;
 } else {
-if (varonce645) {
-var646 = varonce645;
-} else {
-var647 = "ascii";
-var648 = 5;
-var649 = string__NativeString__to_s_with_length(var647, var648);
-var646 = var649;
-varonce645 = var646;
-}
-var650 = ((short int (*)(val*, val*))(var_pname->class->vft[COLOR_kernel__Object___61d_61d]))(var_pname, var646) /* == on <var_pname:String>*/;
-if (var650){
-if (varonce651) {
-var652 = varonce651;
-} else {
-var653 = "(unsigned char)";
-var654 = 15;
-var655 = string__NativeString__to_s_with_length(var653, var654);
-var652 = var655;
-varonce651 = var652;
-}
-var656 = 0;
-var657 = ((val* (*)(val*, long))(var_arguments->class->vft[COLOR_abstract_collection__SequenceRead___91d_93d]))(var_arguments, var656) /* [] on <var_arguments:Array[RuntimeVariable]>*/;
-var658 = NEW_array__Array(&type_array__Arraykernel__Object);
-{ /* var658 = array_instance Array[Object] */
-var659 = 2;
-var660 = NEW_array__NativeArray(var659, &type_array__NativeArraykernel__Object);
-((struct instance_array__NativeArray*)var660)->values[0] = (val*) var652;
-((struct instance_array__NativeArray*)var660)->values[1] = (val*) var657;
-((void (*)(val*, val*, long))(var658->class->vft[COLOR_array__Array__with_native]))(var658, var660, var659) /* with_native on <var658:Array[Object]>*/;
-CHECK_NEW_array__Array(var658);
-}
-var661 = ((val* (*)(val*))(var658->class->vft[COLOR_string__Object__to_s]))(var658) /* to_s on <var658:Array[Object]>*/;
-if (var_ret == NULL) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "src/abstract_compiler.nit", 1457);
-exit(1);
-}
-var662 = ((val* (*)(val*, val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__new_expr]))(var_v, var661, var_ret) /* new_expr on <var_v:AbstractCompilerVisitor>*/;
-((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__ret]))(var_v, var662) /* ret on <var_v:AbstractCompilerVisitor>*/;
-goto RET_LABEL;
+}
+/* <var_valmtype:MType> isa MNullableType */
+cltype = type_model__MNullableType.color;
+idtype = type_model__MNullableType.id;
+if(cltype >= var_valmtype->type->table_size) {
+var14 = 0;
 } else {
+var14 = var_valmtype->type->type_table[cltype] == idtype;
 }
+var_ = var14;
+if (var14){
+{
+{ /* Inline model#MNullableType#mtype (var_valmtype) on <var_valmtype:MType(MNullableType)> */
+var17 = var_valmtype->attrs[COLOR_model__MNullableType___mtype].val; /* _mtype on <var_valmtype:MType(MNullableType)> */
+if (unlikely(var17 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _mtype");
+PRINT_ERROR(" (%s:%d)\n", "model/model.nit", 1388);
+show_backtrace(1);
 }
+var15 = var17;
+RET_LABEL16:(void)0;
 }
 }
+{
+{ /* Inline abstract_compiler#AbstractCompilerVisitor#compiler (self) on <self:AbstractCompilerVisitor> */
+var20 = self->attrs[COLOR_abstract_compiler__AbstractCompilerVisitor___compiler].val; /* _compiler on <self:AbstractCompilerVisitor> */
+if (unlikely(var20 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _compiler");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 1041);
+show_backtrace(1);
 }
+var18 = var20;
+RET_LABEL19:(void)0;
 }
 }
+{
+{ /* Inline abstract_compiler#AbstractCompiler#mainmodule (var18) on <var18:AbstractCompiler> */
+var23 = var18->attrs[COLOR_abstract_compiler__AbstractCompiler___mainmodule].val; /* _mainmodule on <var18:AbstractCompiler> */
+if (unlikely(var23 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _mainmodule");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 463);
+show_backtrace(1);
 }
+var21 = var23;
+RET_LABEL22:(void)0;
 }
 }
+var24 = NULL;
+{
+var25 = model__MType__is_subtype(var15, var21, var24, var_mtype);
 }
+var13 = var25;
+} else {
+var13 = var_;
 }
+if (var13){
+var26 = NEW_abstract_compiler__RuntimeVariable(&type_abstract_compiler__RuntimeVariable);
+{
+{ /* Inline abstract_compiler#RuntimeVariable#name (var_value) on <var_value:RuntimeVariable> */
+var29 = var_value->attrs[COLOR_abstract_compiler__RuntimeVariable___name].val; /* _name on <var_value:RuntimeVariable> */
+if (unlikely(var29 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _name");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 1631);
+show_backtrace(1);
 }
+var27 = var29;
+RET_LABEL28:(void)0;
 }
-} else {
-if (varonce663) {
-var664 = varonce663;
-} else {
-var665 = "Bool";
-var666 = 4;
-var667 = string__NativeString__to_s_with_length(var665, var666);
-var664 = var667;
-varonce663 = var664;
 }
-var668 = ((short int (*)(val*, val*))(var_cname->class->vft[COLOR_kernel__Object___61d_61d]))(var_cname, var664) /* == on <var_cname:String>*/;
-if (var668){
-if (varonce669) {
-var670 = varonce669;
-} else {
-var671 = "output";
-var672 = 6;
-var673 = string__NativeString__to_s_with_length(var671, var672);
-var670 = var673;
-varonce669 = var670;
+{
+{ /* Inline model#MNullableType#mtype (var_valmtype) on <var_valmtype:MType(MNullableType)> */
+var32 = var_valmtype->attrs[COLOR_model__MNullableType___mtype].val; /* _mtype on <var_valmtype:MType(MNullableType)> */
+if (unlikely(var32 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _mtype");
+PRINT_ERROR(" (%s:%d)\n", "model/model.nit", 1388);
+show_backtrace(1);
 }
-var674 = ((short int (*)(val*, val*))(var_pname->class->vft[COLOR_kernel__Object___61d_61d]))(var_pname, var670) /* == on <var_pname:String>*/;
-if (var674){
-if (varonce675) {
-var676 = varonce675;
-} else {
-var677 = "printf(";
-var678 = 7;
-var679 = string__NativeString__to_s_with_length(var677, var678);
-var676 = var679;
-varonce675 = var676;
-}
-var680 = ((val* (*)(val*))(var_arguments->class->vft[COLOR_abstract_collection__Collection__first]))(var_arguments) /* first on <var_arguments:Array[RuntimeVariable]>*/;
-if (varonce681) {
-var682 = varonce681;
-} else {
-var683 = "?\"true\\n\":\"false\\n\");";
-var684 = 21;
-var685 = string__NativeString__to_s_with_length(var683, var684);
-var682 = var685;
-varonce681 = var682;
-}
-var686 = NEW_array__Array(&type_array__Arraykernel__Object);
-{ /* var686 = array_instance Array[Object] */
-var687 = 3;
-var688 = NEW_array__NativeArray(var687, &type_array__NativeArraykernel__Object);
-((struct instance_array__NativeArray*)var688)->values[0] = (val*) var676;
-((struct instance_array__NativeArray*)var688)->values[1] = (val*) var680;
-((struct instance_array__NativeArray*)var688)->values[2] = (val*) var682;
-((void (*)(val*, val*, long))(var686->class->vft[COLOR_array__Array__with_native]))(var686, var688, var687) /* with_native on <var686:Array[Object]>*/;
-CHECK_NEW_array__Array(var686);
-}
-var689 = ((val* (*)(val*))(var686->class->vft[COLOR_string__Object__to_s]))(var686) /* to_s on <var686:Array[Object]>*/;
-((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(var_v, var689) /* add on <var_v:AbstractCompilerVisitor>*/;
-goto RET_LABEL;
-} else {
-if (varonce690) {
-var691 = varonce690;
-} else {
-var692 = "object_id";
-var693 = 9;
-var694 = string__NativeString__to_s_with_length(var692, var693);
-var691 = var694;
-varonce690 = var691;
+var30 = var32;
+RET_LABEL31:(void)0;
 }
-var695 = ((short int (*)(val*, val*))(var_pname->class->vft[COLOR_kernel__Object___61d_61d]))(var_pname, var691) /* == on <var_pname:String>*/;
-if (var695){
-if (varonce696) {
-var697 = varonce696;
-} else {
-var698 = "(long)";
-var699 = 6;
-var700 = string__NativeString__to_s_with_length(var698, var699);
-var697 = var700;
-varonce696 = var697;
-}
-var701 = ((val* (*)(val*))(var_arguments->class->vft[COLOR_abstract_collection__Collection__first]))(var_arguments) /* first on <var_arguments:Array[RuntimeVariable]>*/;
-var702 = NEW_array__Array(&type_array__Arraykernel__Object);
-{ /* var702 = array_instance Array[Object] */
-var703 = 2;
-var704 = NEW_array__NativeArray(var703, &type_array__NativeArraykernel__Object);
-((struct instance_array__NativeArray*)var704)->values[0] = (val*) var697;
-((struct instance_array__NativeArray*)var704)->values[1] = (val*) var701;
-((void (*)(val*, val*, long))(var702->class->vft[COLOR_array__Array__with_native]))(var702, var704, var703) /* with_native on <var702:Array[Object]>*/;
-CHECK_NEW_array__Array(var702);
-}
-var705 = ((val* (*)(val*))(var702->class->vft[COLOR_string__Object__to_s]))(var702) /* to_s on <var702:Array[Object]>*/;
-if (var_ret == NULL) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "src/abstract_compiler.nit", 1465);
-exit(1);
-}
-var706 = ((val* (*)(val*, val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__new_expr]))(var_v, var705, var_ret) /* new_expr on <var_v:AbstractCompilerVisitor>*/;
-((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__ret]))(var_v, var706) /* ret on <var_v:AbstractCompilerVisitor>*/;
-goto RET_LABEL;
-} else {
-if (varonce707) {
-var708 = varonce707;
-} else {
-var709 = "==";
-var710 = 2;
-var711 = string__NativeString__to_s_with_length(var709, var710);
-var708 = var711;
-varonce707 = var708;
-}
-var712 = ((short int (*)(val*, val*))(var_pname->class->vft[COLOR_kernel__Object___61d_61d]))(var_pname, var708) /* == on <var_pname:String>*/;
-if (var712){
-var713 = 0;
-var714 = ((val* (*)(val*, long))(var_arguments->class->vft[COLOR_abstract_collection__SequenceRead___91d_93d]))(var_arguments, var713) /* [] on <var_arguments:Array[RuntimeVariable]>*/;
-var715 = 1;
-var716 = ((val* (*)(val*, long))(var_arguments->class->vft[COLOR_abstract_collection__SequenceRead___91d_93d]))(var_arguments, var715) /* [] on <var_arguments:Array[RuntimeVariable]>*/;
-var717 = ((val* (*)(val*, val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__equal_test]))(var_v, var714, var716) /* equal_test on <var_v:AbstractCompilerVisitor>*/;
-((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__ret]))(var_v, var717) /* ret on <var_v:AbstractCompilerVisitor>*/;
+}
+{
+abstract_compiler__RuntimeVariable__init(var26, var27, var_valmtype, var30); /* Direct call abstract_compiler#RuntimeVariable#init on <var26:RuntimeVariable>*/
+}
+var_res = var26;
+var = var_res;
 goto RET_LABEL;
 } else {
-if (varonce718) {
-var719 = varonce718;
-} else {
-var720 = "!=";
-var721 = 2;
-var722 = string__NativeString__to_s_with_length(var720, var721);
-var719 = var722;
-varonce718 = var719;
-}
-var723 = ((short int (*)(val*, val*))(var_pname->class->vft[COLOR_kernel__Object___61d_61d]))(var_pname, var719) /* == on <var_pname:String>*/;
-if (var723){
-var724 = 0;
-var725 = ((val* (*)(val*, long))(var_arguments->class->vft[COLOR_abstract_collection__SequenceRead___91d_93d]))(var_arguments, var724) /* [] on <var_arguments:Array[RuntimeVariable]>*/;
-var726 = 1;
-var727 = ((val* (*)(val*, long))(var_arguments->class->vft[COLOR_abstract_collection__SequenceRead___91d_93d]))(var_arguments, var726) /* [] on <var_arguments:Array[RuntimeVariable]>*/;
-var728 = ((val* (*)(val*, val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__equal_test]))(var_v, var725, var727) /* equal_test on <var_v:AbstractCompilerVisitor>*/;
-var_res729 = var728;
-if (varonce730) {
-var731 = varonce730;
-} else {
-var732 = "!";
-var733 = 1;
-var734 = string__NativeString__to_s_with_length(var732, var733);
-var731 = var734;
-varonce730 = var731;
-}
-var735 = NEW_array__Array(&type_array__Arraykernel__Object);
-{ /* var735 = array_instance Array[Object] */
-var736 = 2;
-var737 = NEW_array__NativeArray(var736, &type_array__NativeArraykernel__Object);
-((struct instance_array__NativeArray*)var737)->values[0] = (val*) var731;
-((struct instance_array__NativeArray*)var737)->values[1] = (val*) var_res729;
-((void (*)(val*, val*, long))(var735->class->vft[COLOR_array__Array__with_native]))(var735, var737, var736) /* with_native on <var735:Array[Object]>*/;
-CHECK_NEW_array__Array(var735);
-}
-var738 = ((val* (*)(val*))(var735->class->vft[COLOR_string__Object__to_s]))(var735) /* to_s on <var735:Array[Object]>*/;
-if (var_ret == NULL) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "src/abstract_compiler.nit", 1472);
-exit(1);
-}
-var739 = ((val* (*)(val*, val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__new_expr]))(var_v, var738, var_ret) /* new_expr on <var_v:AbstractCompilerVisitor>*/;
-((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__ret]))(var_v, var739) /* ret on <var_v:AbstractCompilerVisitor>*/;
+var33 = NEW_abstract_compiler__RuntimeVariable(&type_abstract_compiler__RuntimeVariable);
+{
+{ /* Inline abstract_compiler#RuntimeVariable#name (var_value) on <var_value:RuntimeVariable> */
+var36 = var_value->attrs[COLOR_abstract_compiler__RuntimeVariable___name].val; /* _name on <var_value:RuntimeVariable> */
+if (unlikely(var36 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _name");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 1631);
+show_backtrace(1);
+}
+var34 = var36;
+RET_LABEL35:(void)0;
+}
+}
+{
+abstract_compiler__RuntimeVariable__init(var33, var34, var_valmtype, var_mtype); /* Direct call abstract_compiler#RuntimeVariable#init on <var33:RuntimeVariable>*/
+}
+var_res37 = var33;
+var = var_res37;
 goto RET_LABEL;
+}
+RET_LABEL:;
+return var;
+}
+/* method abstract_compiler#AbstractCompilerVisitor#autoadapt for (self: Object, RuntimeVariable, MType): RuntimeVariable */
+val* VIRTUAL_abstract_compiler__AbstractCompilerVisitor__autoadapt(val* self, val* p0, val* p1) {
+val* var /* : RuntimeVariable */;
+val* var1 /* : RuntimeVariable */;
+var1 = abstract_compiler__AbstractCompilerVisitor__autoadapt(self, p0, p1);
+var = var1;
+RET_LABEL:;
+return var;
+}
+/* method abstract_compiler#AbstractCompilerVisitor#monomorphic_send for (self: AbstractCompilerVisitor, MMethod, MType, Array[RuntimeVariable]): nullable RuntimeVariable */
+val* abstract_compiler__AbstractCompilerVisitor__monomorphic_send(val* self, val* p0, val* p1, val* p2) {
+val* var /* : nullable RuntimeVariable */;
+val* var_m /* var m: MMethod */;
+val* var_t /* var t: MType */;
+val* var_args /* var args: Array[RuntimeVariable] */;
+short int var1 /* : Bool */;
+int cltype;
+int idtype;
+val* var2 /* : AbstractCompiler */;
+val* var4 /* : AbstractCompiler */;
+val* var5 /* : MModule */;
+val* var7 /* : MModule */;
+val* var8 /* : MPropDef */;
+val* var_propdef /* var propdef: MMethodDef */;
+val* var9 /* : nullable RuntimeVariable */;
+var_m = p0;
+var_t = p1;
+var_args = p2;
+/* <var_t:MType> isa MClassType */
+cltype = type_model__MClassType.color;
+idtype = type_model__MClassType.id;
+if(cltype >= var_t->type->table_size) {
+var1 = 0;
 } else {
+var1 = var_t->type->type_table[cltype] == idtype;
 }
+if (unlikely(!var1)) {
+PRINT_ERROR("Runtime error: %s", "Assert failed");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 1224);
+show_backtrace(1);
 }
+{
+{ /* Inline abstract_compiler#AbstractCompilerVisitor#compiler (self) on <self:AbstractCompilerVisitor> */
+var4 = self->attrs[COLOR_abstract_compiler__AbstractCompilerVisitor___compiler].val; /* _compiler on <self:AbstractCompilerVisitor> */
+if (unlikely(var4 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _compiler");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 1041);
+show_backtrace(1);
 }
+var2 = var4;
+RET_LABEL3:(void)0;
 }
-} else {
-if (varonce740) {
-var741 = varonce740;
-} else {
-var742 = "Float";
-var743 = 5;
-var744 = string__NativeString__to_s_with_length(var742, var743);
-var741 = var744;
-varonce740 = var741;
 }
-var745 = ((short int (*)(val*, val*))(var_cname->class->vft[COLOR_kernel__Object___61d_61d]))(var_cname, var741) /* == on <var_cname:String>*/;
-if (var745){
-if (varonce746) {
-var747 = varonce746;
-} else {
-var748 = "output";
-var749 = 6;
-var750 = string__NativeString__to_s_with_length(var748, var749);
-var747 = var750;
-varonce746 = var747;
+{
+{ /* Inline abstract_compiler#AbstractCompiler#mainmodule (var2) on <var2:AbstractCompiler> */
+var7 = var2->attrs[COLOR_abstract_compiler__AbstractCompiler___mainmodule].val; /* _mainmodule on <var2:AbstractCompiler> */
+if (unlikely(var7 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _mainmodule");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 463);
+show_backtrace(1);
 }
-var751 = ((short int (*)(val*, val*))(var_pname->class->vft[COLOR_kernel__Object___61d_61d]))(var_pname, var747) /* == on <var_pname:String>*/;
-if (var751){
-if (varonce752) {
-var753 = varonce752;
-} else {
-var754 = "printf(\"%f\\n\", ";
-var755 = 15;
-var756 = string__NativeString__to_s_with_length(var754, var755);
-var753 = var756;
-varonce752 = var753;
-}
-var757 = ((val* (*)(val*))(var_arguments->class->vft[COLOR_abstract_collection__Collection__first]))(var_arguments) /* first on <var_arguments:Array[RuntimeVariable]>*/;
-if (varonce758) {
-var759 = varonce758;
-} else {
-var760 = ");";
-var761 = 2;
-var762 = string__NativeString__to_s_with_length(var760, var761);
-var759 = var762;
-varonce758 = var759;
-}
-var763 = NEW_array__Array(&type_array__Arraykernel__Object);
-{ /* var763 = array_instance Array[Object] */
-var764 = 3;
-var765 = NEW_array__NativeArray(var764, &type_array__NativeArraykernel__Object);
-((struct instance_array__NativeArray*)var765)->values[0] = (val*) var753;
-((struct instance_array__NativeArray*)var765)->values[1] = (val*) var757;
-((struct instance_array__NativeArray*)var765)->values[2] = (val*) var759;
-((void (*)(val*, val*, long))(var763->class->vft[COLOR_array__Array__with_native]))(var763, var765, var764) /* with_native on <var763:Array[Object]>*/;
-CHECK_NEW_array__Array(var763);
-}
-var766 = ((val* (*)(val*))(var763->class->vft[COLOR_string__Object__to_s]))(var763) /* to_s on <var763:Array[Object]>*/;
-((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(var_v, var766) /* add on <var_v:AbstractCompilerVisitor>*/;
-goto RET_LABEL;
-} else {
-if (varonce767) {
-var768 = varonce767;
-} else {
-var769 = "object_id";
-var770 = 9;
-var771 = string__NativeString__to_s_with_length(var769, var770);
-var768 = var771;
-varonce767 = var768;
+var5 = var7;
+RET_LABEL6:(void)0;
 }
-var772 = ((short int (*)(val*, val*))(var_pname->class->vft[COLOR_kernel__Object___61d_61d]))(var_pname, var768) /* == on <var_pname:String>*/;
-if (var772){
-if (varonce773) {
-var774 = varonce773;
-} else {
-var775 = "(double)";
-var776 = 8;
-var777 = string__NativeString__to_s_with_length(var775, var776);
-var774 = var777;
-varonce773 = var774;
 }
-var778 = ((val* (*)(val*))(var_arguments->class->vft[COLOR_abstract_collection__Collection__first]))(var_arguments) /* first on <var_arguments:Array[RuntimeVariable]>*/;
-var779 = NEW_array__Array(&type_array__Arraykernel__Object);
-{ /* var779 = array_instance Array[Object] */
-var780 = 2;
-var781 = NEW_array__NativeArray(var780, &type_array__NativeArraykernel__Object);
-((struct instance_array__NativeArray*)var781)->values[0] = (val*) var774;
-((struct instance_array__NativeArray*)var781)->values[1] = (val*) var778;
-((void (*)(val*, val*, long))(var779->class->vft[COLOR_array__Array__with_native]))(var779, var781, var780) /* with_native on <var779:Array[Object]>*/;
-CHECK_NEW_array__Array(var779);
+{
+var8 = model__MProperty__lookup_first_definition(var_m, var5, var_t);
 }
-var782 = ((val* (*)(val*))(var779->class->vft[COLOR_string__Object__to_s]))(var779) /* to_s on <var779:Array[Object]>*/;
-if (var_ret == NULL) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "src/abstract_compiler.nit", 1480);
-exit(1);
+var_propdef = var8;
+{
+var9 = separate_compiler__SeparateCompilerVisitor__call(self, var_propdef, var_t, var_args);
 }
-var783 = ((val* (*)(val*, val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__new_expr]))(var_v, var782, var_ret) /* new_expr on <var_v:AbstractCompilerVisitor>*/;
-((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__ret]))(var_v, var783) /* ret on <var_v:AbstractCompilerVisitor>*/;
-goto RET_LABEL;
-} else {
-if (varonce784) {
-var785 = varonce784;
-} else {
-var786 = "+";
-var787 = 1;
-var788 = string__NativeString__to_s_with_length(var786, var787);
-var785 = var788;
-varonce784 = var785;
-}
-var789 = ((short int (*)(val*, val*))(var_pname->class->vft[COLOR_kernel__Object___61d_61d]))(var_pname, var785) /* == on <var_pname:String>*/;
-if (var789){
-var790 = 0;
-var791 = ((val* (*)(val*, long))(var_arguments->class->vft[COLOR_abstract_collection__SequenceRead___91d_93d]))(var_arguments, var790) /* [] on <var_arguments:Array[RuntimeVariable]>*/;
-if (varonce792) {
-var793 = varonce792;
-} else {
-var794 = " + ";
-var795 = 3;
-var796 = string__NativeString__to_s_with_length(var794, var795);
-var793 = var796;
-varonce792 = var793;
-}
-var797 = 1;
-var798 = ((val* (*)(val*, long))(var_arguments->class->vft[COLOR_abstract_collection__SequenceRead___91d_93d]))(var_arguments, var797) /* [] on <var_arguments:Array[RuntimeVariable]>*/;
-var799 = NEW_array__Array(&type_array__Arraykernel__Object);
-{ /* var799 = array_instance Array[Object] */
-var800 = 3;
-var801 = NEW_array__NativeArray(var800, &type_array__NativeArraykernel__Object);
-((struct instance_array__NativeArray*)var801)->values[0] = (val*) var791;
-((struct instance_array__NativeArray*)var801)->values[1] = (val*) var793;
-((struct instance_array__NativeArray*)var801)->values[2] = (val*) var798;
-((void (*)(val*, val*, long))(var799->class->vft[COLOR_array__Array__with_native]))(var799, var801, var800) /* with_native on <var799:Array[Object]>*/;
-CHECK_NEW_array__Array(var799);
-}
-var802 = ((val* (*)(val*))(var799->class->vft[COLOR_string__Object__to_s]))(var799) /* to_s on <var799:Array[Object]>*/;
-if (var_ret == NULL) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "src/abstract_compiler.nit", 1483);
-exit(1);
-}
-var803 = ((val* (*)(val*, val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__new_expr]))(var_v, var802, var_ret) /* new_expr on <var_v:AbstractCompilerVisitor>*/;
-((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__ret]))(var_v, var803) /* ret on <var_v:AbstractCompilerVisitor>*/;
+var = var9;
 goto RET_LABEL;
-} else {
-if (varonce804) {
-var805 = varonce804;
-} else {
-var806 = "-";
-var807 = 1;
-var808 = string__NativeString__to_s_with_length(var806, var807);
-var805 = var808;
-varonce804 = var805;
+RET_LABEL:;
+return var;
 }
-var809 = ((short int (*)(val*, val*))(var_pname->class->vft[COLOR_kernel__Object___61d_61d]))(var_pname, var805) /* == on <var_pname:String>*/;
-if (var809){
-var810 = 0;
-var811 = ((val* (*)(val*, long))(var_arguments->class->vft[COLOR_abstract_collection__SequenceRead___91d_93d]))(var_arguments, var810) /* [] on <var_arguments:Array[RuntimeVariable]>*/;
-if (varonce812) {
-var813 = varonce812;
-} else {
-var814 = " - ";
-var815 = 3;
-var816 = string__NativeString__to_s_with_length(var814, var815);
-var813 = var816;
-varonce812 = var813;
-}
-var817 = 1;
-var818 = ((val* (*)(val*, long))(var_arguments->class->vft[COLOR_abstract_collection__SequenceRead___91d_93d]))(var_arguments, var817) /* [] on <var_arguments:Array[RuntimeVariable]>*/;
-var819 = NEW_array__Array(&type_array__Arraykernel__Object);
-{ /* var819 = array_instance Array[Object] */
-var820 = 3;
-var821 = NEW_array__NativeArray(var820, &type_array__NativeArraykernel__Object);
-((struct instance_array__NativeArray*)var821)->values[0] = (val*) var811;
-((struct instance_array__NativeArray*)var821)->values[1] = (val*) var813;
-((struct instance_array__NativeArray*)var821)->values[2] = (val*) var818;
-((void (*)(val*, val*, long))(var819->class->vft[COLOR_array__Array__with_native]))(var819, var821, var820) /* with_native on <var819:Array[Object]>*/;
-CHECK_NEW_array__Array(var819);
-}
-var822 = ((val* (*)(val*))(var819->class->vft[COLOR_string__Object__to_s]))(var819) /* to_s on <var819:Array[Object]>*/;
-if (var_ret == NULL) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "src/abstract_compiler.nit", 1486);
-exit(1);
-}
-var823 = ((val* (*)(val*, val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__new_expr]))(var_v, var822, var_ret) /* new_expr on <var_v:AbstractCompilerVisitor>*/;
-((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__ret]))(var_v, var823) /* ret on <var_v:AbstractCompilerVisitor>*/;
-goto RET_LABEL;
-} else {
-if (varonce824) {
-var825 = varonce824;
-} else {
-var826 = "unary -";
-var827 = 7;
-var828 = string__NativeString__to_s_with_length(var826, var827);
-var825 = var828;
-varonce824 = var825;
+/* method abstract_compiler#AbstractCompilerVisitor#monomorphic_send for (self: Object, MMethod, MType, Array[RuntimeVariable]): nullable RuntimeVariable */
+val* VIRTUAL_abstract_compiler__AbstractCompilerVisitor__monomorphic_send(val* self, val* p0, val* p1, val* p2) {
+val* var /* : nullable RuntimeVariable */;
+val* var1 /* : nullable RuntimeVariable */;
+var1 = abstract_compiler__AbstractCompilerVisitor__monomorphic_send(self, p0, p1, p2);
+var = var1;
+RET_LABEL:;
+return var;
 }
-var829 = ((short int (*)(val*, val*))(var_pname->class->vft[COLOR_kernel__Object___61d_61d]))(var_pname, var825) /* == on <var_pname:String>*/;
-if (var829){
-if (varonce830) {
-var831 = varonce830;
-} else {
-var832 = "-";
-var833 = 1;
-var834 = string__NativeString__to_s_with_length(var832, var833);
-var831 = var834;
-varonce830 = var831;
-}
-var835 = 0;
-var836 = ((val* (*)(val*, long))(var_arguments->class->vft[COLOR_abstract_collection__SequenceRead___91d_93d]))(var_arguments, var835) /* [] on <var_arguments:Array[RuntimeVariable]>*/;
-var837 = NEW_array__Array(&type_array__Arraykernel__Object);
-{ /* var837 = array_instance Array[Object] */
-var838 = 2;
-var839 = NEW_array__NativeArray(var838, &type_array__NativeArraykernel__Object);
-((struct instance_array__NativeArray*)var839)->values[0] = (val*) var831;
-((struct instance_array__NativeArray*)var839)->values[1] = (val*) var836;
-((void (*)(val*, val*, long))(var837->class->vft[COLOR_array__Array__with_native]))(var837, var839, var838) /* with_native on <var837:Array[Object]>*/;
-CHECK_NEW_array__Array(var837);
-}
-var840 = ((val* (*)(val*))(var837->class->vft[COLOR_string__Object__to_s]))(var837) /* to_s on <var837:Array[Object]>*/;
-if (var_ret == NULL) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "src/abstract_compiler.nit", 1489);
-exit(1);
-}
-var841 = ((val* (*)(val*, val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__new_expr]))(var_v, var840, var_ret) /* new_expr on <var_v:AbstractCompilerVisitor>*/;
-((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__ret]))(var_v, var841) /* ret on <var_v:AbstractCompilerVisitor>*/;
-goto RET_LABEL;
-} else {
-if (varonce842) {
-var843 = varonce842;
-} else {
-var844 = "succ";
-var845 = 4;
-var846 = string__NativeString__to_s_with_length(var844, var845);
-var843 = var846;
-varonce842 = var843;
-}
-var847 = ((short int (*)(val*, val*))(var_pname->class->vft[COLOR_kernel__Object___61d_61d]))(var_pname, var843) /* == on <var_pname:String>*/;
-if (var847){
-var848 = 0;
-var849 = ((val* (*)(val*, long))(var_arguments->class->vft[COLOR_abstract_collection__SequenceRead___91d_93d]))(var_arguments, var848) /* [] on <var_arguments:Array[RuntimeVariable]>*/;
-if (varonce850) {
-var851 = varonce850;
-} else {
-var852 = "+1";
-var853 = 2;
-var854 = string__NativeString__to_s_with_length(var852, var853);
-var851 = var854;
-varonce850 = var851;
-}
-var855 = NEW_array__Array(&type_array__Arraykernel__Object);
-{ /* var855 = array_instance Array[Object] */
-var856 = 2;
-var857 = NEW_array__NativeArray(var856, &type_array__NativeArraykernel__Object);
-((struct instance_array__NativeArray*)var857)->values[0] = (val*) var849;
-((struct instance_array__NativeArray*)var857)->values[1] = (val*) var851;
-((void (*)(val*, val*, long))(var855->class->vft[COLOR_array__Array__with_native]))(var855, var857, var856) /* with_native on <var855:Array[Object]>*/;
-CHECK_NEW_array__Array(var855);
-}
-var858 = ((val* (*)(val*))(var855->class->vft[COLOR_string__Object__to_s]))(var855) /* to_s on <var855:Array[Object]>*/;
-if (var_ret == NULL) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "src/abstract_compiler.nit", 1492);
-exit(1);
-}
-var859 = ((val* (*)(val*, val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__new_expr]))(var_v, var858, var_ret) /* new_expr on <var_v:AbstractCompilerVisitor>*/;
-((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__ret]))(var_v, var859) /* ret on <var_v:AbstractCompilerVisitor>*/;
-goto RET_LABEL;
-} else {
-if (varonce860) {
-var861 = varonce860;
-} else {
-var862 = "prec";
-var863 = 4;
-var864 = string__NativeString__to_s_with_length(var862, var863);
-var861 = var864;
-varonce860 = var861;
-}
-var865 = ((short int (*)(val*, val*))(var_pname->class->vft[COLOR_kernel__Object___61d_61d]))(var_pname, var861) /* == on <var_pname:String>*/;
-if (var865){
-var866 = 0;
-var867 = ((val* (*)(val*, long))(var_arguments->class->vft[COLOR_abstract_collection__SequenceRead___91d_93d]))(var_arguments, var866) /* [] on <var_arguments:Array[RuntimeVariable]>*/;
-if (varonce868) {
-var869 = varonce868;
-} else {
-var870 = "-1";
-var871 = 2;
-var872 = string__NativeString__to_s_with_length(var870, var871);
-var869 = var872;
-varonce868 = var869;
-}
-var873 = NEW_array__Array(&type_array__Arraykernel__Object);
-{ /* var873 = array_instance Array[Object] */
-var874 = 2;
-var875 = NEW_array__NativeArray(var874, &type_array__NativeArraykernel__Object);
-((struct instance_array__NativeArray*)var875)->values[0] = (val*) var867;
-((struct instance_array__NativeArray*)var875)->values[1] = (val*) var869;
-((void (*)(val*, val*, long))(var873->class->vft[COLOR_array__Array__with_native]))(var873, var875, var874) /* with_native on <var873:Array[Object]>*/;
-CHECK_NEW_array__Array(var873);
-}
-var876 = ((val* (*)(val*))(var873->class->vft[COLOR_string__Object__to_s]))(var873) /* to_s on <var873:Array[Object]>*/;
-if (var_ret == NULL) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "src/abstract_compiler.nit", 1495);
-exit(1);
-}
-var877 = ((val* (*)(val*, val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__new_expr]))(var_v, var876, var_ret) /* new_expr on <var_v:AbstractCompilerVisitor>*/;
-((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__ret]))(var_v, var877) /* ret on <var_v:AbstractCompilerVisitor>*/;
-goto RET_LABEL;
-} else {
-if (varonce878) {
-var879 = varonce878;
+/* method abstract_compiler#AbstractCompilerVisitor#monomorphic_super_send for (self: AbstractCompilerVisitor, MMethodDef, MType, Array[RuntimeVariable]): nullable RuntimeVariable */
+val* abstract_compiler__AbstractCompilerVisitor__monomorphic_super_send(val* self, val* p0, val* p1, val* p2) {
+val* var /* : nullable RuntimeVariable */;
+val* var_m /* var m: MMethodDef */;
+val* var_t /* var t: MType */;
+val* var_args /* var args: Array[RuntimeVariable] */;
+short int var1 /* : Bool */;
+int cltype;
+int idtype;
+val* var2 /* : AbstractCompiler */;
+val* var4 /* : AbstractCompiler */;
+val* var5 /* : MModule */;
+val* var7 /* : MModule */;
+val* var8 /* : MPropDef */;
+val* var9 /* : nullable RuntimeVariable */;
+var_m = p0;
+var_t = p1;
+var_args = p2;
+/* <var_t:MType> isa MClassType */
+cltype = type_model__MClassType.color;
+idtype = type_model__MClassType.id;
+if(cltype >= var_t->type->table_size) {
+var1 = 0;
 } else {
-var880 = "*";
-var881 = 1;
-var882 = string__NativeString__to_s_with_length(var880, var881);
-var879 = var882;
-varonce878 = var879;
+var1 = var_t->type->type_table[cltype] == idtype;
 }
-var883 = ((short int (*)(val*, val*))(var_pname->class->vft[COLOR_kernel__Object___61d_61d]))(var_pname, var879) /* == on <var_pname:String>*/;
-if (var883){
-var884 = 0;
-var885 = ((val* (*)(val*, long))(var_arguments->class->vft[COLOR_abstract_collection__SequenceRead___91d_93d]))(var_arguments, var884) /* [] on <var_arguments:Array[RuntimeVariable]>*/;
-if (varonce886) {
-var887 = varonce886;
-} else {
-var888 = " * ";
-var889 = 3;
-var890 = string__NativeString__to_s_with_length(var888, var889);
-var887 = var890;
-varonce886 = var887;
+if (unlikely(!var1)) {
+PRINT_ERROR("Runtime error: %s", "Assert failed");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 1232);
+show_backtrace(1);
+}
+{
+{ /* Inline abstract_compiler#AbstractCompilerVisitor#compiler (self) on <self:AbstractCompilerVisitor> */
+var4 = self->attrs[COLOR_abstract_compiler__AbstractCompilerVisitor___compiler].val; /* _compiler on <self:AbstractCompilerVisitor> */
+if (unlikely(var4 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _compiler");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 1041);
+show_backtrace(1);
+}
+var2 = var4;
+RET_LABEL3:(void)0;
+}
+}
+{
+{ /* Inline abstract_compiler#AbstractCompiler#mainmodule (var2) on <var2:AbstractCompiler> */
+var7 = var2->attrs[COLOR_abstract_compiler__AbstractCompiler___mainmodule].val; /* _mainmodule on <var2:AbstractCompiler> */
+if (unlikely(var7 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _mainmodule");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 463);
+show_backtrace(1);
 }
-var891 = 1;
-var892 = ((val* (*)(val*, long))(var_arguments->class->vft[COLOR_abstract_collection__SequenceRead___91d_93d]))(var_arguments, var891) /* [] on <var_arguments:Array[RuntimeVariable]>*/;
-var893 = NEW_array__Array(&type_array__Arraykernel__Object);
-{ /* var893 = array_instance Array[Object] */
-var894 = 3;
-var895 = NEW_array__NativeArray(var894, &type_array__NativeArraykernel__Object);
-((struct instance_array__NativeArray*)var895)->values[0] = (val*) var885;
-((struct instance_array__NativeArray*)var895)->values[1] = (val*) var887;
-((struct instance_array__NativeArray*)var895)->values[2] = (val*) var892;
-((void (*)(val*, val*, long))(var893->class->vft[COLOR_array__Array__with_native]))(var893, var895, var894) /* with_native on <var893:Array[Object]>*/;
-CHECK_NEW_array__Array(var893);
-}
-var896 = ((val* (*)(val*))(var893->class->vft[COLOR_string__Object__to_s]))(var893) /* to_s on <var893:Array[Object]>*/;
-if (var_ret == NULL) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "src/abstract_compiler.nit", 1498);
-exit(1);
-}
-var897 = ((val* (*)(val*, val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__new_expr]))(var_v, var896, var_ret) /* new_expr on <var_v:AbstractCompilerVisitor>*/;
-((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__ret]))(var_v, var897) /* ret on <var_v:AbstractCompilerVisitor>*/;
+var5 = var7;
+RET_LABEL6:(void)0;
+}
+}
+{
+var8 = model__MPropDef__lookup_next_definition(var_m, var5, var_t);
+}
+var_m = var8;
+{
+var9 = separate_compiler__SeparateCompilerVisitor__call(self, var_m, var_t, var_args);
+}
+var = var9;
 goto RET_LABEL;
-} else {
-if (varonce898) {
-var899 = varonce898;
-} else {
-var900 = "/";
-var901 = 1;
-var902 = string__NativeString__to_s_with_length(var900, var901);
-var899 = var902;
-varonce898 = var899;
-}
-var903 = ((short int (*)(val*, val*))(var_pname->class->vft[COLOR_kernel__Object___61d_61d]))(var_pname, var899) /* == on <var_pname:String>*/;
-if (var903){
-var904 = 0;
-var905 = ((val* (*)(val*, long))(var_arguments->class->vft[COLOR_abstract_collection__SequenceRead___91d_93d]))(var_arguments, var904) /* [] on <var_arguments:Array[RuntimeVariable]>*/;
-if (varonce906) {
-var907 = varonce906;
-} else {
-var908 = " / ";
-var909 = 3;
-var910 = string__NativeString__to_s_with_length(var908, var909);
-var907 = var910;
-varonce906 = var907;
-}
-var911 = 1;
-var912 = ((val* (*)(val*, long))(var_arguments->class->vft[COLOR_abstract_collection__SequenceRead___91d_93d]))(var_arguments, var911) /* [] on <var_arguments:Array[RuntimeVariable]>*/;
-var913 = NEW_array__Array(&type_array__Arraykernel__Object);
-{ /* var913 = array_instance Array[Object] */
-var914 = 3;
-var915 = NEW_array__NativeArray(var914, &type_array__NativeArraykernel__Object);
-((struct instance_array__NativeArray*)var915)->values[0] = (val*) var905;
-((struct instance_array__NativeArray*)var915)->values[1] = (val*) var907;
-((struct instance_array__NativeArray*)var915)->values[2] = (val*) var912;
-((void (*)(val*, val*, long))(var913->class->vft[COLOR_array__Array__with_native]))(var913, var915, var914) /* with_native on <var913:Array[Object]>*/;
-CHECK_NEW_array__Array(var913);
-}
-var916 = ((val* (*)(val*))(var913->class->vft[COLOR_string__Object__to_s]))(var913) /* to_s on <var913:Array[Object]>*/;
-if (var_ret == NULL) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "src/abstract_compiler.nit", 1501);
-exit(1);
-}
-var917 = ((val* (*)(val*, val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__new_expr]))(var_v, var916, var_ret) /* new_expr on <var_v:AbstractCompilerVisitor>*/;
-((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__ret]))(var_v, var917) /* ret on <var_v:AbstractCompilerVisitor>*/;
+RET_LABEL:;
+return var;
+}
+/* method abstract_compiler#AbstractCompilerVisitor#monomorphic_super_send for (self: Object, MMethodDef, MType, Array[RuntimeVariable]): nullable RuntimeVariable */
+val* VIRTUAL_abstract_compiler__AbstractCompilerVisitor__monomorphic_super_send(val* self, val* p0, val* p1, val* p2) {
+val* var /* : nullable RuntimeVariable */;
+val* var1 /* : nullable RuntimeVariable */;
+var1 = abstract_compiler__AbstractCompilerVisitor__monomorphic_super_send(self, p0, p1, p2);
+var = var1;
+RET_LABEL:;
+return var;
+}
+/* method abstract_compiler#AbstractCompilerVisitor#check_recv_notnull for (self: AbstractCompilerVisitor, RuntimeVariable) */
+void abstract_compiler__AbstractCompilerVisitor__check_recv_notnull(val* self, val* p0) {
+val* var_recv /* var recv: RuntimeVariable */;
+val* var /* : AbstractCompiler */;
+val* var2 /* : AbstractCompiler */;
+val* var3 /* : ModelBuilder */;
+val* var5 /* : ModelBuilder */;
+val* var6 /* : ToolContext */;
+val* var8 /* : ToolContext */;
+val* var9 /* : OptionBool */;
+val* var11 /* : OptionBool */;
+val* var12 /* : nullable Object */;
+val* var14 /* : nullable Object */;
+short int var15 /* : Bool */;
+short int var16 /* : Bool */;
+val* var17 /* : MType */;
+val* var19 /* : MType */;
+short int var20 /* : Bool */;
+int cltype;
+int idtype;
+short int var_ /* var : Bool */;
+val* var21 /* : MType */;
+val* var23 /* : MType */;
+short int var24 /* : Bool */;
+int cltype25;
+int idtype26;
+short int var_maybenull /* var maybenull: Bool */;
+static val* varonce;
+val* var27 /* : String */;
+char* var28 /* : NativeString */;
+long var29 /* : Int */;
+val* var30 /* : FlatString */;
+static val* varonce31;
+val* var32 /* : String */;
+char* var33 /* : NativeString */;
+long var34 /* : Int */;
+val* var35 /* : FlatString */;
+val* var36 /* : Array[Object] */;
+long var37 /* : Int */;
+val* var38 /* : NativeArray[Object] */;
+val* var39 /* : String */;
+static val* varonce40;
+val* var41 /* : String */;
+char* var42 /* : NativeString */;
+long var43 /* : Int */;
+val* var44 /* : FlatString */;
+static val* varonce45;
+val* var46 /* : String */;
+char* var47 /* : NativeString */;
+long var48 /* : Int */;
+val* var49 /* : FlatString */;
+var_recv = p0;
+{
+{ /* Inline abstract_compiler#AbstractCompilerVisitor#compiler (self) on <self:AbstractCompilerVisitor> */
+var2 = self->attrs[COLOR_abstract_compiler__AbstractCompilerVisitor___compiler].val; /* _compiler on <self:AbstractCompilerVisitor> */
+if (unlikely(var2 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _compiler");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 1041);
+show_backtrace(1);
+}
+var = var2;
+RET_LABEL1:(void)0;
+}
+}
+{
+{ /* Inline abstract_compiler#AbstractCompiler#modelbuilder (var) on <var:AbstractCompiler> */
+var5 = var->attrs[COLOR_abstract_compiler__AbstractCompiler___modelbuilder].val; /* _modelbuilder on <var:AbstractCompiler> */
+if (unlikely(var5 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _modelbuilder");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 470);
+show_backtrace(1);
+}
+var3 = var5;
+RET_LABEL4:(void)0;
+}
+}
+{
+{ /* Inline modelbuilder#ModelBuilder#toolcontext (var3) on <var3:ModelBuilder> */
+var8 = var3->attrs[COLOR_modelbuilder__ModelBuilder___toolcontext].val; /* _toolcontext on <var3:ModelBuilder> */
+if (unlikely(var8 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _toolcontext");
+PRINT_ERROR(" (%s:%d)\n", "modelbuilder.nit", 106);
+show_backtrace(1);
+}
+var6 = var8;
+RET_LABEL7:(void)0;
+}
+}
+{
+{ /* Inline abstract_compiler#ToolContext#opt_no_check_null (var6) on <var6:ToolContext> */
+var11 = var6->attrs[COLOR_abstract_compiler__ToolContext___opt_no_check_null].val; /* _opt_no_check_null on <var6:ToolContext> */
+if (unlikely(var11 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _opt_no_check_null");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 57);
+show_backtrace(1);
+}
+var9 = var11;
+RET_LABEL10:(void)0;
+}
+}
+{
+{ /* Inline opts#Option#value (var9) on <var9:OptionBool> */
+var14 = var9->attrs[COLOR_opts__Option___value].val; /* _value on <var9:OptionBool> */
+var12 = var14;
+RET_LABEL13:(void)0;
+}
+}
+var15 = ((struct instance_kernel__Bool*)var12)->value; /* autounbox from nullable Object to Bool */;
+if (var15){
 goto RET_LABEL;
 } else {
-if (varonce918) {
-var919 = varonce918;
-} else {
-var920 = "==";
-var921 = 2;
-var922 = string__NativeString__to_s_with_length(var920, var921);
-var919 = var922;
-varonce918 = var919;
-}
-var923 = ((short int (*)(val*, val*))(var_pname->class->vft[COLOR_kernel__Object___61d_61d]))(var_pname, var919) /* == on <var_pname:String>*/;
-if (var923){
-var924 = 0;
-var925 = ((val* (*)(val*, long))(var_arguments->class->vft[COLOR_abstract_collection__SequenceRead___91d_93d]))(var_arguments, var924) /* [] on <var_arguments:Array[RuntimeVariable]>*/;
-var926 = 1;
-var927 = ((val* (*)(val*, long))(var_arguments->class->vft[COLOR_abstract_collection__SequenceRead___91d_93d]))(var_arguments, var926) /* [] on <var_arguments:Array[RuntimeVariable]>*/;
-var928 = ((val* (*)(val*, val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__equal_test]))(var_v, var925, var927) /* equal_test on <var_v:AbstractCompilerVisitor>*/;
-((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__ret]))(var_v, var928) /* ret on <var_v:AbstractCompilerVisitor>*/;
-goto RET_LABEL;
+}
+{
+{ /* Inline abstract_compiler#RuntimeVariable#mcasttype (var_recv) on <var_recv:RuntimeVariable> */
+var19 = var_recv->attrs[COLOR_abstract_compiler__RuntimeVariable___mcasttype].val; /* _mcasttype on <var_recv:RuntimeVariable> */
+if (unlikely(var19 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _mcasttype");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 1637);
+show_backtrace(1);
+}
+var17 = var19;
+RET_LABEL18:(void)0;
+}
+}
+/* <var17:MType> isa MNullableType */
+cltype = type_model__MNullableType.color;
+idtype = type_model__MNullableType.id;
+if(cltype >= var17->type->table_size) {
+var20 = 0;
 } else {
-if (varonce929) {
-var930 = varonce929;
+var20 = var17->type->type_table[cltype] == idtype;
+}
+var_ = var20;
+if (var20){
+var16 = var_;
 } else {
-var931 = "!=";
-var932 = 2;
-var933 = string__NativeString__to_s_with_length(var931, var932);
-var930 = var933;
-varonce929 = var930;
+{
+{ /* Inline abstract_compiler#RuntimeVariable#mcasttype (var_recv) on <var_recv:RuntimeVariable> */
+var23 = var_recv->attrs[COLOR_abstract_compiler__RuntimeVariable___mcasttype].val; /* _mcasttype on <var_recv:RuntimeVariable> */
+if (unlikely(var23 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _mcasttype");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 1637);
+show_backtrace(1);
 }
-var934 = ((short int (*)(val*, val*))(var_pname->class->vft[COLOR_kernel__Object___61d_61d]))(var_pname, var930) /* == on <var_pname:String>*/;
-if (var934){
-var935 = 0;
-var936 = ((val* (*)(val*, long))(var_arguments->class->vft[COLOR_abstract_collection__SequenceRead___91d_93d]))(var_arguments, var935) /* [] on <var_arguments:Array[RuntimeVariable]>*/;
-var937 = 1;
-var938 = ((val* (*)(val*, long))(var_arguments->class->vft[COLOR_abstract_collection__SequenceRead___91d_93d]))(var_arguments, var937) /* [] on <var_arguments:Array[RuntimeVariable]>*/;
-var939 = ((val* (*)(val*, val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__equal_test]))(var_v, var936, var938) /* equal_test on <var_v:AbstractCompilerVisitor>*/;
-var_res940 = var939;
-if (varonce941) {
-var942 = varonce941;
-} else {
-var943 = "!";
-var944 = 1;
-var945 = string__NativeString__to_s_with_length(var943, var944);
-var942 = var945;
-varonce941 = var942;
-}
-var946 = NEW_array__Array(&type_array__Arraykernel__Object);
-{ /* var946 = array_instance Array[Object] */
-var947 = 2;
-var948 = NEW_array__NativeArray(var947, &type_array__NativeArraykernel__Object);
-((struct instance_array__NativeArray*)var948)->values[0] = (val*) var942;
-((struct instance_array__NativeArray*)var948)->values[1] = (val*) var_res940;
-((void (*)(val*, val*, long))(var946->class->vft[COLOR_array__Array__with_native]))(var946, var948, var947) /* with_native on <var946:Array[Object]>*/;
-CHECK_NEW_array__Array(var946);
-}
-var949 = ((val* (*)(val*))(var946->class->vft[COLOR_string__Object__to_s]))(var946) /* to_s on <var946:Array[Object]>*/;
-if (var_ret == NULL) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "src/abstract_compiler.nit", 1508);
-exit(1);
-}
-var950 = ((val* (*)(val*, val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__new_expr]))(var_v, var949, var_ret) /* new_expr on <var_v:AbstractCompilerVisitor>*/;
-((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__ret]))(var_v, var950) /* ret on <var_v:AbstractCompilerVisitor>*/;
-goto RET_LABEL;
+var21 = var23;
+RET_LABEL22:(void)0;
+}
+}
+/* <var21:MType> isa MNullType */
+cltype25 = type_model__MNullType.color;
+idtype26 = type_model__MNullType.id;
+if(cltype25 >= var21->type->table_size) {
+var24 = 0;
 } else {
-if (varonce951) {
-var952 = varonce951;
-} else {
-var953 = "<";
-var954 = 1;
-var955 = string__NativeString__to_s_with_length(var953, var954);
-var952 = var955;
-varonce951 = var952;
-}
-var956 = ((short int (*)(val*, val*))(var_pname->class->vft[COLOR_kernel__Object___61d_61d]))(var_pname, var952) /* == on <var_pname:String>*/;
-if (var956){
-var957 = 0;
-var958 = ((val* (*)(val*, long))(var_arguments->class->vft[COLOR_abstract_collection__SequenceRead___91d_93d]))(var_arguments, var957) /* [] on <var_arguments:Array[RuntimeVariable]>*/;
-if (varonce959) {
-var960 = varonce959;
-} else {
-var961 = " < ";
-var962 = 3;
-var963 = string__NativeString__to_s_with_length(var961, var962);
-var960 = var963;
-varonce959 = var960;
-}
-var964 = 1;
-var965 = ((val* (*)(val*, long))(var_arguments->class->vft[COLOR_abstract_collection__SequenceRead___91d_93d]))(var_arguments, var964) /* [] on <var_arguments:Array[RuntimeVariable]>*/;
-var966 = NEW_array__Array(&type_array__Arraykernel__Object);
-{ /* var966 = array_instance Array[Object] */
-var967 = 3;
-var968 = NEW_array__NativeArray(var967, &type_array__NativeArraykernel__Object);
-((struct instance_array__NativeArray*)var968)->values[0] = (val*) var958;
-((struct instance_array__NativeArray*)var968)->values[1] = (val*) var960;
-((struct instance_array__NativeArray*)var968)->values[2] = (val*) var965;
-((void (*)(val*, val*, long))(var966->class->vft[COLOR_array__Array__with_native]))(var966, var968, var967) /* with_native on <var966:Array[Object]>*/;
-CHECK_NEW_array__Array(var966);
-}
-var969 = ((val* (*)(val*))(var966->class->vft[COLOR_string__Object__to_s]))(var966) /* to_s on <var966:Array[Object]>*/;
-if (var_ret == NULL) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "src/abstract_compiler.nit", 1511);
-exit(1);
-}
-var970 = ((val* (*)(val*, val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__new_expr]))(var_v, var969, var_ret) /* new_expr on <var_v:AbstractCompilerVisitor>*/;
-((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__ret]))(var_v, var970) /* ret on <var_v:AbstractCompilerVisitor>*/;
-goto RET_LABEL;
+var24 = var21->type->type_table[cltype25] == idtype26;
+}
+var16 = var24;
+}
+var_maybenull = var16;
+if (var_maybenull){
+if (varonce) {
+var27 = varonce;
 } else {
-if (varonce971) {
-var972 = varonce971;
-} else {
-var973 = ">";
-var974 = 1;
-var975 = string__NativeString__to_s_with_length(var973, var974);
-var972 = var975;
-varonce971 = var972;
-}
-var976 = ((short int (*)(val*, val*))(var_pname->class->vft[COLOR_kernel__Object___61d_61d]))(var_pname, var972) /* == on <var_pname:String>*/;
-if (var976){
-var977 = 0;
-var978 = ((val* (*)(val*, long))(var_arguments->class->vft[COLOR_abstract_collection__SequenceRead___91d_93d]))(var_arguments, var977) /* [] on <var_arguments:Array[RuntimeVariable]>*/;
-if (varonce979) {
-var980 = varonce979;
-} else {
-var981 = " > ";
-var982 = 3;
-var983 = string__NativeString__to_s_with_length(var981, var982);
-var980 = var983;
-varonce979 = var980;
-}
-var984 = 1;
-var985 = ((val* (*)(val*, long))(var_arguments->class->vft[COLOR_abstract_collection__SequenceRead___91d_93d]))(var_arguments, var984) /* [] on <var_arguments:Array[RuntimeVariable]>*/;
-var986 = NEW_array__Array(&type_array__Arraykernel__Object);
-{ /* var986 = array_instance Array[Object] */
-var987 = 3;
-var988 = NEW_array__NativeArray(var987, &type_array__NativeArraykernel__Object);
-((struct instance_array__NativeArray*)var988)->values[0] = (val*) var978;
-((struct instance_array__NativeArray*)var988)->values[1] = (val*) var980;
-((struct instance_array__NativeArray*)var988)->values[2] = (val*) var985;
-((void (*)(val*, val*, long))(var986->class->vft[COLOR_array__Array__with_native]))(var986, var988, var987) /* with_native on <var986:Array[Object]>*/;
-CHECK_NEW_array__Array(var986);
-}
-var989 = ((val* (*)(val*))(var986->class->vft[COLOR_string__Object__to_s]))(var986) /* to_s on <var986:Array[Object]>*/;
-if (var_ret == NULL) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "src/abstract_compiler.nit", 1514);
-exit(1);
-}
-var990 = ((val* (*)(val*, val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__new_expr]))(var_v, var989, var_ret) /* new_expr on <var_v:AbstractCompilerVisitor>*/;
-((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__ret]))(var_v, var990) /* ret on <var_v:AbstractCompilerVisitor>*/;
-goto RET_LABEL;
+var28 = "if (unlikely(";
+var29 = 13;
+var30 = string__NativeString__to_s_with_length(var28, var29);
+var27 = var30;
+varonce = var27;
+}
+if (varonce31) {
+var32 = varonce31;
 } else {
-if (varonce991) {
-var992 = varonce991;
-} else {
-var993 = "<=";
-var994 = 2;
-var995 = string__NativeString__to_s_with_length(var993, var994);
-var992 = var995;
-varonce991 = var992;
-}
-var996 = ((short int (*)(val*, val*))(var_pname->class->vft[COLOR_kernel__Object___61d_61d]))(var_pname, var992) /* == on <var_pname:String>*/;
-if (var996){
-var997 = 0;
-var998 = ((val* (*)(val*, long))(var_arguments->class->vft[COLOR_abstract_collection__SequenceRead___91d_93d]))(var_arguments, var997) /* [] on <var_arguments:Array[RuntimeVariable]>*/;
-if (varonce999) {
-var1000 = varonce999;
-} else {
-var1001 = " <= ";
-var1002 = 4;
-var1003 = string__NativeString__to_s_with_length(var1001, var1002);
-var1000 = var1003;
-varonce999 = var1000;
-}
-var1004 = 1;
-var1005 = ((val* (*)(val*, long))(var_arguments->class->vft[COLOR_abstract_collection__SequenceRead___91d_93d]))(var_arguments, var1004) /* [] on <var_arguments:Array[RuntimeVariable]>*/;
-var1006 = NEW_array__Array(&type_array__Arraykernel__Object);
-{ /* var1006 = array_instance Array[Object] */
-var1007 = 3;
-var1008 = NEW_array__NativeArray(var1007, &type_array__NativeArraykernel__Object);
-((struct instance_array__NativeArray*)var1008)->values[0] = (val*) var998;
-((struct instance_array__NativeArray*)var1008)->values[1] = (val*) var1000;
-((struct instance_array__NativeArray*)var1008)->values[2] = (val*) var1005;
-((void (*)(val*, val*, long))(var1006->class->vft[COLOR_array__Array__with_native]))(var1006, var1008, var1007) /* with_native on <var1006:Array[Object]>*/;
-CHECK_NEW_array__Array(var1006);
-}
-var1009 = ((val* (*)(val*))(var1006->class->vft[COLOR_string__Object__to_s]))(var1006) /* to_s on <var1006:Array[Object]>*/;
-if (var_ret == NULL) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "src/abstract_compiler.nit", 1517);
-exit(1);
-}
-var1010 = ((val* (*)(val*, val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__new_expr]))(var_v, var1009, var_ret) /* new_expr on <var_v:AbstractCompilerVisitor>*/;
-((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__ret]))(var_v, var1010) /* ret on <var_v:AbstractCompilerVisitor>*/;
-goto RET_LABEL;
+var33 = " == NULL)) {";
+var34 = 12;
+var35 = string__NativeString__to_s_with_length(var33, var34);
+var32 = var35;
+varonce31 = var32;
+}
+var36 = NEW_array__Array(&type_array__Arraykernel__Object);
+{ /* var36 = array_instance Array[Object] */
+var37 = 3;
+var38 = NEW_array__NativeArray(var37, &type_array__NativeArraykernel__Object);
+((struct instance_array__NativeArray*)var38)->values[0] = (val*) var27;
+((struct instance_array__NativeArray*)var38)->values[1] = (val*) var_recv;
+((struct instance_array__NativeArray*)var38)->values[2] = (val*) var32;
+{
+((void (*)(val*, val*, long))(var36->class->vft[COLOR_array__Array__with_native]))(var36, var38, var37) /* with_native on <var36:Array[Object]>*/;
+}
+}
+{
+var39 = ((val* (*)(val*))(var36->class->vft[COLOR_string__Object__to_s]))(var36) /* to_s on <var36:Array[Object]>*/;
+}
+{
+abstract_compiler__AbstractCompilerVisitor__add(self, var39); /* Direct call abstract_compiler#AbstractCompilerVisitor#add on <self:AbstractCompilerVisitor>*/
+}
+if (varonce40) {
+var41 = varonce40;
 } else {
-if (varonce1011) {
-var1012 = varonce1011;
-} else {
-var1013 = ">=";
-var1014 = 2;
-var1015 = string__NativeString__to_s_with_length(var1013, var1014);
-var1012 = var1015;
-varonce1011 = var1012;
-}
-var1016 = ((short int (*)(val*, val*))(var_pname->class->vft[COLOR_kernel__Object___61d_61d]))(var_pname, var1012) /* == on <var_pname:String>*/;
-if (var1016){
-var1017 = 0;
-var1018 = ((val* (*)(val*, long))(var_arguments->class->vft[COLOR_abstract_collection__SequenceRead___91d_93d]))(var_arguments, var1017) /* [] on <var_arguments:Array[RuntimeVariable]>*/;
-if (varonce1019) {
-var1020 = varonce1019;
-} else {
-var1021 = " >= ";
-var1022 = 4;
-var1023 = string__NativeString__to_s_with_length(var1021, var1022);
-var1020 = var1023;
-varonce1019 = var1020;
-}
-var1024 = 1;
-var1025 = ((val* (*)(val*, long))(var_arguments->class->vft[COLOR_abstract_collection__SequenceRead___91d_93d]))(var_arguments, var1024) /* [] on <var_arguments:Array[RuntimeVariable]>*/;
-var1026 = NEW_array__Array(&type_array__Arraykernel__Object);
-{ /* var1026 = array_instance Array[Object] */
-var1027 = 3;
-var1028 = NEW_array__NativeArray(var1027, &type_array__NativeArraykernel__Object);
-((struct instance_array__NativeArray*)var1028)->values[0] = (val*) var1018;
-((struct instance_array__NativeArray*)var1028)->values[1] = (val*) var1020;
-((struct instance_array__NativeArray*)var1028)->values[2] = (val*) var1025;
-((void (*)(val*, val*, long))(var1026->class->vft[COLOR_array__Array__with_native]))(var1026, var1028, var1027) /* with_native on <var1026:Array[Object]>*/;
-CHECK_NEW_array__Array(var1026);
-}
-var1029 = ((val* (*)(val*))(var1026->class->vft[COLOR_string__Object__to_s]))(var1026) /* to_s on <var1026:Array[Object]>*/;
-if (var_ret == NULL) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "src/abstract_compiler.nit", 1520);
-exit(1);
-}
-var1030 = ((val* (*)(val*, val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__new_expr]))(var_v, var1029, var_ret) /* new_expr on <var_v:AbstractCompilerVisitor>*/;
-((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__ret]))(var_v, var1030) /* ret on <var_v:AbstractCompilerVisitor>*/;
-goto RET_LABEL;
+var42 = "Receiver is null";
+var43 = 16;
+var44 = string__NativeString__to_s_with_length(var42, var43);
+var41 = var44;
+varonce40 = var41;
+}
+{
+abstract_compiler__AbstractCompilerVisitor__add_abort(self, var41); /* Direct call abstract_compiler#AbstractCompilerVisitor#add_abort on <self:AbstractCompilerVisitor>*/
+}
+if (varonce45) {
+var46 = varonce45;
 } else {
-if (varonce1031) {
-var1032 = varonce1031;
-} else {
-var1033 = "to_i";
-var1034 = 4;
-var1035 = string__NativeString__to_s_with_length(var1033, var1034);
-var1032 = var1035;
-varonce1031 = var1032;
-}
-var1036 = ((short int (*)(val*, val*))(var_pname->class->vft[COLOR_kernel__Object___61d_61d]))(var_pname, var1032) /* == on <var_pname:String>*/;
-if (var1036){
-if (varonce1037) {
-var1038 = varonce1037;
-} else {
-var1039 = "(long)";
-var1040 = 6;
-var1041 = string__NativeString__to_s_with_length(var1039, var1040);
-var1038 = var1041;
-varonce1037 = var1038;
-}
-var1042 = 0;
-var1043 = ((val* (*)(val*, long))(var_arguments->class->vft[COLOR_abstract_collection__SequenceRead___91d_93d]))(var_arguments, var1042) /* [] on <var_arguments:Array[RuntimeVariable]>*/;
-var1044 = NEW_array__Array(&type_array__Arraykernel__Object);
-{ /* var1044 = array_instance Array[Object] */
-var1045 = 2;
-var1046 = NEW_array__NativeArray(var1045, &type_array__NativeArraykernel__Object);
-((struct instance_array__NativeArray*)var1046)->values[0] = (val*) var1038;
-((struct instance_array__NativeArray*)var1046)->values[1] = (val*) var1043;
-((void (*)(val*, val*, long))(var1044->class->vft[COLOR_array__Array__with_native]))(var1044, var1046, var1045) /* with_native on <var1044:Array[Object]>*/;
-CHECK_NEW_array__Array(var1044);
-}
-var1047 = ((val* (*)(val*))(var1044->class->vft[COLOR_string__Object__to_s]))(var1044) /* to_s on <var1044:Array[Object]>*/;
-if (var_ret == NULL) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "src/abstract_compiler.nit", 1523);
-exit(1);
-}
-var1048 = ((val* (*)(val*, val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__new_expr]))(var_v, var1047, var_ret) /* new_expr on <var_v:AbstractCompilerVisitor>*/;
-((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__ret]))(var_v, var1048) /* ret on <var_v:AbstractCompilerVisitor>*/;
-goto RET_LABEL;
+var47 = "}";
+var48 = 1;
+var49 = string__NativeString__to_s_with_length(var47, var48);
+var46 = var49;
+varonce45 = var46;
+}
+{
+abstract_compiler__AbstractCompilerVisitor__add(self, var46); /* Direct call abstract_compiler#AbstractCompilerVisitor#add on <self:AbstractCompilerVisitor>*/
+}
 } else {
 }
+RET_LABEL:;
+}
+/* method abstract_compiler#AbstractCompilerVisitor#check_recv_notnull for (self: Object, RuntimeVariable) */
+void VIRTUAL_abstract_compiler__AbstractCompilerVisitor__check_recv_notnull(val* self, val* p0) {
+abstract_compiler__AbstractCompilerVisitor__check_recv_notnull(self, p0); /* Direct call abstract_compiler#AbstractCompilerVisitor#check_recv_notnull on <self:Object(AbstractCompilerVisitor)>*/
+RET_LABEL:;
+}
+/* method abstract_compiler#AbstractCompilerVisitor#names for (self: AbstractCompilerVisitor): HashSet[String] */
+val* abstract_compiler__AbstractCompilerVisitor__names(val* self) {
+val* var /* : HashSet[String] */;
+val* var1 /* : HashSet[String] */;
+var1 = self->attrs[COLOR_abstract_compiler__AbstractCompilerVisitor___names].val; /* _names on <self:AbstractCompilerVisitor> */
+if (unlikely(var1 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _names");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 1265);
+show_backtrace(1);
+}
+var = var1;
+RET_LABEL:;
+return var;
+}
+/* method abstract_compiler#AbstractCompilerVisitor#names for (self: Object): HashSet[String] */
+val* VIRTUAL_abstract_compiler__AbstractCompilerVisitor__names(val* self) {
+val* var /* : HashSet[String] */;
+val* var1 /* : HashSet[String] */;
+val* var3 /* : HashSet[String] */;
+{ /* Inline abstract_compiler#AbstractCompilerVisitor#names (self) on <self:Object(AbstractCompilerVisitor)> */
+var3 = self->attrs[COLOR_abstract_compiler__AbstractCompilerVisitor___names].val; /* _names on <self:Object(AbstractCompilerVisitor)> */
+if (unlikely(var3 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _names");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 1265);
+show_backtrace(1);
+}
+var1 = var3;
+RET_LABEL2:(void)0;
+}
+var = var1;
+RET_LABEL:;
+return var;
 }
+/* method abstract_compiler#AbstractCompilerVisitor#last for (self: AbstractCompilerVisitor): Int */
+long abstract_compiler__AbstractCompilerVisitor__last(val* self) {
+long var /* : Int */;
+long var1 /* : Int */;
+var1 = self->attrs[COLOR_abstract_compiler__AbstractCompilerVisitor___last].l; /* _last on <self:AbstractCompilerVisitor> */
+var = var1;
+RET_LABEL:;
+return var;
 }
+/* method abstract_compiler#AbstractCompilerVisitor#last for (self: Object): Int */
+long VIRTUAL_abstract_compiler__AbstractCompilerVisitor__last(val* self) {
+long var /* : Int */;
+long var1 /* : Int */;
+long var3 /* : Int */;
+{ /* Inline abstract_compiler#AbstractCompilerVisitor#last (self) on <self:Object(AbstractCompilerVisitor)> */
+var3 = self->attrs[COLOR_abstract_compiler__AbstractCompilerVisitor___last].l; /* _last on <self:Object(AbstractCompilerVisitor)> */
+var1 = var3;
+RET_LABEL2:(void)0;
 }
+var = var1;
+RET_LABEL:;
+return var;
 }
+/* method abstract_compiler#AbstractCompilerVisitor#last= for (self: AbstractCompilerVisitor, Int) */
+void abstract_compiler__AbstractCompilerVisitor__last_61d(val* self, long p0) {
+self->attrs[COLOR_abstract_compiler__AbstractCompilerVisitor___last].l = p0; /* _last on <self:AbstractCompilerVisitor> */
+RET_LABEL:;
 }
+/* method abstract_compiler#AbstractCompilerVisitor#last= for (self: Object, Int) */
+void VIRTUAL_abstract_compiler__AbstractCompilerVisitor__last_61d(val* self, long p0) {
+{ /* Inline abstract_compiler#AbstractCompilerVisitor#last= (self,p0) on <self:Object(AbstractCompilerVisitor)> */
+self->attrs[COLOR_abstract_compiler__AbstractCompilerVisitor___last].l = p0; /* _last on <self:Object(AbstractCompilerVisitor)> */
+RET_LABEL1:(void)0;
 }
+RET_LABEL:;
 }
+/* method abstract_compiler#AbstractCompilerVisitor#get_name for (self: AbstractCompilerVisitor, String): String */
+val* abstract_compiler__AbstractCompilerVisitor__get_name(val* self, val* p0) {
+val* var /* : String */;
+val* var_s /* var s: String */;
+val* var1 /* : HashSet[String] */;
+val* var3 /* : HashSet[String] */;
+short int var4 /* : Bool */;
+short int var5 /* : Bool */;
+val* var6 /* : HashSet[String] */;
+val* var8 /* : HashSet[String] */;
+long var9 /* : Int */;
+long var11 /* : Int */;
+long var12 /* : Int */;
+long var13 /* : Int */;
+short int var15 /* : Bool */;
+int cltype;
+int idtype;
+const char* var_class_name;
+long var16 /* : Int */;
+long var_i /* var i: Int */;
+val* var17 /* : String */;
+val* var18 /* : String */;
+val* var_s2 /* var s2: String */;
+val* var19 /* : HashSet[String] */;
+val* var21 /* : HashSet[String] */;
+short int var22 /* : Bool */;
+short int var23 /* : Bool */;
+val* var25 /* : HashSet[String] */;
+val* var27 /* : HashSet[String] */;
+long var28 /* : Int */;
+long var29 /* : Int */;
+short int var31 /* : Bool */;
+int cltype32;
+int idtype33;
+const char* var_class_name34;
+long var35 /* : Int */;
+var_s = p0;
+{
+{ /* Inline abstract_compiler#AbstractCompilerVisitor#names (self) on <self:AbstractCompilerVisitor> */
+var3 = self->attrs[COLOR_abstract_compiler__AbstractCompilerVisitor___names].val; /* _names on <self:AbstractCompilerVisitor> */
+if (unlikely(var3 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _names");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 1265);
+show_backtrace(1);
 }
+var1 = var3;
+RET_LABEL2:(void)0;
 }
 }
+{
+var4 = hash_collection__HashSet__has(var1, var_s);
 }
+var5 = !var4;
+if (var5){
+{
+{ /* Inline abstract_compiler#AbstractCompilerVisitor#names (self) on <self:AbstractCompilerVisitor> */
+var8 = self->attrs[COLOR_abstract_compiler__AbstractCompilerVisitor___names].val; /* _names on <self:AbstractCompilerVisitor> */
+if (unlikely(var8 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _names");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 1265);
+show_backtrace(1);
 }
+var6 = var8;
+RET_LABEL7:(void)0;
 }
 }
+{
+hash_collection__HashSet__add(var6, var_s); /* Direct call hash_collection#HashSet#add on <var6:HashSet[String]>*/
 }
+var = var_s;
+goto RET_LABEL;
 } else {
-if (varonce1049) {
-var1050 = varonce1049;
-} else {
-var1051 = "NativeString";
-var1052 = 12;
-var1053 = string__NativeString__to_s_with_length(var1051, var1052);
-var1050 = var1053;
-varonce1049 = var1050;
 }
-var1054 = ((short int (*)(val*, val*))(var_cname->class->vft[COLOR_kernel__Object___61d_61d]))(var_cname, var1050) /* == on <var_cname:String>*/;
-if (var1054){
-if (varonce1055) {
-var1056 = varonce1055;
-} else {
-var1057 = "[]";
-var1058 = 2;
-var1059 = string__NativeString__to_s_with_length(var1057, var1058);
-var1056 = var1059;
-varonce1055 = var1056;
+{
+{ /* Inline abstract_compiler#AbstractCompilerVisitor#last (self) on <self:AbstractCompilerVisitor> */
+var11 = self->attrs[COLOR_abstract_compiler__AbstractCompilerVisitor___last].l; /* _last on <self:AbstractCompilerVisitor> */
+var9 = var11;
+RET_LABEL10:(void)0;
 }
-var1060 = ((short int (*)(val*, val*))(var_pname->class->vft[COLOR_kernel__Object___61d_61d]))(var_pname, var1056) /* == on <var_pname:String>*/;
-if (var1060){
-var1061 = 0;
-var1062 = ((val* (*)(val*, long))(var_arguments->class->vft[COLOR_abstract_collection__SequenceRead___91d_93d]))(var_arguments, var1061) /* [] on <var_arguments:Array[RuntimeVariable]>*/;
-if (varonce1063) {
-var1064 = varonce1063;
-} else {
-var1065 = "[";
-var1066 = 1;
-var1067 = string__NativeString__to_s_with_length(var1065, var1066);
-var1064 = var1067;
-varonce1063 = var1064;
 }
-var1068 = 1;
-var1069 = ((val* (*)(val*, long))(var_arguments->class->vft[COLOR_abstract_collection__SequenceRead___91d_93d]))(var_arguments, var1068) /* [] on <var_arguments:Array[RuntimeVariable]>*/;
-if (varonce1070) {
-var1071 = varonce1070;
-} else {
-var1072 = "]";
-var1073 = 1;
-var1074 = string__NativeString__to_s_with_length(var1072, var1073);
-var1071 = var1074;
-varonce1070 = var1071;
+var12 = 1;
+{
+{ /* Inline kernel#Int#+ (var9,var12) on <var9:Int> */
+/* Covariant cast for argument 0 (i) <var12:Int> isa OTHER */
+/* <var12:Int> isa OTHER */
+var15 = 1; /* easy <var12:Int> isa OTHER*/
+if (unlikely(!var15)) {
+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);
 }
-var1075 = NEW_array__Array(&type_array__Arraykernel__Object);
-{ /* var1075 = array_instance Array[Object] */
-var1076 = 4;
-var1077 = NEW_array__NativeArray(var1076, &type_array__NativeArraykernel__Object);
-((struct instance_array__NativeArray*)var1077)->values[0] = (val*) var1062;
-((struct instance_array__NativeArray*)var1077)->values[1] = (val*) var1064;
-((struct instance_array__NativeArray*)var1077)->values[2] = (val*) var1069;
-((struct instance_array__NativeArray*)var1077)->values[3] = (val*) var1071;
-((void (*)(val*, val*, long))(var1075->class->vft[COLOR_array__Array__with_native]))(var1075, var1077, var1076) /* with_native on <var1075:Array[Object]>*/;
-CHECK_NEW_array__Array(var1075);
+var16 = var9 + var12;
+var13 = var16;
+goto RET_LABEL14;
+RET_LABEL14:(void)0;
 }
-var1078 = ((val* (*)(val*))(var1075->class->vft[COLOR_string__Object__to_s]))(var1075) /* to_s on <var1075:Array[Object]>*/;
-if (var_ret == NULL) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "src/abstract_compiler.nit", 1528);
-exit(1);
 }
-var1079 = ((val* (*)(val*, val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__new_expr]))(var_v, var1078, var_ret) /* new_expr on <var_v:AbstractCompilerVisitor>*/;
-((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__ret]))(var_v, var1079) /* ret on <var_v:AbstractCompilerVisitor>*/;
-goto RET_LABEL;
-} else {
-if (varonce1080) {
-var1081 = varonce1080;
-} else {
-var1082 = "[]=";
-var1083 = 3;
-var1084 = string__NativeString__to_s_with_length(var1082, var1083);
-var1081 = var1084;
-varonce1080 = var1081;
-}
-var1085 = ((short int (*)(val*, val*))(var_pname->class->vft[COLOR_kernel__Object___61d_61d]))(var_pname, var1081) /* == on <var_pname:String>*/;
-if (var1085){
-var1086 = 0;
-var1087 = ((val* (*)(val*, long))(var_arguments->class->vft[COLOR_abstract_collection__SequenceRead___91d_93d]))(var_arguments, var1086) /* [] on <var_arguments:Array[RuntimeVariable]>*/;
-if (varonce1088) {
-var1089 = varonce1088;
-} else {
-var1090 = "[";
-var1091 = 1;
-var1092 = string__NativeString__to_s_with_length(var1090, var1091);
-var1089 = var1092;
-varonce1088 = var1089;
-}
-var1093 = 1;
-var1094 = ((val* (*)(val*, long))(var_arguments->class->vft[COLOR_abstract_collection__SequenceRead___91d_93d]))(var_arguments, var1093) /* [] on <var_arguments:Array[RuntimeVariable]>*/;
-if (varonce1095) {
-var1096 = varonce1095;
-} else {
-var1097 = "]=";
-var1098 = 2;
-var1099 = string__NativeString__to_s_with_length(var1097, var1098);
-var1096 = var1099;
-varonce1095 = var1096;
-}
-var1100 = 2;
-var1101 = ((val* (*)(val*, long))(var_arguments->class->vft[COLOR_abstract_collection__SequenceRead___91d_93d]))(var_arguments, var1100) /* [] on <var_arguments:Array[RuntimeVariable]>*/;
-if (varonce1102) {
-var1103 = varonce1102;
-} else {
-var1104 = ";";
-var1105 = 1;
-var1106 = string__NativeString__to_s_with_length(var1104, var1105);
-var1103 = var1106;
-varonce1102 = var1103;
-}
-var1107 = NEW_array__Array(&type_array__Arraykernel__Object);
-{ /* var1107 = array_instance Array[Object] */
-var1108 = 6;
-var1109 = NEW_array__NativeArray(var1108, &type_array__NativeArraykernel__Object);
-((struct instance_array__NativeArray*)var1109)->values[0] = (val*) var1087;
-((struct instance_array__NativeArray*)var1109)->values[1] = (val*) var1089;
-((struct instance_array__NativeArray*)var1109)->values[2] = (val*) var1094;
-((struct instance_array__NativeArray*)var1109)->values[3] = (val*) var1096;
-((struct instance_array__NativeArray*)var1109)->values[4] = (val*) var1101;
-((struct instance_array__NativeArray*)var1109)->values[5] = (val*) var1103;
-((void (*)(val*, val*, long))(var1107->class->vft[COLOR_array__Array__with_native]))(var1107, var1109, var1108) /* with_native on <var1107:Array[Object]>*/;
-CHECK_NEW_array__Array(var1107);
-}
-var1110 = ((val* (*)(val*))(var1107->class->vft[COLOR_string__Object__to_s]))(var1107) /* to_s on <var1107:Array[Object]>*/;
-((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(var_v, var1110) /* add on <var_v:AbstractCompilerVisitor>*/;
-goto RET_LABEL;
-} else {
-if (varonce1111) {
-var1112 = varonce1111;
-} else {
-var1113 = "copy_to";
-var1114 = 7;
-var1115 = string__NativeString__to_s_with_length(var1113, var1114);
-var1112 = var1115;
-varonce1111 = var1112;
-}
-var1116 = ((short int (*)(val*, val*))(var_pname->class->vft[COLOR_kernel__Object___61d_61d]))(var_pname, var1112) /* == on <var_pname:String>*/;
-if (var1116){
-if (varonce1117) {
-var1118 = varonce1117;
-} else {
-var1119 = "memcpy(";
-var1120 = 7;
-var1121 = string__NativeString__to_s_with_length(var1119, var1120);
-var1118 = var1121;
-varonce1117 = var1118;
-}
-var1122 = 1;
-var1123 = ((val* (*)(val*, long))(var_arguments->class->vft[COLOR_abstract_collection__SequenceRead___91d_93d]))(var_arguments, var1122) /* [] on <var_arguments:Array[RuntimeVariable]>*/;
-if (varonce1124) {
-var1125 = varonce1124;
-} else {
-var1126 = "+";
-var1127 = 1;
-var1128 = string__NativeString__to_s_with_length(var1126, var1127);
-var1125 = var1128;
-varonce1124 = var1125;
-}
-var1129 = 4;
-var1130 = ((val* (*)(val*, long))(var_arguments->class->vft[COLOR_abstract_collection__SequenceRead___91d_93d]))(var_arguments, var1129) /* [] on <var_arguments:Array[RuntimeVariable]>*/;
-if (varonce1131) {
-var1132 = varonce1131;
-} else {
-var1133 = ",";
-var1134 = 1;
-var1135 = string__NativeString__to_s_with_length(var1133, var1134);
-var1132 = var1135;
-varonce1131 = var1132;
-}
-var1136 = 0;
-var1137 = ((val* (*)(val*, long))(var_arguments->class->vft[COLOR_abstract_collection__SequenceRead___91d_93d]))(var_arguments, var1136) /* [] on <var_arguments:Array[RuntimeVariable]>*/;
-if (varonce1138) {
-var1139 = varonce1138;
-} else {
-var1140 = "+";
-var1141 = 1;
-var1142 = string__NativeString__to_s_with_length(var1140, var1141);
-var1139 = var1142;
-varonce1138 = var1139;
-}
-var1143 = 3;
-var1144 = ((val* (*)(val*, long))(var_arguments->class->vft[COLOR_abstract_collection__SequenceRead___91d_93d]))(var_arguments, var1143) /* [] on <var_arguments:Array[RuntimeVariable]>*/;
-if (varonce1145) {
-var1146 = varonce1145;
-} else {
-var1147 = ",";
-var1148 = 1;
-var1149 = string__NativeString__to_s_with_length(var1147, var1148);
-var1146 = var1149;
-varonce1145 = var1146;
-}
-var1150 = 2;
-var1151 = ((val* (*)(val*, long))(var_arguments->class->vft[COLOR_abstract_collection__SequenceRead___91d_93d]))(var_arguments, var1150) /* [] on <var_arguments:Array[RuntimeVariable]>*/;
-if (varonce1152) {
-var1153 = varonce1152;
-} else {
-var1154 = ");";
-var1155 = 2;
-var1156 = string__NativeString__to_s_with_length(var1154, var1155);
-var1153 = var1156;
-varonce1152 = var1153;
-}
-var1157 = NEW_array__Array(&type_array__Arraykernel__Object);
-{ /* var1157 = array_instance Array[Object] */
-var1158 = 11;
-var1159 = NEW_array__NativeArray(var1158, &type_array__NativeArraykernel__Object);
-((struct instance_array__NativeArray*)var1159)->values[0] = (val*) var1118;
-((struct instance_array__NativeArray*)var1159)->values[1] = (val*) var1123;
-((struct instance_array__NativeArray*)var1159)->values[2] = (val*) var1125;
-((struct instance_array__NativeArray*)var1159)->values[3] = (val*) var1130;
-((struct instance_array__NativeArray*)var1159)->values[4] = (val*) var1132;
-((struct instance_array__NativeArray*)var1159)->values[5] = (val*) var1137;
-((struct instance_array__NativeArray*)var1159)->values[6] = (val*) var1139;
-((struct instance_array__NativeArray*)var1159)->values[7] = (val*) var1144;
-((struct instance_array__NativeArray*)var1159)->values[8] = (val*) var1146;
-((struct instance_array__NativeArray*)var1159)->values[9] = (val*) var1151;
-((struct instance_array__NativeArray*)var1159)->values[10] = (val*) var1153;
-((void (*)(val*, val*, long))(var1157->class->vft[COLOR_array__Array__with_native]))(var1157, var1159, var1158) /* with_native on <var1157:Array[Object]>*/;
-CHECK_NEW_array__Array(var1157);
-}
-var1160 = ((val* (*)(val*))(var1157->class->vft[COLOR_string__Object__to_s]))(var1157) /* to_s on <var1157:Array[Object]>*/;
-((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(var_v, var1160) /* add on <var_v:AbstractCompilerVisitor>*/;
-goto RET_LABEL;
-} else {
-if (varonce1161) {
-var1162 = varonce1161;
-} else {
-var1163 = "atoi";
-var1164 = 4;
-var1165 = string__NativeString__to_s_with_length(var1163, var1164);
-var1162 = var1165;
-varonce1161 = var1162;
-}
-var1166 = ((short int (*)(val*, val*))(var_pname->class->vft[COLOR_kernel__Object___61d_61d]))(var_pname, var1162) /* == on <var_pname:String>*/;
-if (var1166){
-if (varonce1167) {
-var1168 = varonce1167;
-} else {
-var1169 = "atoi(";
-var1170 = 5;
-var1171 = string__NativeString__to_s_with_length(var1169, var1170);
-var1168 = var1171;
-varonce1167 = var1168;
-}
-var1172 = 0;
-var1173 = ((val* (*)(val*, long))(var_arguments->class->vft[COLOR_abstract_collection__SequenceRead___91d_93d]))(var_arguments, var1172) /* [] on <var_arguments:Array[RuntimeVariable]>*/;
-if (varonce1174) {
-var1175 = varonce1174;
-} else {
-var1176 = ");";
-var1177 = 2;
-var1178 = string__NativeString__to_s_with_length(var1176, var1177);
-var1175 = var1178;
-varonce1174 = var1175;
-}
-var1179 = NEW_array__Array(&type_array__Arraykernel__Object);
-{ /* var1179 = array_instance Array[Object] */
-var1180 = 3;
-var1181 = NEW_array__NativeArray(var1180, &type_array__NativeArraykernel__Object);
-((struct instance_array__NativeArray*)var1181)->values[0] = (val*) var1168;
-((struct instance_array__NativeArray*)var1181)->values[1] = (val*) var1173;
-((struct instance_array__NativeArray*)var1181)->values[2] = (val*) var1175;
-((void (*)(val*, val*, long))(var1179->class->vft[COLOR_array__Array__with_native]))(var1179, var1181, var1180) /* with_native on <var1179:Array[Object]>*/;
-CHECK_NEW_array__Array(var1179);
-}
-var1182 = ((val* (*)(val*))(var1179->class->vft[COLOR_string__Object__to_s]))(var1179) /* to_s on <var1179:Array[Object]>*/;
-if (var_ret == NULL) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "src/abstract_compiler.nit", 1537);
-exit(1);
-}
-var1183 = ((val* (*)(val*, val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__new_expr]))(var_v, var1182, var_ret) /* new_expr on <var_v:AbstractCompilerVisitor>*/;
-((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__ret]))(var_v, var1183) /* ret on <var_v:AbstractCompilerVisitor>*/;
-goto RET_LABEL;
-} else {
+var_i = var13;
+for(;;) {
+{
+var17 = string__Int__to_s(var_i);
 }
+{
+var18 = string__FlatString___43d(var_s, var17);
 }
+var_s2 = var18;
+{
+{ /* Inline abstract_compiler#AbstractCompilerVisitor#names (self) on <self:AbstractCompilerVisitor> */
+var21 = self->attrs[COLOR_abstract_compiler__AbstractCompilerVisitor___names].val; /* _names on <self:AbstractCompilerVisitor> */
+if (unlikely(var21 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _names");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 1265);
+show_backtrace(1);
 }
+var19 = var21;
+RET_LABEL20:(void)0;
 }
-} else {
-if (varonce1184) {
-var1185 = varonce1184;
-} else {
-var1186 = "NativeArray";
-var1187 = 11;
-var1188 = string__NativeString__to_s_with_length(var1186, var1187);
-var1185 = var1188;
-varonce1184 = var1185;
 }
-var1189 = ((short int (*)(val*, val*))(var_cname->class->vft[COLOR_kernel__Object___61d_61d]))(var_cname, var1185) /* == on <var_cname:String>*/;
-if (var1189){
-((void (*)(val*, val*, val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__native_array_def]))(var_v, var_pname, var_ret, var_arguments) /* native_array_def on <var_v:AbstractCompilerVisitor>*/;
-goto RET_LABEL;
-} else {
+{
+var22 = hash_collection__HashSet__has(var19, var_s2);
 }
+var23 = !var22;
+if (var23){
+{
+{ /* Inline abstract_compiler#AbstractCompilerVisitor#last= (self,var_i) on <self:AbstractCompilerVisitor> */
+self->attrs[COLOR_abstract_compiler__AbstractCompilerVisitor___last].l = var_i; /* _last on <self:AbstractCompilerVisitor> */
+RET_LABEL24:(void)0;
 }
 }
+{
+{ /* Inline abstract_compiler#AbstractCompilerVisitor#names (self) on <self:AbstractCompilerVisitor> */
+var27 = self->attrs[COLOR_abstract_compiler__AbstractCompilerVisitor___names].val; /* _names on <self:AbstractCompilerVisitor> */
+if (unlikely(var27 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _names");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 1265);
+show_backtrace(1);
 }
+var25 = var27;
+RET_LABEL26:(void)0;
 }
 }
-if (varonce1190) {
-var1191 = varonce1190;
-} else {
-var1192 = "exit";
-var1193 = 4;
-var1194 = string__NativeString__to_s_with_length(var1192, var1193);
-var1191 = var1194;
-varonce1190 = var1191;
+{
+hash_collection__HashSet__add(var25, var_s2); /* Direct call hash_collection#HashSet#add on <var25:HashSet[String]>*/
 }
-var1195 = ((short int (*)(val*, val*))(var_pname->class->vft[COLOR_kernel__Object___61d_61d]))(var_pname, var1191) /* == on <var_pname:String>*/;
-if (var1195){
-if (varonce1196) {
-var1197 = varonce1196;
+var = var_s2;
+goto RET_LABEL;
 } else {
-var1198 = "exit(";
-var1199 = 5;
-var1200 = string__NativeString__to_s_with_length(var1198, var1199);
-var1197 = var1200;
-varonce1196 = var1197;
 }
-var1201 = 1;
-var1202 = ((val* (*)(val*, long))(var_arguments->class->vft[COLOR_abstract_collection__SequenceRead___91d_93d]))(var_arguments, var1201) /* [] on <var_arguments:Array[RuntimeVariable]>*/;
-if (varonce1203) {
-var1204 = varonce1203;
-} else {
-var1205 = ");";
-var1206 = 2;
-var1207 = string__NativeString__to_s_with_length(var1205, var1206);
-var1204 = var1207;
-varonce1203 = var1204;
+var28 = 1;
+{
+{ /* Inline kernel#Int#+ (var_i,var28) on <var_i:Int> */
+/* Covariant cast for argument 0 (i) <var28:Int> isa OTHER */
+/* <var28:Int> isa OTHER */
+var31 = 1; /* easy <var28:Int> isa OTHER*/
+if (unlikely(!var31)) {
+var_class_name34 = type_kernel__Int.name;
+PRINT_ERROR("Runtime error: Cast failed. Expected `%s`, got `%s`", "OTHER", var_class_name34);
+PRINT_ERROR(" (%s:%d)\n", "../lib/standard/kernel.nit", 374);
+show_backtrace(1);
+}
+var35 = var_i + var28;
+var29 = var35;
+goto RET_LABEL30;
+RET_LABEL30:(void)0;
 }
-var1208 = NEW_array__Array(&type_array__Arraykernel__Object);
-{ /* var1208 = array_instance Array[Object] */
-var1209 = 3;
-var1210 = NEW_array__NativeArray(var1209, &type_array__NativeArraykernel__Object);
-((struct instance_array__NativeArray*)var1210)->values[0] = (val*) var1197;
-((struct instance_array__NativeArray*)var1210)->values[1] = (val*) var1202;
-((struct instance_array__NativeArray*)var1210)->values[2] = (val*) var1204;
-((void (*)(val*, val*, long))(var1208->class->vft[COLOR_array__Array__with_native]))(var1208, var1210, var1209) /* with_native on <var1208:Array[Object]>*/;
-CHECK_NEW_array__Array(var1208);
 }
-var1211 = ((val* (*)(val*))(var1208->class->vft[COLOR_string__Object__to_s]))(var1208) /* to_s on <var1208:Array[Object]>*/;
-((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(var_v, var1211) /* add on <var_v:AbstractCompilerVisitor>*/;
-goto RET_LABEL;
-} else {
-if (varonce1212) {
-var1213 = varonce1212;
-} else {
-var1214 = "sys";
-var1215 = 3;
-var1216 = string__NativeString__to_s_with_length(var1214, var1215);
-var1213 = var1216;
-varonce1212 = var1213;
+var_i = var29;
 }
-var1217 = ((short int (*)(val*, val*))(var_pname->class->vft[COLOR_kernel__Object___61d_61d]))(var_pname, var1213) /* == on <var_pname:String>*/;
-if (var1217){
-if (varonce1218) {
-var1219 = varonce1218;
-} else {
-var1220 = "glob_sys";
-var1221 = 8;
-var1222 = string__NativeString__to_s_with_length(var1220, var1221);
-var1219 = var1222;
-varonce1218 = var1219;
+RET_LABEL:;
+return var;
 }
-if (var_ret == NULL) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "src/abstract_compiler.nit", 1548);
-exit(1);
+/* method abstract_compiler#AbstractCompilerVisitor#get_name for (self: Object, String): String */
+val* VIRTUAL_abstract_compiler__AbstractCompilerVisitor__get_name(val* self, val* p0) {
+val* var /* : String */;
+val* var1 /* : String */;
+var1 = abstract_compiler__AbstractCompilerVisitor__get_name(self, p0);
+var = var1;
+RET_LABEL:;
+return var;
 }
-var1223 = ((val* (*)(val*, val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__new_expr]))(var_v, var1219, var_ret) /* new_expr on <var_v:AbstractCompilerVisitor>*/;
-((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__ret]))(var_v, var1223) /* ret on <var_v:AbstractCompilerVisitor>*/;
-goto RET_LABEL;
-} else {
-if (varonce1224) {
-var1225 = varonce1224;
-} else {
-var1226 = "calloc_string";
-var1227 = 13;
-var1228 = string__NativeString__to_s_with_length(var1226, var1227);
-var1225 = var1228;
-varonce1224 = var1225;
-}
-var1229 = ((short int (*)(val*, val*))(var_pname->class->vft[COLOR_kernel__Object___61d_61d]))(var_pname, var1225) /* == on <var_pname:String>*/;
-if (var1229){
-if (varonce1230) {
-var1231 = varonce1230;
-} else {
-var1232 = "(char*)nit_alloc(";
-var1233 = 17;
-var1234 = string__NativeString__to_s_with_length(var1232, var1233);
-var1231 = var1234;
-varonce1230 = var1231;
-}
-var1235 = 1;
-var1236 = ((val* (*)(val*, long))(var_arguments->class->vft[COLOR_abstract_collection__SequenceRead___91d_93d]))(var_arguments, var1235) /* [] on <var_arguments:Array[RuntimeVariable]>*/;
-if (varonce1237) {
-var1238 = varonce1237;
-} else {
-var1239 = ")";
-var1240 = 1;
-var1241 = string__NativeString__to_s_with_length(var1239, var1240);
-var1238 = var1241;
-varonce1237 = var1238;
-}
-var1242 = NEW_array__Array(&type_array__Arraykernel__Object);
-{ /* var1242 = array_instance Array[Object] */
-var1243 = 3;
-var1244 = NEW_array__NativeArray(var1243, &type_array__NativeArraykernel__Object);
-((struct instance_array__NativeArray*)var1244)->values[0] = (val*) var1231;
-((struct instance_array__NativeArray*)var1244)->values[1] = (val*) var1236;
-((struct instance_array__NativeArray*)var1244)->values[2] = (val*) var1238;
-((void (*)(val*, val*, long))(var1242->class->vft[COLOR_array__Array__with_native]))(var1242, var1244, var1243) /* with_native on <var1242:Array[Object]>*/;
-CHECK_NEW_array__Array(var1242);
-}
-var1245 = ((val* (*)(val*))(var1242->class->vft[COLOR_string__Object__to_s]))(var1242) /* to_s on <var1242:Array[Object]>*/;
-if (var_ret == NULL) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "src/abstract_compiler.nit", 1551);
-exit(1);
-}
-var1246 = ((val* (*)(val*, val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__new_expr]))(var_v, var1245, var_ret) /* new_expr on <var_v:AbstractCompilerVisitor>*/;
-((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__ret]))(var_v, var1246) /* ret on <var_v:AbstractCompilerVisitor>*/;
-goto RET_LABEL;
-} else {
-if (varonce1247) {
-var1248 = varonce1247;
+/* method abstract_compiler#AbstractCompilerVisitor#escapemark_name for (self: AbstractCompilerVisitor, nullable EscapeMark): String */
+val* abstract_compiler__AbstractCompilerVisitor__escapemark_name(val* self, val* p0) {
+val* var /* : String */;
+val* var_e /* var e: nullable EscapeMark */;
+val* var1 /* : null */;
+short int var2 /* : Bool */;
+short int var3 /* : Bool */;
+val* var_other /* var other: nullable Object */;
+short int var5 /* : Bool */;
+short int var6 /* : Bool */;
+short int var7 /* : Bool */;
+val* var8 /* : HashMap[EscapeMark, String] */;
+val* var10 /* : HashMap[EscapeMark, String] */;
+short int var11 /* : Bool */;
+val* var12 /* : HashMap[EscapeMark, String] */;
+val* var14 /* : HashMap[EscapeMark, String] */;
+val* var15 /* : nullable Object */;
+val* var16 /* : nullable String */;
+val* var18 /* : nullable String */;
+val* var_name /* var name: nullable String */;
+val* var19 /* : null */;
+short int var20 /* : Bool */;
+short int var21 /* : Bool */;
+static val* varonce;
+val* var22 /* : String */;
+char* var23 /* : NativeString */;
+long var24 /* : Int */;
+val* var25 /* : FlatString */;
+val* var26 /* : String */;
+val* var27 /* : HashMap[EscapeMark, String] */;
+val* var29 /* : HashMap[EscapeMark, String] */;
+var_e = p0;
+var1 = NULL;
+if (var_e == NULL) {
+var2 = 0; /* is null */
 } else {
-var1249 = "calloc_array";
-var1250 = 12;
-var1251 = string__NativeString__to_s_with_length(var1249, var1250);
-var1248 = var1251;
-varonce1247 = var1248;
+var2 = 1; /* arg is null and recv is not */
 }
-var1252 = ((short int (*)(val*, val*))(var_pname->class->vft[COLOR_kernel__Object___61d_61d]))(var_pname, var1248) /* == on <var_pname:String>*/;
-if (var1252){
-if (var_ret == NULL) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "src/abstract_compiler.nit", 1554);
-exit(1);
+if (0) {
+{ /* Inline kernel#Object#!= (var_e,var1) on <var_e:nullable EscapeMark> */
+var_other = var1;
+{
+var6 = ((short int (*)(val*, val*))(var_e->class->vft[COLOR_kernel__Object___61d_61d]))(var_e, var_other) /* == on <var_e:nullable EscapeMark(EscapeMark)>*/;
+var5 = var6;
 }
-((void (*)(val*, val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__calloc_array]))(var_v, var_ret, var_arguments) /* calloc_array on <var_v:AbstractCompilerVisitor>*/;
-goto RET_LABEL;
-} else {
-if (varonce1253) {
-var1254 = varonce1253;
-} else {
-var1255 = "object_id";
-var1256 = 9;
-var1257 = string__NativeString__to_s_with_length(var1255, var1256);
-var1254 = var1257;
-varonce1253 = var1254;
-}
-var1258 = ((short int (*)(val*, val*))(var_pname->class->vft[COLOR_kernel__Object___61d_61d]))(var_pname, var1254) /* == on <var_pname:String>*/;
-if (var1258){
-if (varonce1259) {
-var1260 = varonce1259;
-} else {
-var1261 = "(long)";
-var1262 = 6;
-var1263 = string__NativeString__to_s_with_length(var1261, var1262);
-var1260 = var1263;
-varonce1259 = var1260;
-}
-var1264 = ((val* (*)(val*))(var_arguments->class->vft[COLOR_abstract_collection__Collection__first]))(var_arguments) /* first on <var_arguments:Array[RuntimeVariable]>*/;
-var1265 = NEW_array__Array(&type_array__Arraykernel__Object);
-{ /* var1265 = array_instance Array[Object] */
-var1266 = 2;
-var1267 = NEW_array__NativeArray(var1266, &type_array__NativeArraykernel__Object);
-((struct instance_array__NativeArray*)var1267)->values[0] = (val*) var1260;
-((struct instance_array__NativeArray*)var1267)->values[1] = (val*) var1264;
-((void (*)(val*, val*, long))(var1265->class->vft[COLOR_array__Array__with_native]))(var1265, var1267, var1266) /* with_native on <var1265:Array[Object]>*/;
-CHECK_NEW_array__Array(var1265);
-}
-var1268 = ((val* (*)(val*))(var1265->class->vft[COLOR_string__Object__to_s]))(var1265) /* to_s on <var1265:Array[Object]>*/;
-if (var_ret == NULL) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "src/abstract_compiler.nit", 1557);
-exit(1);
-}
-var1269 = ((val* (*)(val*, val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__new_expr]))(var_v, var1268, var_ret) /* new_expr on <var_v:AbstractCompilerVisitor>*/;
-((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__ret]))(var_v, var1269) /* ret on <var_v:AbstractCompilerVisitor>*/;
-goto RET_LABEL;
-} else {
-if (varonce1270) {
-var1271 = varonce1270;
-} else {
-var1272 = "is_same_type";
-var1273 = 12;
-var1274 = string__NativeString__to_s_with_length(var1272, var1273);
-var1271 = var1274;
-varonce1270 = var1271;
-}
-var1275 = ((short int (*)(val*, val*))(var_pname->class->vft[COLOR_kernel__Object___61d_61d]))(var_pname, var1271) /* == on <var_pname:String>*/;
-if (var1275){
-var1276 = 0;
-var1277 = ((val* (*)(val*, long))(var_arguments->class->vft[COLOR_abstract_collection__SequenceRead___91d_93d]))(var_arguments, var1276) /* [] on <var_arguments:Array[RuntimeVariable]>*/;
-var1278 = 1;
-var1279 = ((val* (*)(val*, long))(var_arguments->class->vft[COLOR_abstract_collection__SequenceRead___91d_93d]))(var_arguments, var1278) /* [] on <var_arguments:Array[RuntimeVariable]>*/;
-var1280 = ((val* (*)(val*, val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__is_same_type_test]))(var_v, var1277, var1279) /* is_same_type_test on <var_v:AbstractCompilerVisitor>*/;
-((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__ret]))(var_v, var1280) /* ret on <var_v:AbstractCompilerVisitor>*/;
-goto RET_LABEL;
-} else {
-if (varonce1281) {
-var1282 = varonce1281;
-} else {
-var1283 = "output_class_name";
-var1284 = 17;
-var1285 = string__NativeString__to_s_with_length(var1283, var1284);
-var1282 = var1285;
-varonce1281 = var1282;
-}
-var1286 = ((short int (*)(val*, val*))(var_pname->class->vft[COLOR_kernel__Object___61d_61d]))(var_pname, var1282) /* == on <var_pname:String>*/;
-if (var1286){
-var1287 = ((val* (*)(val*))(var_arguments->class->vft[COLOR_abstract_collection__Collection__first]))(var_arguments) /* first on <var_arguments:Array[RuntimeVariable]>*/;
-var1288 = ((val* (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__class_name_string]))(var_v, var1287) /* class_name_string on <var_v:AbstractCompilerVisitor>*/;
-var_nat = var1288;
-if (varonce1289) {
-var1290 = varonce1289;
-} else {
-var1291 = "printf(\"%s\\n\", ";
-var1292 = 15;
-var1293 = string__NativeString__to_s_with_length(var1291, var1292);
-var1290 = var1293;
-varonce1289 = var1290;
-}
-if (varonce1294) {
-var1295 = varonce1294;
-} else {
-var1296 = ");";
-var1297 = 2;
-var1298 = string__NativeString__to_s_with_length(var1296, var1297);
-var1295 = var1298;
-varonce1294 = var1295;
-}
-var1299 = NEW_array__Array(&type_array__Arraykernel__Object);
-{ /* var1299 = array_instance Array[Object] */
-var1300 = 3;
-var1301 = NEW_array__NativeArray(var1300, &type_array__NativeArraykernel__Object);
-((struct instance_array__NativeArray*)var1301)->values[0] = (val*) var1290;
-((struct instance_array__NativeArray*)var1301)->values[1] = (val*) var_nat;
-((struct instance_array__NativeArray*)var1301)->values[2] = (val*) var1295;
-((void (*)(val*, val*, long))(var1299->class->vft[COLOR_array__Array__with_native]))(var1299, var1301, var1300) /* with_native on <var1299:Array[Object]>*/;
-CHECK_NEW_array__Array(var1299);
-}
-var1302 = ((val* (*)(val*))(var1299->class->vft[COLOR_string__Object__to_s]))(var1299) /* to_s on <var1299:Array[Object]>*/;
-((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(var_v, var1302) /* add on <var_v:AbstractCompilerVisitor>*/;
-goto RET_LABEL;
-} else {
-if (varonce1303) {
-var1304 = varonce1303;
-} else {
-var1305 = "native_class_name";
-var1306 = 17;
-var1307 = string__NativeString__to_s_with_length(var1305, var1306);
-var1304 = var1307;
-varonce1303 = var1304;
-}
-var1308 = ((short int (*)(val*, val*))(var_pname->class->vft[COLOR_kernel__Object___61d_61d]))(var_pname, var1304) /* == on <var_pname:String>*/;
-if (var1308){
-var1309 = ((val* (*)(val*))(var_arguments->class->vft[COLOR_abstract_collection__Collection__first]))(var_arguments) /* first on <var_arguments:Array[RuntimeVariable]>*/;
-var1310 = ((val* (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__class_name_string]))(var_v, var1309) /* class_name_string on <var_v:AbstractCompilerVisitor>*/;
-var_nat1311 = var1310;
-if (varonce1312) {
-var1313 = varonce1312;
-} else {
-var1314 = "(char*)";
-var1315 = 7;
-var1316 = string__NativeString__to_s_with_length(var1314, var1315);
-var1313 = var1316;
-varonce1312 = var1313;
-}
-var1317 = NEW_array__Array(&type_array__Arraykernel__Object);
-{ /* var1317 = array_instance Array[Object] */
-var1318 = 2;
-var1319 = NEW_array__NativeArray(var1318, &type_array__NativeArraykernel__Object);
-((struct instance_array__NativeArray*)var1319)->values[0] = (val*) var1313;
-((struct instance_array__NativeArray*)var1319)->values[1] = (val*) var_nat1311;
-((void (*)(val*, val*, long))(var1317->class->vft[COLOR_array__Array__with_native]))(var1317, var1319, var1318) /* with_native on <var1317:Array[Object]>*/;
-CHECK_NEW_array__Array(var1317);
-}
-var1320 = ((val* (*)(val*))(var1317->class->vft[COLOR_string__Object__to_s]))(var1317) /* to_s on <var1317:Array[Object]>*/;
-if (var_ret == NULL) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "src/abstract_compiler.nit", 1568);
-exit(1);
-}
-var1321 = ((val* (*)(val*, val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__new_expr]))(var_v, var1320, var_ret) /* new_expr on <var_v:AbstractCompilerVisitor>*/;
-((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__ret]))(var_v, var1321) /* ret on <var_v:AbstractCompilerVisitor>*/;
-goto RET_LABEL;
-} else {
-if (varonce1322) {
-var1323 = varonce1322;
-} else {
-var1324 = "force_garbage_collection";
-var1325 = 24;
-var1326 = string__NativeString__to_s_with_length(var1324, var1325);
-var1323 = var1326;
-varonce1322 = var1323;
+var7 = !var5;
+var3 = var7;
+goto RET_LABEL4;
+RET_LABEL4:(void)0;
 }
-var1327 = ((short int (*)(val*, val*))(var_pname->class->vft[COLOR_kernel__Object___61d_61d]))(var_pname, var1323) /* == on <var_pname:String>*/;
-if (var1327){
-if (varonce1328) {
-var1329 = varonce1328;
-} else {
-var1330 = "nit_gcollect();";
-var1331 = 15;
-var1332 = string__NativeString__to_s_with_length(var1330, var1331);
-var1329 = var1332;
-varonce1328 = var1329;
+var2 = var3;
 }
-((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(var_v, var1329) /* add on <var_v:AbstractCompilerVisitor>*/;
-goto RET_LABEL;
-} else {
-if (varonce1333) {
-var1334 = varonce1333;
-} else {
-var1335 = "native_argc";
-var1336 = 11;
-var1337 = string__NativeString__to_s_with_length(var1335, var1336);
-var1334 = var1337;
-varonce1333 = var1334;
+if (unlikely(!var2)) {
+PRINT_ERROR("Runtime error: %s", "Assert failed");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 1290);
+show_backtrace(1);
 }
-var1338 = ((short int (*)(val*, val*))(var_pname->class->vft[COLOR_kernel__Object___61d_61d]))(var_pname, var1334) /* == on <var_pname:String>*/;
-if (var1338){
-if (varonce1339) {
-var1340 = varonce1339;
-} else {
-var1341 = "glob_argc";
-var1342 = 9;
-var1343 = string__NativeString__to_s_with_length(var1341, var1342);
-var1340 = var1343;
-varonce1339 = var1340;
+{
+{ /* Inline abstract_compiler#AbstractCompilerVisitor#escapemark_names (self) on <self:AbstractCompilerVisitor> */
+var10 = self->attrs[COLOR_abstract_compiler__AbstractCompilerVisitor___escapemark_names].val; /* _escapemark_names on <self:AbstractCompilerVisitor> */
+if (unlikely(var10 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _escapemark_names");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 1307);
+show_backtrace(1);
 }
-if (var_ret == NULL) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "src/abstract_compiler.nit", 1574);
-exit(1);
+var8 = var10;
+RET_LABEL9:(void)0;
 }
-var1344 = ((val* (*)(val*, val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__new_expr]))(var_v, var1340, var_ret) /* new_expr on <var_v:AbstractCompilerVisitor>*/;
-((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__ret]))(var_v, var1344) /* ret on <var_v:AbstractCompilerVisitor>*/;
-goto RET_LABEL;
-} else {
-if (varonce1345) {
-var1346 = varonce1345;
-} else {
-var1347 = "native_argv";
-var1348 = 11;
-var1349 = string__NativeString__to_s_with_length(var1347, var1348);
-var1346 = var1349;
-varonce1345 = var1346;
-}
-var1350 = ((short int (*)(val*, val*))(var_pname->class->vft[COLOR_kernel__Object___61d_61d]))(var_pname, var1346) /* == on <var_pname:String>*/;
-if (var1350){
-if (varonce1351) {
-var1352 = varonce1351;
-} else {
-var1353 = "glob_argv[";
-var1354 = 10;
-var1355 = string__NativeString__to_s_with_length(var1353, var1354);
-var1352 = var1355;
-varonce1351 = var1352;
-}
-var1356 = 1;
-var1357 = ((val* (*)(val*, long))(var_arguments->class->vft[COLOR_abstract_collection__SequenceRead___91d_93d]))(var_arguments, var1356) /* [] on <var_arguments:Array[RuntimeVariable]>*/;
-if (varonce1358) {
-var1359 = varonce1358;
-} else {
-var1360 = "]";
-var1361 = 1;
-var1362 = string__NativeString__to_s_with_length(var1360, var1361);
-var1359 = var1362;
-varonce1358 = var1359;
-}
-var1363 = NEW_array__Array(&type_array__Arraykernel__Object);
-{ /* var1363 = array_instance Array[Object] */
-var1364 = 3;
-var1365 = NEW_array__NativeArray(var1364, &type_array__NativeArraykernel__Object);
-((struct instance_array__NativeArray*)var1365)->values[0] = (val*) var1352;
-((struct instance_array__NativeArray*)var1365)->values[1] = (val*) var1357;
-((struct instance_array__NativeArray*)var1365)->values[2] = (val*) var1359;
-((void (*)(val*, val*, long))(var1363->class->vft[COLOR_array__Array__with_native]))(var1363, var1365, var1364) /* with_native on <var1363:Array[Object]>*/;
-CHECK_NEW_array__Array(var1363);
-}
-var1366 = ((val* (*)(val*))(var1363->class->vft[COLOR_string__Object__to_s]))(var1363) /* to_s on <var1363:Array[Object]>*/;
-if (var_ret == NULL) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "src/abstract_compiler.nit", 1577);
-exit(1);
-}
-var1367 = ((val* (*)(val*, val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__new_expr]))(var_v, var1366, var_ret) /* new_expr on <var_v:AbstractCompilerVisitor>*/;
-((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__ret]))(var_v, var1367) /* ret on <var_v:AbstractCompilerVisitor>*/;
-goto RET_LABEL;
-} else {
 }
+{
+var11 = abstract_collection__MapRead__has_key(var8, var_e);
 }
+if (var11){
+{
+{ /* Inline abstract_compiler#AbstractCompilerVisitor#escapemark_names (self) on <self:AbstractCompilerVisitor> */
+var14 = self->attrs[COLOR_abstract_compiler__AbstractCompilerVisitor___escapemark_names].val; /* _escapemark_names on <self:AbstractCompilerVisitor> */
+if (unlikely(var14 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _escapemark_names");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 1307);
+show_backtrace(1);
 }
+var12 = var14;
+RET_LABEL13:(void)0;
 }
 }
+{
+var15 = hash_collection__HashMap___91d_93d(var12, var_e);
 }
+var = var15;
+goto RET_LABEL;
+} else {
 }
+{
+{ /* Inline scope#EscapeMark#name (var_e) on <var_e:nullable EscapeMark(EscapeMark)> */
+var18 = var_e->attrs[COLOR_scope__EscapeMark___name].val; /* _name on <var_e:nullable EscapeMark(EscapeMark)> */
+var16 = var18;
+RET_LABEL17:(void)0;
 }
 }
+var_name = var16;
+var19 = NULL;
+if (var_name == NULL) {
+var20 = 1; /* is null */
+} else {
+var20 = 0; /* arg is null but recv is not */
 }
+if (0) {
+var21 = string__FlatString___61d_61d(var_name, var19);
+var20 = var21;
 }
-if (varonce1368) {
-var1369 = varonce1368;
+if (var20){
+if (varonce) {
+var22 = varonce;
 } else {
-var1370 = "printf(\"NOT YET IMPLEMENTED ";
-var1371 = 28;
-var1372 = string__NativeString__to_s_with_length(var1370, var1371);
-var1369 = var1372;
-varonce1368 = var1369;
+var23 = "label";
+var24 = 5;
+var25 = string__NativeString__to_s_with_length(var23, var24);
+var22 = var25;
+varonce = var22;
 }
-var1373 = ((val* (*)(val*))(self->class->vft[COLOR_string__Object__class_name]))(self) /* class_name on <self:AInternMethPropdef>*/;
-if (varonce1374) {
-var1375 = varonce1374;
+var_name = var22;
 } else {
-var1376 = ":";
-var1377 = 1;
-var1378 = string__NativeString__to_s_with_length(var1376, var1377);
-var1375 = var1378;
-varonce1374 = var1375;
 }
-if (varonce1379) {
-var1380 = varonce1379;
-} else {
-var1381 = " at ";
-var1382 = 4;
-var1383 = string__NativeString__to_s_with_length(var1381, var1382);
-var1380 = var1383;
-varonce1379 = var1380;
+{
+var26 = abstract_compiler__AbstractCompilerVisitor__get_name(self, var_name);
 }
-var1384 = ((val* (*)(val*))(self->class->vft[COLOR_parser_nodes__ANode__location]))(self) /* location on <self:AInternMethPropdef>*/;
-var1385 = ((val* (*)(val*))(var1384->class->vft[COLOR_string__Object__to_s]))(var1384) /* to_s on <var1384:Location>*/;
-if (varonce1386) {
-var1387 = varonce1386;
-} else {
-var1388 = "\\n\");";
-var1389 = 5;
-var1390 = string__NativeString__to_s_with_length(var1388, var1389);
-var1387 = var1390;
-varonce1386 = var1387;
+var_name = var26;
+{
+{ /* Inline abstract_compiler#AbstractCompilerVisitor#escapemark_names (self) on <self:AbstractCompilerVisitor> */
+var29 = self->attrs[COLOR_abstract_compiler__AbstractCompilerVisitor___escapemark_names].val; /* _escapemark_names on <self:AbstractCompilerVisitor> */
+if (unlikely(var29 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _escapemark_names");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 1307);
+show_backtrace(1);
 }
-var1391 = NEW_array__Array(&type_array__Arraykernel__Object);
-{ /* var1391 = array_instance Array[Object] */
-var1392 = 7;
-var1393 = NEW_array__NativeArray(var1392, &type_array__NativeArraykernel__Object);
-((struct instance_array__NativeArray*)var1393)->values[0] = (val*) var1369;
-((struct instance_array__NativeArray*)var1393)->values[1] = (val*) var1373;
-((struct instance_array__NativeArray*)var1393)->values[2] = (val*) var1375;
-((struct instance_array__NativeArray*)var1393)->values[3] = (val*) var_mpropdef;
-((struct instance_array__NativeArray*)var1393)->values[4] = (val*) var1380;
-((struct instance_array__NativeArray*)var1393)->values[5] = (val*) var1385;
-((struct instance_array__NativeArray*)var1393)->values[6] = (val*) var1387;
-((void (*)(val*, val*, long))(var1391->class->vft[COLOR_array__Array__with_native]))(var1391, var1393, var1392) /* with_native on <var1391:Array[Object]>*/;
-CHECK_NEW_array__Array(var1391);
+var27 = var29;
+RET_LABEL28:(void)0;
 }
-var1394 = ((val* (*)(val*))(var1391->class->vft[COLOR_string__Object__to_s]))(var1391) /* to_s on <var1391:Array[Object]>*/;
-((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(var_v, var1394) /* add on <var_v:AbstractCompilerVisitor>*/;
-if (varonce1395) {
-var1396 = varonce1395;
-} else {
-var1397 = "Not implemented ";
-var1398 = 16;
-var1399 = string__NativeString__to_s_with_length(var1397, var1398);
-var1396 = var1399;
-varonce1395 = var1396;
 }
-var1400 = NEW_array__Array(&type_array__Arraykernel__Object);
-{ /* var1400 = array_instance Array[Object] */
-var1401 = 2;
-var1402 = NEW_array__NativeArray(var1401, &type_array__NativeArraykernel__Object);
-((struct instance_array__NativeArray*)var1402)->values[0] = (val*) var1396;
-((struct instance_array__NativeArray*)var1402)->values[1] = (val*) var_mpropdef;
-((void (*)(val*, val*, long))(var1400->class->vft[COLOR_array__Array__with_native]))(var1400, var1402, var1401) /* with_native on <var1400:Array[Object]>*/;
-CHECK_NEW_array__Array(var1400);
+{
+hash_collection__HashMap___91d_93d_61d(var27, var_e, var_name); /* Direct call hash_collection#HashMap#[]= on <var27:HashMap[EscapeMark, String]>*/
 }
-var1403 = ((val* (*)(val*))(var1400->class->vft[COLOR_string__Object__to_s]))(var1400) /* to_s on <var1400:Array[Object]>*/;
-((void (*)(val*, val*))(self->class->vft[COLOR_parser_nodes__ANode__debug]))(self, var1403) /* debug on <self:AInternMethPropdef>*/;
+var = var_name;
+goto RET_LABEL;
 RET_LABEL:;
+return var;
 }
-/* method abstract_compiler#AInternMethPropdef#compile_to_c for (self: Object, AbstractCompilerVisitor, MMethodDef, Array[RuntimeVariable]) */
-void VIRTUAL_abstract_compiler__AInternMethPropdef__compile_to_c(val* self, val* p0, val* p1, val* p2) {
-abstract_compiler__AInternMethPropdef__compile_to_c(self, p0, p1, p2);
+/* method abstract_compiler#AbstractCompilerVisitor#escapemark_name for (self: Object, nullable EscapeMark): String */
+val* VIRTUAL_abstract_compiler__AbstractCompilerVisitor__escapemark_name(val* self, val* p0) {
+val* var /* : String */;
+val* var1 /* : String */;
+var1 = abstract_compiler__AbstractCompilerVisitor__escapemark_name(self, p0);
+var = var1;
 RET_LABEL:;
+return var;
 }
-/* method abstract_compiler#AExternMethPropdef#compile_to_c for (self: AExternMethPropdef, AbstractCompilerVisitor, MMethodDef, Array[RuntimeVariable]) */
-void abstract_compiler__AExternMethPropdef__compile_to_c(val* self, val* p0, val* p1, val* p2) {
-val* var_v /* var v: AbstractCompilerVisitor */;
-val* var_mpropdef /* var mpropdef: MMethodDef */;
-val* var_arguments /* var arguments: Array[RuntimeVariable] */;
-val* var /* : nullable TString */;
-val* var_nextern /* var nextern: nullable TString */;
-val* var1 /* : null */;
+/* method abstract_compiler#AbstractCompilerVisitor#add_escape_label for (self: AbstractCompilerVisitor, nullable EscapeMark) */
+void abstract_compiler__AbstractCompilerVisitor__add_escape_label(val* self, val* p0) {
+val* var_e /* var e: nullable EscapeMark */;
+val* var /* : null */;
+short int var1 /* : Bool */;
 short int var2 /* : Bool */;
+val* var_other /* var other: nullable Object */;
+short int var4 /* : Bool */;
+short int var6 /* : Bool */;
+val* var7 /* : Array[AEscapeExpr] */;
+val* var9 /* : Array[AEscapeExpr] */;
+short int var10 /* : Bool */;
 static val* varonce;
-val* var3 /* : String */;
-char* var4 /* : NativeString */;
-long var5 /* : Int */;
-val* var6 /* : String */;
-static val* varonce7;
-val* var8 /* : String */;
-char* var9 /* : NativeString */;
-long var10 /* : Int */;
 val* var11 /* : String */;
-val* var12 /* : Location */;
-val* var13 /* : String */;
-static val* varonce14;
+char* var12 /* : NativeString */;
+long var13 /* : Int */;
+val* var14 /* : FlatString */;
 val* var15 /* : String */;
-char* var16 /* : NativeString */;
-long var17 /* : Int */;
-val* var18 /* : String */;
-val* var19 /* : Array[Object] */;
-long var20 /* : Int */;
-val* var21 /* : NativeArray[Object] */;
-val* var22 /* : String */;
-static val* varonce23;
+static val* varonce16;
+val* var17 /* : String */;
+char* var18 /* : NativeString */;
+long var19 /* : Int */;
+val* var20 /* : FlatString */;
+val* var21 /* : Array[Object] */;
+long var22 /* : Int */;
+val* var23 /* : NativeArray[Object] */;
 val* var24 /* : String */;
-char* var25 /* : NativeString */;
-long var26 /* : Int */;
-val* var27 /* : String */;
-val* var28 /* : String */;
-long var29 /* : Int */;
-val* var30 /* : String */;
-long var31 /* : Int */;
-long var32 /* : Int */;
-long var33 /* : Int */;
-long var35 /* : Int */;
-val* var36 /* : String */;
-val* var_externname /* var externname: nullable Object */;
-val* var37 /* : Location */;
-val* var38 /* : nullable SourceFile */;
-val* var39 /* : null */;
-short int var40 /* : Bool */;
-val* var41 /* : Location */;
-val* var42 /* : nullable SourceFile */;
-val* var43 /* : String */;
-val* var_file /* var file: String */;
-val* var44 /* : null */;
-val* var_res /* var res: nullable RuntimeVariable */;
-val* var45 /* : nullable MSignature */;
-val* var46 /* : nullable MType */;
-val* var_ret /* var ret: nullable MType */;
-val* var47 /* : null */;
-short int var48 /* : Bool */;
-val* var49 /* : nullable Object */;
-val* var50 /* : MType */;
-val* var51 /* : RuntimeVariable */;
-val* var52 /* : null */;
-short int var53 /* : Bool */;
-static val* varonce54;
-val* var55 /* : String */;
-char* var56 /* : NativeString */;
-long var57 /* : Int */;
-val* var58 /* : String */;
-static val* varonce59;
-val* var60 /* : String */;
-char* var61 /* : NativeString */;
-long var62 /* : Int */;
-val* var63 /* : String */;
-val* var64 /* : String */;
-static val* varonce65;
-val* var66 /* : String */;
-char* var67 /* : NativeString */;
-long var68 /* : Int */;
-val* var69 /* : String */;
-val* var70 /* : Array[Object] */;
-long var71 /* : Int */;
-val* var72 /* : NativeArray[Object] */;
-val* var73 /* : String */;
-static val* varonce74;
-val* var75 /* : String */;
-char* var76 /* : NativeString */;
-long var77 /* : Int */;
-val* var78 /* : String */;
-static val* varonce79;
-val* var80 /* : String */;
-char* var81 /* : NativeString */;
-long var82 /* : Int */;
-val* var83 /* : String */;
-static val* varonce84;
-val* var85 /* : String */;
-char* var86 /* : NativeString */;
-long var87 /* : Int */;
-val* var88 /* : String */;
-val* var89 /* : String */;
-static val* varonce90;
-val* var91 /* : String */;
-char* var92 /* : NativeString */;
-long var93 /* : Int */;
-val* var94 /* : String */;
-val* var95 /* : Array[Object] */;
-long var96 /* : Int */;
-val* var97 /* : NativeArray[Object] */;
-val* var98 /* : String */;
-var_v = p0;
-var_mpropdef = p1;
-var_arguments = p2;
-var = ((val* (*)(val*))(self->class->vft[COLOR_parser_nodes__AExternPropdef__n_extern]))(self) /* n_extern on <self:AExternMethPropdef>*/;
-var_nextern = var;
-var1 = NULL;
-if (var_nextern == NULL) {
-var2 = 1; /* is null */
+var_e = p0;
+var = NULL;
+if (var_e == NULL) {
+var1 = 1; /* is null */
 } else {
-var2 = 0; /* arg is null but recv is not */
+var1 = 0; /* arg is null but recv is not */
 }
-if (var2){
-if (varonce) {
-var3 = varonce;
-} else {
-var4 = "fprintf(stderr, \"NOT YET IMPLEMENTED nitni for ";
-var5 = 47;
-var6 = string__NativeString__to_s_with_length(var4, var5);
-var3 = var6;
-varonce = var3;
+if (0) {
+{ /* Inline kernel#Object#== (var_e,var) on <var_e:nullable EscapeMark> */
+var_other = var;
+{
+{ /* Inline kernel#Object#is_same_instance (var_e,var_other) on <var_e:nullable EscapeMark(EscapeMark)> */
+var6 = var_e == var_other;
+var4 = var6;
+goto RET_LABEL5;
+RET_LABEL5:(void)0;
 }
-if (varonce7) {
-var8 = varonce7;
-} else {
-var9 = " at ";
-var10 = 4;
-var11 = string__NativeString__to_s_with_length(var9, var10);
-var8 = var11;
-varonce7 = var8;
 }
-var12 = ((val* (*)(val*))(self->class->vft[COLOR_parser_nodes__ANode__location]))(self) /* location on <self:AExternMethPropdef>*/;
-var13 = ((val* (*)(val*))(var12->class->vft[COLOR_string__Object__to_s]))(var12) /* to_s on <var12:Location>*/;
-if (varonce14) {
-var15 = varonce14;
-} else {
-var16 = "\\n\");";
-var17 = 5;
-var18 = string__NativeString__to_s_with_length(var16, var17);
-var15 = var18;
-varonce14 = var15;
+var2 = var4;
+goto RET_LABEL3;
+RET_LABEL3:(void)0;
 }
-var19 = NEW_array__Array(&type_array__Arraykernel__Object);
-{ /* var19 = array_instance Array[Object] */
-var20 = 5;
-var21 = NEW_array__NativeArray(var20, &type_array__NativeArraykernel__Object);
-((struct instance_array__NativeArray*)var21)->values[0] = (val*) var3;
-((struct instance_array__NativeArray*)var21)->values[1] = (val*) var_mpropdef;
-((struct instance_array__NativeArray*)var21)->values[2] = (val*) var8;
-((struct instance_array__NativeArray*)var21)->values[3] = (val*) var13;
-((struct instance_array__NativeArray*)var21)->values[4] = (val*) var15;
-((void (*)(val*, val*, long))(var19->class->vft[COLOR_array__Array__with_native]))(var19, var21, var20) /* with_native on <var19:Array[Object]>*/;
-CHECK_NEW_array__Array(var19);
-}
-var22 = ((val* (*)(val*))(var19->class->vft[COLOR_string__Object__to_s]))(var19) /* to_s on <var19:Array[Object]>*/;
-((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(var_v, var22) /* add on <var_v:AbstractCompilerVisitor>*/;
-if (varonce23) {
-var24 = varonce23;
-} else {
-var25 = "exit(1);";
-var26 = 8;
-var27 = string__NativeString__to_s_with_length(var25, var26);
-var24 = var27;
-varonce23 = var24;
-}
-((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(var_v, var24) /* add on <var_v:AbstractCompilerVisitor>*/;
+var1 = var2;
+}
+if (var1){
 goto RET_LABEL;
 } else {
 }
-var28 = ((val* (*)(val*))(var_nextern->class->vft[COLOR_parser_nodes__Token__text]))(var_nextern) /* text on <var_nextern:nullable TString(TString)>*/;
-var29 = 1;
-var30 = ((val* (*)(val*))(var_nextern->class->vft[COLOR_parser_nodes__Token__text]))(var_nextern) /* text on <var_nextern:nullable TString(TString)>*/;
-var31 = ((long (*)(val*))(var30->class->vft[COLOR_abstract_collection__Collection__length]))(var30) /* length on <var30:String>*/;
-var32 = 2;
-{ /* Inline kernel#Int#- (var31,var32) */
-var35 = var31 - var32;
-var33 = var35;
-goto RET_LABEL34;
-RET_LABEL34:(void)0;
+{
+{ /* Inline scope#EscapeMark#escapes (var_e) on <var_e:nullable EscapeMark(EscapeMark)> */
+var9 = var_e->attrs[COLOR_scope__EscapeMark___escapes].val; /* _escapes on <var_e:nullable EscapeMark(EscapeMark)> */
+if (unlikely(var9 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _escapes");
+PRINT_ERROR(" (%s:%d)\n", "semantize/scope.nit", 57);
+show_backtrace(1);
 }
-var36 = ((val* (*)(val*, long, long))(var28->class->vft[COLOR_string__AbstractString__substring]))(var28, var29, var33) /* substring on <var28:String>*/;
-var_externname = var36;
-var37 = ((val* (*)(val*))(self->class->vft[COLOR_parser_nodes__ANode__location]))(self) /* location on <self:AExternMethPropdef>*/;
-var38 = ((val* (*)(val*))(var37->class->vft[COLOR_location__Location__file]))(var37) /* file on <var37:Location>*/;
-var39 = NULL;
-if (var38 == NULL) {
-var40 = 0; /* is null */
-} else {
-var40 = 1; /* arg is null and recv is not */
+var7 = var9;
+RET_LABEL8:(void)0;
 }
-if (var40){
-var41 = ((val* (*)(val*))(self->class->vft[COLOR_parser_nodes__ANode__location]))(self) /* location on <self:AExternMethPropdef>*/;
-var42 = ((val* (*)(val*))(var41->class->vft[COLOR_location__Location__file]))(var41) /* file on <var41:Location>*/;
-if (var42 == NULL) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Reciever is null", "src/abstract_compiler.nit", 1597);
-exit(1);
-} else {
-var43 = ((val* (*)(val*))(var42->class->vft[COLOR_location__SourceFile__filename]))(var42) /* filename on <var42:nullable SourceFile>*/;
 }
-var_file = var43;
-((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add_extern]))(var_v, var_file) /* add_extern on <var_v:AbstractCompilerVisitor>*/;
-} else {
+{
+var10 = array__AbstractArrayRead__is_empty(var7);
 }
-var44 = NULL;
-var_res = var44;
-var45 = ((val* (*)(val*))(var_mpropdef->class->vft[COLOR_model__MMethodDef__msignature]))(var_mpropdef) /* msignature on <var_mpropdef:MMethodDef>*/;
-if (var45 == NULL) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Reciever is null", "src/abstract_compiler.nit", 1601);
-exit(1);
+if (var10){
+goto RET_LABEL;
 } else {
-var46 = ((val* (*)(val*))(var45->class->vft[COLOR_model__MSignature__return_mtype]))(var45) /* return_mtype on <var45:nullable MSignature>*/;
 }
-var_ret = var46;
-var47 = NULL;
-if (var_ret == NULL) {
-var48 = 0; /* is null */
+if (varonce) {
+var11 = varonce;
 } else {
-var48 = 1; /* arg is null and recv is not */
+var12 = "BREAK_";
+var13 = 6;
+var14 = string__NativeString__to_s_with_length(var12, var13);
+var11 = var14;
+varonce = var11;
 }
-if (var48){
-var49 = ((val* (*)(val*))(var_arguments->class->vft[COLOR_abstract_collection__Collection__first]))(var_arguments) /* first on <var_arguments:Array[RuntimeVariable]>*/;
-var50 = ((val* (*)(val*, val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__resolve_for]))(var_v, var_ret, var49) /* resolve_for on <var_v:AbstractCompilerVisitor>*/;
-var_ret = var50;
-var51 = ((val* (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__new_var]))(var_v, var_ret) /* new_var on <var_v:AbstractCompilerVisitor>*/;
-var_res = var51;
-} else {
+{
+var15 = abstract_compiler__AbstractCompilerVisitor__escapemark_name(self, var_e);
 }
-((void (*)(val*, val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__adapt_signature]))(var_v, var_mpropdef, var_arguments) /* adapt_signature on <var_v:AbstractCompilerVisitor>*/;
-var52 = NULL;
-if (var_res == NULL) {
-var53 = 1; /* is null */
+if (varonce16) {
+var17 = varonce16;
 } else {
-var53 = 0; /* arg is null but recv is not */
+var18 = ": (void)0;";
+var19 = 10;
+var20 = string__NativeString__to_s_with_length(var18, var19);
+var17 = var20;
+varonce16 = var17;
 }
-if (var53){
-if (varonce54) {
-var55 = varonce54;
-} else {
-var56 = "(";
-var57 = 1;
-var58 = string__NativeString__to_s_with_length(var56, var57);
-var55 = var58;
-varonce54 = var55;
+var21 = NEW_array__Array(&type_array__Arraykernel__Object);
+{ /* var21 = array_instance Array[Object] */
+var22 = 3;
+var23 = NEW_array__NativeArray(var22, &type_array__NativeArraykernel__Object);
+((struct instance_array__NativeArray*)var23)->values[0] = (val*) var11;
+((struct instance_array__NativeArray*)var23)->values[1] = (val*) var15;
+((struct instance_array__NativeArray*)var23)->values[2] = (val*) var17;
+{
+((void (*)(val*, val*, long))(var21->class->vft[COLOR_array__Array__with_native]))(var21, var23, var22) /* with_native on <var21:Array[Object]>*/;
 }
-if (varonce59) {
-var60 = varonce59;
-} else {
-var61 = ", ";
-var62 = 2;
-var63 = string__NativeString__to_s_with_length(var61, var62);
-var60 = var63;
-varonce59 = var60;
-}
-var64 = ((val* (*)(val*, val*))(var_arguments->class->vft[COLOR_string__Collection__join]))(var_arguments, var60) /* join on <var_arguments:Array[RuntimeVariable]>*/;
-if (varonce65) {
-var66 = varonce65;
-} else {
-var67 = ");";
-var68 = 2;
-var69 = string__NativeString__to_s_with_length(var67, var68);
-var66 = var69;
-varonce65 = var66;
-}
-var70 = NEW_array__Array(&type_array__Arraykernel__Object);
-{ /* var70 = array_instance Array[Object] */
-var71 = 4;
-var72 = NEW_array__NativeArray(var71, &type_array__NativeArraykernel__Object);
-((struct instance_array__NativeArray*)var72)->values[0] = (val*) var_externname;
-((struct instance_array__NativeArray*)var72)->values[1] = (val*) var55;
-((struct instance_array__NativeArray*)var72)->values[2] = (val*) var64;
-((struct instance_array__NativeArray*)var72)->values[3] = (val*) var66;
-((void (*)(val*, val*, long))(var70->class->vft[COLOR_array__Array__with_native]))(var70, var72, var71) /* with_native on <var70:Array[Object]>*/;
-CHECK_NEW_array__Array(var70);
-}
-var73 = ((val* (*)(val*))(var70->class->vft[COLOR_string__Object__to_s]))(var70) /* to_s on <var70:Array[Object]>*/;
-((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(var_v, var73) /* add on <var_v:AbstractCompilerVisitor>*/;
-} else {
-if (varonce74) {
-var75 = varonce74;
-} else {
-var76 = " = ";
-var77 = 3;
-var78 = string__NativeString__to_s_with_length(var76, var77);
-var75 = var78;
-varonce74 = var75;
 }
-if (varonce79) {
-var80 = varonce79;
-} else {
-var81 = "(";
-var82 = 1;
-var83 = string__NativeString__to_s_with_length(var81, var82);
-var80 = var83;
-varonce79 = var80;
+{
+var24 = ((val* (*)(val*))(var21->class->vft[COLOR_string__Object__to_s]))(var21) /* to_s on <var21:Array[Object]>*/;
+}
+{
+abstract_compiler__AbstractCompilerVisitor__add(self, var24); /* Direct call abstract_compiler#AbstractCompilerVisitor#add on <self:AbstractCompilerVisitor>*/
+}
+RET_LABEL:;
+}
+/* method abstract_compiler#AbstractCompilerVisitor#add_escape_label for (self: Object, nullable EscapeMark) */
+void VIRTUAL_abstract_compiler__AbstractCompilerVisitor__add_escape_label(val* self, val* p0) {
+abstract_compiler__AbstractCompilerVisitor__add_escape_label(self, p0); /* Direct call abstract_compiler#AbstractCompilerVisitor#add_escape_label on <self:Object(AbstractCompilerVisitor)>*/
+RET_LABEL:;
+}
+/* method abstract_compiler#AbstractCompilerVisitor#escapemark_names for (self: AbstractCompilerVisitor): HashMap[EscapeMark, String] */
+val* abstract_compiler__AbstractCompilerVisitor__escapemark_names(val* self) {
+val* var /* : HashMap[EscapeMark, String] */;
+val* var1 /* : HashMap[EscapeMark, String] */;
+var1 = self->attrs[COLOR_abstract_compiler__AbstractCompilerVisitor___escapemark_names].val; /* _escapemark_names on <self:AbstractCompilerVisitor> */
+if (unlikely(var1 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _escapemark_names");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 1307);
+show_backtrace(1);
+}
+var = var1;
+RET_LABEL:;
+return var;
+}
+/* method abstract_compiler#AbstractCompilerVisitor#escapemark_names for (self: Object): HashMap[EscapeMark, String] */
+val* VIRTUAL_abstract_compiler__AbstractCompilerVisitor__escapemark_names(val* self) {
+val* var /* : HashMap[EscapeMark, String] */;
+val* var1 /* : HashMap[EscapeMark, String] */;
+val* var3 /* : HashMap[EscapeMark, String] */;
+{ /* Inline abstract_compiler#AbstractCompilerVisitor#escapemark_names (self) on <self:Object(AbstractCompilerVisitor)> */
+var3 = self->attrs[COLOR_abstract_compiler__AbstractCompilerVisitor___escapemark_names].val; /* _escapemark_names on <self:Object(AbstractCompilerVisitor)> */
+if (unlikely(var3 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _escapemark_names");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 1307);
+show_backtrace(1);
+}
+var1 = var3;
+RET_LABEL2:(void)0;
+}
+var = var1;
+RET_LABEL:;
+return var;
 }
-if (varonce84) {
-var85 = varonce84;
-} else {
-var86 = ", ";
-var87 = 2;
-var88 = string__NativeString__to_s_with_length(var86, var87);
-var85 = var88;
-varonce84 = var85;
-}
-var89 = ((val* (*)(val*, val*))(var_arguments->class->vft[COLOR_string__Collection__join]))(var_arguments, var85) /* join on <var_arguments:Array[RuntimeVariable]>*/;
-if (varonce90) {
-var91 = varonce90;
-} else {
-var92 = ");";
-var93 = 2;
-var94 = string__NativeString__to_s_with_length(var92, var93);
-var91 = var94;
-varonce90 = var91;
-}
-var95 = NEW_array__Array(&type_array__Arraykernel__Object);
-{ /* var95 = array_instance Array[Object] */
-var96 = 6;
-var97 = NEW_array__NativeArray(var96, &type_array__NativeArraykernel__Object);
-((struct instance_array__NativeArray*)var97)->values[0] = (val*) var_res;
-((struct instance_array__NativeArray*)var97)->values[1] = (val*) var75;
-((struct instance_array__NativeArray*)var97)->values[2] = (val*) var_externname;
-((struct instance_array__NativeArray*)var97)->values[3] = (val*) var80;
-((struct instance_array__NativeArray*)var97)->values[4] = (val*) var89;
-((struct instance_array__NativeArray*)var97)->values[5] = (val*) var91;
-((void (*)(val*, val*, long))(var95->class->vft[COLOR_array__Array__with_native]))(var95, var97, var96) /* with_native on <var95:Array[Object]>*/;
-CHECK_NEW_array__Array(var95);
-}
-var98 = ((val* (*)(val*))(var95->class->vft[COLOR_string__Object__to_s]))(var95) /* to_s on <var95:Array[Object]>*/;
-((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(var_v, var98) /* add on <var_v:AbstractCompilerVisitor>*/;
-((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__ret]))(var_v, var_res) /* ret on <var_v:AbstractCompilerVisitor>*/;
+/* method abstract_compiler#AbstractCompilerVisitor#variables for (self: AbstractCompilerVisitor): HashMap[Variable, RuntimeVariable] */
+val* abstract_compiler__AbstractCompilerVisitor__variables(val* self) {
+val* var /* : HashMap[Variable, RuntimeVariable] */;
+val* var1 /* : HashMap[Variable, RuntimeVariable] */;
+var1 = self->attrs[COLOR_abstract_compiler__AbstractCompilerVisitor___variables].val; /* _variables on <self:AbstractCompilerVisitor> */
+if (unlikely(var1 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _variables");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 1315);
+show_backtrace(1);
 }
+var = var1;
 RET_LABEL:;
+return var;
 }
-/* method abstract_compiler#AExternMethPropdef#compile_to_c for (self: Object, AbstractCompilerVisitor, MMethodDef, Array[RuntimeVariable]) */
-void VIRTUAL_abstract_compiler__AExternMethPropdef__compile_to_c(val* self, val* p0, val* p1, val* p2) {
-abstract_compiler__AExternMethPropdef__compile_to_c(self, p0, p1, p2);
+/* method abstract_compiler#AbstractCompilerVisitor#variables for (self: Object): HashMap[Variable, RuntimeVariable] */
+val* VIRTUAL_abstract_compiler__AbstractCompilerVisitor__variables(val* self) {
+val* var /* : HashMap[Variable, RuntimeVariable] */;
+val* var1 /* : HashMap[Variable, RuntimeVariable] */;
+val* var3 /* : HashMap[Variable, RuntimeVariable] */;
+{ /* Inline abstract_compiler#AbstractCompilerVisitor#variables (self) on <self:Object(AbstractCompilerVisitor)> */
+var3 = self->attrs[COLOR_abstract_compiler__AbstractCompilerVisitor___variables].val; /* _variables on <self:Object(AbstractCompilerVisitor)> */
+if (unlikely(var3 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _variables");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 1315);
+show_backtrace(1);
+}
+var1 = var3;
+RET_LABEL2:(void)0;
+}
+var = var1;
 RET_LABEL:;
+return var;
 }
-/* method abstract_compiler#AExternInitPropdef#compile_to_c for (self: AExternInitPropdef, AbstractCompilerVisitor, MMethodDef, Array[RuntimeVariable]) */
-void abstract_compiler__AExternInitPropdef__compile_to_c(val* self, val* p0, val* p1, val* p2) {
-val* var_v /* var v: AbstractCompilerVisitor */;
-val* var_mpropdef /* var mpropdef: MMethodDef */;
-val* var_arguments /* var arguments: Array[RuntimeVariable] */;
-val* var /* : nullable TString */;
-val* var_nextern /* var nextern: nullable TString */;
-val* var1 /* : null */;
-short int var2 /* : Bool */;
+/* method abstract_compiler#AbstractCompilerVisitor#variable for (self: AbstractCompilerVisitor, Variable): RuntimeVariable */
+val* abstract_compiler__AbstractCompilerVisitor__variable(val* self, val* p0) {
+val* var /* : RuntimeVariable */;
+val* var_variable /* var variable: Variable */;
+val* var1 /* : HashMap[Variable, RuntimeVariable] */;
+val* var3 /* : HashMap[Variable, RuntimeVariable] */;
+short int var4 /* : Bool */;
+val* var5 /* : HashMap[Variable, RuntimeVariable] */;
+val* var7 /* : HashMap[Variable, RuntimeVariable] */;
+val* var8 /* : nullable Object */;
 static val* varonce;
-val* var3 /* : String */;
-char* var4 /* : NativeString */;
-long var5 /* : Int */;
-val* var6 /* : String */;
-static val* varonce7;
-val* var8 /* : String */;
-char* var9 /* : NativeString */;
-long var10 /* : Int */;
-val* var11 /* : String */;
-val* var12 /* : Location */;
+val* var9 /* : String */;
+char* var10 /* : NativeString */;
+long var11 /* : Int */;
+val* var12 /* : FlatString */;
 val* var13 /* : String */;
-static val* varonce14;
 val* var15 /* : String */;
-char* var16 /* : NativeString */;
+val* var16 /* : Array[Object] */;
 long var17 /* : Int */;
-val* var18 /* : String */;
-val* var19 /* : Array[Object] */;
-long var20 /* : Int */;
-val* var21 /* : NativeArray[Object] */;
-val* var22 /* : String */;
-static val* varonce23;
-val* var24 /* : String */;
-char* var25 /* : NativeString */;
-long var26 /* : Int */;
-val* var27 /* : String */;
+val* var18 /* : NativeArray[Object] */;
+val* var19 /* : String */;
+val* var20 /* : String */;
+val* var_name /* var name: String */;
+val* var21 /* : nullable MType */;
+val* var23 /* : nullable MType */;
+val* var_mtype /* var mtype: MType */;
+val* var24 /* : MType */;
+val* var25 /* : RuntimeVariable */;
+val* var_res /* var res: RuntimeVariable */;
+val* var26 /* : String */;
+static val* varonce27;
 val* var28 /* : String */;
-long var29 /* : Int */;
-val* var30 /* : String */;
-long var31 /* : Int */;
-long var32 /* : Int */;
-long var33 /* : Int */;
+char* var29 /* : NativeString */;
+long var30 /* : Int */;
+val* var31 /* : FlatString */;
+static val* varonce32;
+val* var33 /* : String */;
+char* var34 /* : NativeString */;
 long var35 /* : Int */;
-val* var36 /* : String */;
-val* var_externname /* var externname: nullable Object */;
-val* var37 /* : Location */;
-val* var38 /* : nullable SourceFile */;
-val* var39 /* : null */;
-short int var40 /* : Bool */;
-val* var41 /* : Location */;
-val* var42 /* : nullable SourceFile */;
+val* var36 /* : FlatString */;
+static val* varonce37;
+val* var38 /* : String */;
+char* var39 /* : NativeString */;
+long var40 /* : Int */;
+val* var41 /* : FlatString */;
+static val* varonce42;
 val* var43 /* : String */;
-val* var_file /* var file: String */;
-val* var44 /* : nullable Object */;
-val* var45 /* : MType */;
-val* var_ret /* var ret: MType */;
-val* var46 /* : RuntimeVariable */;
-val* var_res /* var res: RuntimeVariable */;
-val* var47 /* : nullable Object */;
-static val* varonce48;
-val* var49 /* : String */;
-char* var50 /* : NativeString */;
-long var51 /* : Int */;
-val* var52 /* : String */;
-static val* varonce53;
-val* var54 /* : String */;
-char* var55 /* : NativeString */;
-long var56 /* : Int */;
-val* var57 /* : String */;
-static val* varonce58;
-val* var59 /* : String */;
-char* var60 /* : NativeString */;
-long var61 /* : Int */;
-val* var62 /* : String */;
-val* var63 /* : String */;
-static val* varonce64;
-val* var65 /* : String */;
-char* var66 /* : NativeString */;
-long var67 /* : Int */;
-val* var68 /* : String */;
-val* var69 /* : Array[Object] */;
-long var70 /* : Int */;
-val* var71 /* : NativeArray[Object] */;
-val* var72 /* : String */;
-var_v = p0;
-var_mpropdef = p1;
-var_arguments = p2;
-var = ((val* (*)(val*))(self->class->vft[COLOR_parser_nodes__AExternPropdef__n_extern]))(self) /* n_extern on <self:AExternInitPropdef>*/;
-var_nextern = var;
-var1 = NULL;
-if (var_nextern == NULL) {
-var2 = 1; /* is null */
-} else {
-var2 = 0; /* arg is null but recv is not */
+char* var44 /* : NativeString */;
+long var45 /* : Int */;
+val* var46 /* : FlatString */;
+val* var47 /* : Array[Object] */;
+long var48 /* : Int */;
+val* var49 /* : NativeArray[Object] */;
+val* var50 /* : String */;
+val* var51 /* : HashMap[Variable, RuntimeVariable] */;
+val* var53 /* : HashMap[Variable, RuntimeVariable] */;
+var_variable = p0;
+{
+{ /* Inline abstract_compiler#AbstractCompilerVisitor#variables (self) on <self:AbstractCompilerVisitor> */
+var3 = self->attrs[COLOR_abstract_compiler__AbstractCompilerVisitor___variables].val; /* _variables on <self:AbstractCompilerVisitor> */
+if (unlikely(var3 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _variables");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 1315);
+show_backtrace(1);
+}
+var1 = var3;
+RET_LABEL2:(void)0;
+}
+}
+{
+var4 = abstract_collection__MapRead__has_key(var1, var_variable);
 }
-if (var2){
-if (varonce) {
-var3 = varonce;
-} else {
-var4 = "printf(\"NOT YET IMPLEMENTED nitni for ";
-var5 = 38;
-var6 = string__NativeString__to_s_with_length(var4, var5);
-var3 = var6;
-varonce = var3;
+if (var4){
+{
+{ /* Inline abstract_compiler#AbstractCompilerVisitor#variables (self) on <self:AbstractCompilerVisitor> */
+var7 = self->attrs[COLOR_abstract_compiler__AbstractCompilerVisitor___variables].val; /* _variables on <self:AbstractCompilerVisitor> */
+if (unlikely(var7 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _variables");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 1315);
+show_backtrace(1);
 }
-if (varonce7) {
-var8 = varonce7;
-} else {
-var9 = " at ";
-var10 = 4;
-var11 = string__NativeString__to_s_with_length(var9, var10);
-var8 = var11;
-varonce7 = var8;
+var5 = var7;
+RET_LABEL6:(void)0;
 }
-var12 = ((val* (*)(val*))(self->class->vft[COLOR_parser_nodes__ANode__location]))(self) /* location on <self:AExternInitPropdef>*/;
-var13 = ((val* (*)(val*))(var12->class->vft[COLOR_string__Object__to_s]))(var12) /* to_s on <var12:Location>*/;
-if (varonce14) {
-var15 = varonce14;
-} else {
-var16 = "\\n\");";
-var17 = 5;
-var18 = string__NativeString__to_s_with_length(var16, var17);
-var15 = var18;
-varonce14 = var15;
 }
-var19 = NEW_array__Array(&type_array__Arraykernel__Object);
-{ /* var19 = array_instance Array[Object] */
-var20 = 5;
-var21 = NEW_array__NativeArray(var20, &type_array__NativeArraykernel__Object);
-((struct instance_array__NativeArray*)var21)->values[0] = (val*) var3;
-((struct instance_array__NativeArray*)var21)->values[1] = (val*) var_mpropdef;
-((struct instance_array__NativeArray*)var21)->values[2] = (val*) var8;
-((struct instance_array__NativeArray*)var21)->values[3] = (val*) var13;
-((struct instance_array__NativeArray*)var21)->values[4] = (val*) var15;
-((void (*)(val*, val*, long))(var19->class->vft[COLOR_array__Array__with_native]))(var19, var21, var20) /* with_native on <var19:Array[Object]>*/;
-CHECK_NEW_array__Array(var19);
-}
-var22 = ((val* (*)(val*))(var19->class->vft[COLOR_string__Object__to_s]))(var19) /* to_s on <var19:Array[Object]>*/;
-((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(var_v, var22) /* add on <var_v:AbstractCompilerVisitor>*/;
-if (varonce23) {
-var24 = varonce23;
-} else {
-var25 = "exit(1);";
-var26 = 8;
-var27 = string__NativeString__to_s_with_length(var25, var26);
-var24 = var27;
-varonce23 = var24;
-}
-((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(var_v, var24) /* add on <var_v:AbstractCompilerVisitor>*/;
+{
+var8 = hash_collection__HashMap___91d_93d(var5, var_variable);
+}
+var = var8;
 goto RET_LABEL;
 } else {
+if (varonce) {
+var9 = varonce;
+} else {
+var10 = "var_";
+var11 = 4;
+var12 = string__NativeString__to_s_with_length(var10, var11);
+var9 = var12;
+varonce = var9;
 }
-var28 = ((val* (*)(val*))(var_nextern->class->vft[COLOR_parser_nodes__Token__text]))(var_nextern) /* text on <var_nextern:nullable TString(TString)>*/;
-var29 = 1;
-var30 = ((val* (*)(val*))(var_nextern->class->vft[COLOR_parser_nodes__Token__text]))(var_nextern) /* text on <var_nextern:nullable TString(TString)>*/;
-var31 = ((long (*)(val*))(var30->class->vft[COLOR_abstract_collection__Collection__length]))(var30) /* length on <var30:String>*/;
-var32 = 2;
-{ /* Inline kernel#Int#- (var31,var32) */
-var35 = var31 - var32;
-var33 = var35;
-goto RET_LABEL34;
-RET_LABEL34:(void)0;
+{
+{ /* Inline scope#Variable#name (var_variable) on <var_variable:Variable> */
+var15 = var_variable->attrs[COLOR_scope__Variable___name].val; /* _name on <var_variable:Variable> */
+if (unlikely(var15 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _name");
+PRINT_ERROR(" (%s:%d)\n", "semantize/scope.nit", 34);
+show_backtrace(1);
 }
-var36 = ((val* (*)(val*, long, long))(var28->class->vft[COLOR_string__AbstractString__substring]))(var28, var29, var33) /* substring on <var28:String>*/;
-var_externname = var36;
-var37 = ((val* (*)(val*))(self->class->vft[COLOR_parser_nodes__ANode__location]))(self) /* location on <self:AExternInitPropdef>*/;
-var38 = ((val* (*)(val*))(var37->class->vft[COLOR_location__Location__file]))(var37) /* file on <var37:Location>*/;
-var39 = NULL;
-if (var38 == NULL) {
-var40 = 0; /* is null */
-} else {
-var40 = 1; /* arg is null and recv is not */
-}
-if (var40){
-var41 = ((val* (*)(val*))(self->class->vft[COLOR_parser_nodes__ANode__location]))(self) /* location on <self:AExternInitPropdef>*/;
-var42 = ((val* (*)(val*))(var41->class->vft[COLOR_location__Location__file]))(var41) /* file on <var41:Location>*/;
-if (var42 == NULL) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Reciever is null", "src/abstract_compiler.nit", 1629);
-exit(1);
-} else {
-var43 = ((val* (*)(val*))(var42->class->vft[COLOR_location__SourceFile__filename]))(var42) /* filename on <var42:nullable SourceFile>*/;
-}
-var_file = var43;
-((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add_extern]))(var_v, var_file) /* add_extern on <var_v:AbstractCompilerVisitor>*/;
-} else {
-}
-((void (*)(val*, val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__adapt_signature]))(var_v, var_mpropdef, var_arguments) /* adapt_signature on <var_v:AbstractCompilerVisitor>*/;
-var44 = ((val* (*)(val*))(var_arguments->class->vft[COLOR_abstract_collection__Collection__first]))(var_arguments) /* first on <var_arguments:Array[RuntimeVariable]>*/;
-var45 = ((val* (*)(val*))(var44->class->vft[COLOR_abstract_compiler__RuntimeVariable__mtype]))(var44) /* mtype on <var44:nullable Object(RuntimeVariable)>*/;
-var_ret = var45;
-var46 = ((val* (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__new_var]))(var_v, var_ret) /* new_var on <var_v:AbstractCompilerVisitor>*/;
-var_res = var46;
-var47 = ((val* (*)(val*))(var_arguments->class->vft[COLOR_abstract_collection__Sequence__shift]))(var_arguments) /* shift on <var_arguments:Array[RuntimeVariable]>*/;
-var47;
-if (varonce48) {
-var49 = varonce48;
-} else {
-var50 = " = ";
-var51 = 3;
-var52 = string__NativeString__to_s_with_length(var50, var51);
-var49 = var52;
-varonce48 = var49;
+var13 = var15;
+RET_LABEL14:(void)0;
 }
-if (varonce53) {
-var54 = varonce53;
-} else {
-var55 = "(";
-var56 = 1;
-var57 = string__NativeString__to_s_with_length(var55, var56);
-var54 = var57;
-varonce53 = var54;
 }
-if (varonce58) {
-var59 = varonce58;
-} else {
-var60 = ", ";
-var61 = 2;
-var62 = string__NativeString__to_s_with_length(var60, var61);
-var59 = var62;
-varonce58 = var59;
-}
-var63 = ((val* (*)(val*, val*))(var_arguments->class->vft[COLOR_string__Collection__join]))(var_arguments, var59) /* join on <var_arguments:Array[RuntimeVariable]>*/;
-if (varonce64) {
-var65 = varonce64;
-} else {
-var66 = ");";
-var67 = 2;
-var68 = string__NativeString__to_s_with_length(var66, var67);
-var65 = var68;
-varonce64 = var65;
-}
-var69 = NEW_array__Array(&type_array__Arraykernel__Object);
-{ /* var69 = array_instance Array[Object] */
-var70 = 6;
-var71 = NEW_array__NativeArray(var70, &type_array__NativeArraykernel__Object);
-((struct instance_array__NativeArray*)var71)->values[0] = (val*) var_res;
-((struct instance_array__NativeArray*)var71)->values[1] = (val*) var49;
-((struct instance_array__NativeArray*)var71)->values[2] = (val*) var_externname;
-((struct instance_array__NativeArray*)var71)->values[3] = (val*) var54;
-((struct instance_array__NativeArray*)var71)->values[4] = (val*) var63;
-((struct instance_array__NativeArray*)var71)->values[5] = (val*) var65;
-((void (*)(val*, val*, long))(var69->class->vft[COLOR_array__Array__with_native]))(var69, var71, var70) /* with_native on <var69:Array[Object]>*/;
-CHECK_NEW_array__Array(var69);
-}
-var72 = ((val* (*)(val*))(var69->class->vft[COLOR_string__Object__to_s]))(var69) /* to_s on <var69:Array[Object]>*/;
-((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(var_v, var72) /* add on <var_v:AbstractCompilerVisitor>*/;
-((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__ret]))(var_v, var_res) /* ret on <var_v:AbstractCompilerVisitor>*/;
-RET_LABEL:;
+var16 = NEW_array__Array(&type_array__Arraykernel__Object);
+{ /* var16 = array_instance Array[Object] */
+var17 = 2;
+var18 = NEW_array__NativeArray(var17, &type_array__NativeArraykernel__Object);
+((struct instance_array__NativeArray*)var18)->values[0] = (val*) var9;
+((struct instance_array__NativeArray*)var18)->values[1] = (val*) var13;
+{
+((void (*)(val*, val*, long))(var16->class->vft[COLOR_array__Array__with_native]))(var16, var18, var17) /* with_native on <var16:Array[Object]>*/;
 }
-/* method abstract_compiler#AExternInitPropdef#compile_to_c for (self: Object, AbstractCompilerVisitor, MMethodDef, Array[RuntimeVariable]) */
-void VIRTUAL_abstract_compiler__AExternInitPropdef__compile_to_c(val* self, val* p0, val* p1, val* p2) {
-abstract_compiler__AExternInitPropdef__compile_to_c(self, p0, p1, p2);
-RET_LABEL:;
 }
-/* method abstract_compiler#AAttrPropdef#compile_to_c for (self: AAttrPropdef, AbstractCompilerVisitor, MMethodDef, Array[RuntimeVariable]) */
-void abstract_compiler__AAttrPropdef__compile_to_c(val* self, val* p0, val* p1, val* p2) {
-val* var_v /* var v: AbstractCompilerVisitor */;
-val* var_mpropdef /* var mpropdef: MMethodDef */;
-val* var_arguments /* var arguments: Array[RuntimeVariable] */;
-long var /* : Int */;
-long var1 /* : Int */;
-short int var2 /* : Bool */;
-short int var4 /* : Bool */;
-val* var5 /* : nullable MPropDef */;
-val* var6 /* : MProperty */;
-val* var7 /* : nullable Object */;
-val* var8 /* : RuntimeVariable */;
-val* var_res /* var res: RuntimeVariable */;
-val* var9 /* : nullable Frame */;
-val* var10 /* : nullable RuntimeVariable */;
-val* var11 /* : nullable MPropDef */;
-val* var12 /* : MProperty */;
-val* var13 /* : nullable Object */;
-long var14 /* : Int */;
-val* var15 /* : nullable Object */;
-var_v = p0;
-var_mpropdef = p1;
-var_arguments = p2;
-var = ((long (*)(val*))(var_arguments->class->vft[COLOR_abstract_collection__Collection__length]))(var_arguments) /* length on <var_arguments:Array[RuntimeVariable]>*/;
-var1 = 1;
-{ /* Inline kernel#Int#== (var,var1) */
-var4 = var == var1;
-var2 = var4;
-goto RET_LABEL3;
-RET_LABEL3:(void)0;
+{
+var19 = ((val* (*)(val*))(var16->class->vft[COLOR_string__Object__to_s]))(var16) /* to_s on <var16:Array[Object]>*/;
 }
-if (var2){
-var5 = ((val* (*)(val*))(self->class->vft[COLOR_modelize_property__APropdef__mpropdef]))(self) /* mpropdef on <self:AAttrPropdef>*/;
-if (var5 == NULL) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Reciever is null", "src/abstract_compiler.nit", 1647);
-exit(1);
-} else {
-var6 = ((val* (*)(val*))(var5->class->vft[COLOR_model__MPropDef__mproperty]))(var5) /* mproperty on <var5:nullable MPropDef(nullable MAttributeDef)>*/;
+{
+var20 = abstract_compiler__AbstractCompilerVisitor__get_name(self, var19);
 }
-var7 = ((val* (*)(val*))(var_arguments->class->vft[COLOR_abstract_collection__Collection__first]))(var_arguments) /* first on <var_arguments:Array[RuntimeVariable]>*/;
-var8 = ((val* (*)(val*, val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__read_attribute]))(var_v, var6, var7) /* read_attribute on <var_v:AbstractCompilerVisitor>*/;
-var_res = var8;
-var9 = ((val* (*)(val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__frame]))(var_v) /* frame on <var_v:AbstractCompilerVisitor>*/;
-if (var9 == NULL) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Reciever is null", "src/abstract_compiler.nit", 1648);
-exit(1);
-} else {
-var10 = ((val* (*)(val*))(var9->class->vft[COLOR_abstract_compiler__Frame__returnvar]))(var9) /* returnvar on <var9:nullable Frame>*/;
+var_name = var20;
+{
+{ /* Inline typing#Variable#declared_type (var_variable) on <var_variable:Variable> */
+var23 = var_variable->attrs[COLOR_typing__Variable___declared_type].val; /* _declared_type on <var_variable:Variable> */
+var21 = var23;
+RET_LABEL22:(void)0;
 }
-if (var10 == NULL) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "src/abstract_compiler.nit", 1648);
-exit(1);
 }
-((void (*)(val*, val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__assign]))(var_v, var10, var_res) /* assign on <var_v:AbstractCompilerVisitor>*/;
-} else {
-var11 = ((val* (*)(val*))(self->class->vft[COLOR_modelize_property__APropdef__mpropdef]))(self) /* mpropdef on <self:AAttrPropdef>*/;
-if (var11 == NULL) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Reciever is null", "src/abstract_compiler.nit", 1650);
-exit(1);
-} else {
-var12 = ((val* (*)(val*))(var11->class->vft[COLOR_model__MPropDef__mproperty]))(var11) /* mproperty on <var11:nullable MPropDef(nullable MAttributeDef)>*/;
+if (unlikely(var21 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Cast failed");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 1324);
+show_backtrace(1);
 }
-var13 = ((val* (*)(val*))(var_arguments->class->vft[COLOR_abstract_collection__Collection__first]))(var_arguments) /* first on <var_arguments:Array[RuntimeVariable]>*/;
-var14 = 1;
-var15 = ((val* (*)(val*, long))(var_arguments->class->vft[COLOR_abstract_collection__SequenceRead___91d_93d]))(var_arguments, var14) /* [] on <var_arguments:Array[RuntimeVariable]>*/;
-((void (*)(val*, val*, val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__write_attribute]))(var_v, var12, var13, var15) /* write_attribute on <var_v:AbstractCompilerVisitor>*/;
+var_mtype = var21;
+{
+var24 = abstract_compiler__AbstractCompilerVisitor__anchor(self, var_mtype);
 }
-RET_LABEL:;
+var_mtype = var24;
+var25 = NEW_abstract_compiler__RuntimeVariable(&type_abstract_compiler__RuntimeVariable);
+{
+abstract_compiler__RuntimeVariable__init(var25, var_name, var_mtype, var_mtype); /* Direct call abstract_compiler#RuntimeVariable#init on <var25:RuntimeVariable>*/
 }
-/* method abstract_compiler#AAttrPropdef#compile_to_c for (self: Object, AbstractCompilerVisitor, MMethodDef, Array[RuntimeVariable]) */
-void VIRTUAL_abstract_compiler__AAttrPropdef__compile_to_c(val* self, val* p0, val* p1, val* p2) {
-abstract_compiler__AAttrPropdef__compile_to_c(self, p0, p1, p2);
-RET_LABEL:;
+var_res = var25;
+{
+var26 = ((val* (*)(val*))(var_mtype->class->vft[COLOR_abstract_compiler__MType__ctype]))(var_mtype) /* ctype on <var_mtype:MType>*/;
 }
-/* method abstract_compiler#AAttrPropdef#init_expr for (self: AAttrPropdef, AbstractCompilerVisitor, RuntimeVariable) */
-void abstract_compiler__AAttrPropdef__init_expr(val* self, val* p0, val* p1) {
-val* var_v /* var v: AbstractCompilerVisitor */;
-val* var_recv /* var recv: RuntimeVariable */;
-val* var /* : nullable AExpr */;
-val* var_nexpr /* var nexpr: nullable AExpr */;
-val* var1 /* : null */;
-short int var2 /* : Bool */;
-val* var3 /* : nullable ANode */;
-val* var_oldnode /* var oldnode: nullable ANode */;
-val* var4 /* : nullable Frame */;
-val* var_old_frame /* var old_frame: nullable Frame */;
-val* var5 /* : Frame */;
-val* var6 /* : nullable MPropDef */;
-val* var7 /* : MType */;
-short int var8 /* : Bool */;
-int cltype;
-int idtype;
-val* var9 /* : Array[RuntimeVariable] */;
-long var10 /* : Int */;
-val* var_ /* var : Array[RuntimeVariable] */;
-val* var_frame /* var frame: Frame */;
-val* var11 /* : nullable MPropDef */;
-val* var12 /* : nullable MType */;
-val* var13 /* : RuntimeVariable */;
-val* var_value /* var value: RuntimeVariable */;
-val* var14 /* : nullable MPropDef */;
-val* var15 /* : MProperty */;
-var_v = p0;
-var_recv = p1;
-var = ((val* (*)(val*))(self->class->vft[COLOR_parser_nodes__AAttrPropdef__n_expr]))(self) /* n_expr on <self:AAttrPropdef>*/;
-var_nexpr = var;
-var1 = NULL;
-if (var_nexpr == NULL) {
-var2 = 0; /* is null */
+if (varonce27) {
+var28 = varonce27;
 } else {
-var2 = 1; /* arg is null and recv is not */
-}
-if (var2){
-var3 = ((val* (*)(val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__current_node]))(var_v) /* current_node on <var_v:AbstractCompilerVisitor>*/;
-var_oldnode = var3;
-((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__current_node_61d]))(var_v, self) /* current_node= on <var_v:AbstractCompilerVisitor>*/;
-var4 = ((val* (*)(val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__frame]))(var_v) /* frame on <var_v:AbstractCompilerVisitor>*/;
-var_old_frame = var4;
-var5 = NEW_abstract_compiler__Frame(&type_abstract_compiler__Frame);
-var6 = ((val* (*)(val*))(self->class->vft[COLOR_modelize_property__APropdef__mpropdef]))(self) /* mpropdef on <self:AAttrPropdef>*/;
-if (var6 == NULL) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "src/abstract_compiler.nit", 1661);
-exit(1);
+var29 = " ";
+var30 = 1;
+var31 = string__NativeString__to_s_with_length(var29, var30);
+var28 = var31;
+varonce27 = var28;
 }
-var7 = ((val* (*)(val*))(var_recv->class->vft[COLOR_abstract_compiler__RuntimeVariable__mtype]))(var_recv) /* mtype on <var_recv:RuntimeVariable>*/;
-/* <var7:MType> isa MClassType */
-cltype = type_model__MClassType.color;
-idtype = type_model__MClassType.id;
-if(cltype >= var7->type->table_size) {
-var8 = 0;
+if (varonce32) {
+var33 = varonce32;
 } else {
-var8 = var7->type->type_table[cltype] == idtype;
+var34 = " /* var ";
+var35 = 8;
+var36 = string__NativeString__to_s_with_length(var34, var35);
+var33 = var36;
+varonce32 = var33;
 }
-if (!var8) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "src/abstract_compiler.nit", 1661);
-exit(1);
+if (varonce37) {
+var38 = varonce37;
+} else {
+var39 = ": ";
+var40 = 2;
+var41 = string__NativeString__to_s_with_length(var39, var40);
+var38 = var41;
+varonce37 = var38;
 }
-var9 = NEW_array__Array(&type_array__Arrayabstract_compiler__RuntimeVariable);
-var10 = 1;
-((void (*)(val*, long))(var9->class->vft[COLOR_array__Array__with_capacity]))(var9, var10) /* with_capacity on <var9:Array[RuntimeVariable]>*/;
-CHECK_NEW_array__Array(var9);
-var_ = var9;
-((void (*)(val*, val*))(var_->class->vft[COLOR_abstract_collection__Sequence__push]))(var_, var_recv) /* push on <var_:Array[RuntimeVariable]>*/;
-((void (*)(val*, val*, val*, val*, val*))(var5->class->vft[COLOR_abstract_compiler__Frame__init]))(var5, var_v, var6, var7, var_) /* init on <var5:Frame>*/;
-CHECK_NEW_abstract_compiler__Frame(var5);
-var_frame = var5;
-((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__frame_61d]))(var_v, var_frame) /* frame= on <var_v:AbstractCompilerVisitor>*/;
-var11 = ((val* (*)(val*))(self->class->vft[COLOR_modelize_property__APropdef__mpropdef]))(self) /* mpropdef on <self:AAttrPropdef>*/;
-if (var11 == NULL) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Reciever is null", "src/abstract_compiler.nit", 1663);
-exit(1);
-} else {
-var12 = ((val* (*)(val*))(var11->class->vft[COLOR_model__MAttributeDef__static_mtype]))(var11) /* static_mtype on <var11:nullable MPropDef(nullable MAttributeDef)>*/;
-}
-var13 = ((val* (*)(val*, val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__expr]))(var_v, var_nexpr, var12) /* expr on <var_v:AbstractCompilerVisitor>*/;
-var_value = var13;
-var14 = ((val* (*)(val*))(self->class->vft[COLOR_modelize_property__APropdef__mpropdef]))(self) /* mpropdef on <self:AAttrPropdef>*/;
-if (var14 == NULL) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Reciever is null", "src/abstract_compiler.nit", 1664);
-exit(1);
-} else {
-var15 = ((val* (*)(val*))(var14->class->vft[COLOR_model__MPropDef__mproperty]))(var14) /* mproperty on <var14:nullable MPropDef(nullable MAttributeDef)>*/;
-}
-((void (*)(val*, val*, val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__write_attribute]))(var_v, var15, var_recv, var_value) /* write_attribute on <var_v:AbstractCompilerVisitor>*/;
-((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__frame_61d]))(var_v, var_old_frame) /* frame= on <var_v:AbstractCompilerVisitor>*/;
-((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__current_node_61d]))(var_v, var_oldnode) /* current_node= on <var_v:AbstractCompilerVisitor>*/;
+if (varonce42) {
+var43 = varonce42;
 } else {
+var44 = " */;";
+var45 = 4;
+var46 = string__NativeString__to_s_with_length(var44, var45);
+var43 = var46;
+varonce42 = var43;
 }
-RET_LABEL:;
+var47 = NEW_array__Array(&type_array__Arraykernel__Object);
+{ /* var47 = array_instance Array[Object] */
+var48 = 8;
+var49 = NEW_array__NativeArray(var48, &type_array__NativeArraykernel__Object);
+((struct instance_array__NativeArray*)var49)->values[0] = (val*) var26;
+((struct instance_array__NativeArray*)var49)->values[1] = (val*) var28;
+((struct instance_array__NativeArray*)var49)->values[2] = (val*) var_name;
+((struct instance_array__NativeArray*)var49)->values[3] = (val*) var33;
+((struct instance_array__NativeArray*)var49)->values[4] = (val*) var_variable;
+((struct instance_array__NativeArray*)var49)->values[5] = (val*) var38;
+((struct instance_array__NativeArray*)var49)->values[6] = (val*) var_mtype;
+((struct instance_array__NativeArray*)var49)->values[7] = (val*) var43;
+{
+((void (*)(val*, val*, long))(var47->class->vft[COLOR_array__Array__with_native]))(var47, var49, var48) /* with_native on <var47:Array[Object]>*/;
 }
-/* method abstract_compiler#AAttrPropdef#init_expr for (self: Object, AbstractCompilerVisitor, RuntimeVariable) */
-void VIRTUAL_abstract_compiler__AAttrPropdef__init_expr(val* self, val* p0, val* p1) {
-abstract_compiler__AAttrPropdef__init_expr(self, p0, p1);
-RET_LABEL:;
 }
-/* method abstract_compiler#AAttrPropdef#check_expr for (self: AAttrPropdef, AbstractCompilerVisitor, RuntimeVariable) */
-void abstract_compiler__AAttrPropdef__check_expr(val* self, val* p0, val* p1) {
-val* var_v /* var v: AbstractCompilerVisitor */;
-val* var_recv /* var recv: RuntimeVariable */;
-val* var /* : nullable AExpr */;
-val* var_nexpr /* var nexpr: nullable AExpr */;
-val* var1 /* : null */;
-short int var2 /* : Bool */;
-val* var3 /* : nullable ANode */;
-val* var_oldnode /* var oldnode: nullable ANode */;
-val* var4 /* : nullable Frame */;
-val* var_old_frame /* var old_frame: nullable Frame */;
-val* var5 /* : Frame */;
-val* var6 /* : nullable MPropDef */;
-val* var7 /* : MType */;
-short int var8 /* : Bool */;
-int cltype;
-int idtype;
-val* var9 /* : Array[RuntimeVariable] */;
-long var10 /* : Int */;
-val* var_ /* var : Array[RuntimeVariable] */;
-val* var_frame /* var frame: Frame */;
-val* var11 /* : nullable MPropDef */;
-val* var12 /* : MProperty */;
-val* var13 /* : RuntimeVariable */;
-var_v = p0;
-var_recv = p1;
-var = ((val* (*)(val*))(self->class->vft[COLOR_parser_nodes__AAttrPropdef__n_expr]))(self) /* n_expr on <self:AAttrPropdef>*/;
-var_nexpr = var;
-var1 = NULL;
-if (var_nexpr == NULL) {
-var2 = 0; /* is null */
-} else {
-var2 = 1; /* arg is null and recv is not */
+{
+var50 = ((val* (*)(val*))(var47->class->vft[COLOR_string__Object__to_s]))(var47) /* to_s on <var47:Array[Object]>*/;
 }
-if (var2){
-goto RET_LABEL;
-} else {
+{
+abstract_compiler__AbstractCompilerVisitor__add_decl(self, var50); /* Direct call abstract_compiler#AbstractCompilerVisitor#add_decl on <self:AbstractCompilerVisitor>*/
 }
-var3 = ((val* (*)(val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__current_node]))(var_v) /* current_node on <var_v:AbstractCompilerVisitor>*/;
-var_oldnode = var3;
-((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__current_node_61d]))(var_v, self) /* current_node= on <var_v:AbstractCompilerVisitor>*/;
-var4 = ((val* (*)(val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__frame]))(var_v) /* frame on <var_v:AbstractCompilerVisitor>*/;
-var_old_frame = var4;
-var5 = NEW_abstract_compiler__Frame(&type_abstract_compiler__Frame);
-var6 = ((val* (*)(val*))(self->class->vft[COLOR_modelize_property__APropdef__mpropdef]))(self) /* mpropdef on <self:AAttrPropdef>*/;
-if (var6 == NULL) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "src/abstract_compiler.nit", 1678);
-exit(1);
+{
+{ /* Inline abstract_compiler#AbstractCompilerVisitor#variables (self) on <self:AbstractCompilerVisitor> */
+var53 = self->attrs[COLOR_abstract_compiler__AbstractCompilerVisitor___variables].val; /* _variables on <self:AbstractCompilerVisitor> */
+if (unlikely(var53 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _variables");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 1315);
+show_backtrace(1);
 }
-var7 = ((val* (*)(val*))(var_recv->class->vft[COLOR_abstract_compiler__RuntimeVariable__mtype]))(var_recv) /* mtype on <var_recv:RuntimeVariable>*/;
-/* <var7:MType> isa MClassType */
-cltype = type_model__MClassType.color;
-idtype = type_model__MClassType.id;
-if(cltype >= var7->type->table_size) {
-var8 = 0;
-} else {
-var8 = var7->type->type_table[cltype] == idtype;
+var51 = var53;
+RET_LABEL52:(void)0;
 }
-if (!var8) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "src/abstract_compiler.nit", 1678);
-exit(1);
 }
-var9 = NEW_array__Array(&type_array__Arrayabstract_compiler__RuntimeVariable);
-var10 = 1;
-((void (*)(val*, long))(var9->class->vft[COLOR_array__Array__with_capacity]))(var9, var10) /* with_capacity on <var9:Array[RuntimeVariable]>*/;
-CHECK_NEW_array__Array(var9);
-var_ = var9;
-((void (*)(val*, val*))(var_->class->vft[COLOR_abstract_collection__Sequence__push]))(var_, var_recv) /* push on <var_:Array[RuntimeVariable]>*/;
-((void (*)(val*, val*, val*, val*, val*))(var5->class->vft[COLOR_abstract_compiler__Frame__init]))(var5, var_v, var6, var7, var_) /* init on <var5:Frame>*/;
-CHECK_NEW_abstract_compiler__Frame(var5);
-var_frame = var5;
-((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__frame_61d]))(var_v, var_frame) /* frame= on <var_v:AbstractCompilerVisitor>*/;
-var11 = ((val* (*)(val*))(self->class->vft[COLOR_modelize_property__APropdef__mpropdef]))(self) /* mpropdef on <self:AAttrPropdef>*/;
-if (var11 == NULL) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Reciever is null", "src/abstract_compiler.nit", 1681);
-exit(1);
-} else {
-var12 = ((val* (*)(val*))(var11->class->vft[COLOR_model__MPropDef__mproperty]))(var11) /* mproperty on <var11:nullable MPropDef(nullable MAttributeDef)>*/;
-}
-var13 = ((val* (*)(val*, val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__read_attribute]))(var_v, var12, var_recv) /* read_attribute on <var_v:AbstractCompilerVisitor>*/;
-var13;
-((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__frame_61d]))(var_v, var_old_frame) /* frame= on <var_v:AbstractCompilerVisitor>*/;
-((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__current_node_61d]))(var_v, var_oldnode) /* current_node= on <var_v:AbstractCompilerVisitor>*/;
-RET_LABEL:;
+{
+hash_collection__HashMap___91d_93d_61d(var51, var_variable, var_res); /* Direct call hash_collection#HashMap#[]= on <var51:HashMap[Variable, RuntimeVariable]>*/
+}
+var = var_res;
+goto RET_LABEL;
 }
-/* method abstract_compiler#AAttrPropdef#check_expr for (self: Object, AbstractCompilerVisitor, RuntimeVariable) */
-void VIRTUAL_abstract_compiler__AAttrPropdef__check_expr(val* self, val* p0, val* p1) {
-abstract_compiler__AAttrPropdef__check_expr(self, p0, p1);
 RET_LABEL:;
+return var;
 }
-/* method abstract_compiler#AClassdef#compile_to_c for (self: AClassdef, AbstractCompilerVisitor, MMethodDef, Array[RuntimeVariable]) */
-void abstract_compiler__AClassdef__compile_to_c(val* self, val* p0, val* p1, val* p2) {
-val* var_v /* var v: AbstractCompilerVisitor */;
-val* var_mpropdef /* var mpropdef: MMethodDef */;
-val* var_arguments /* var arguments: Array[RuntimeVariable] */;
-val* var /* : nullable MMethodDef */;
-short int var1 /* : Bool */;
-val* var2 /* : nullable Collection[MMethod] */;
-val* var_super_inits /* var super_inits: nullable Collection[MMethod] */;
-val* var3 /* : null */;
-short int var4 /* : Bool */;
-long var5 /* : Int */;
-long var6 /* : Int */;
-short int var7 /* : Bool */;
-short int var9 /* : Bool */;
-val* var10 /* : Iterator[nullable Object] */;
-short int var11 /* : Bool */;
-val* var12 /* : nullable Object */;
-val* var_su /* var su: MMethod */;
-val* var13 /* : nullable RuntimeVariable */;
-val* var14 /* : nullable Object */;
-val* var_recv /* var recv: RuntimeVariable */;
-long var15 /* : Int */;
-long var_i /* var i: Int */;
-val* var16 /* : ANodes[APropdef] */;
-val* var17 /* : Iterator[nullable Object] */;
-short int var18 /* : Bool */;
-val* var19 /* : nullable Object */;
-val* var_npropdef /* var npropdef: APropdef */;
-short int var20 /* : Bool */;
-short int var21 /* : Bool */;
-int cltype;
-int idtype;
-short int var_ /* var : Bool */;
-val* var22 /* : nullable AExpr */;
-val* var23 /* : null */;
-short int var24 /* : Bool */;
-val* var25 /* : nullable MPropDef */;
-val* var26 /* : MProperty */;
-val* var27 /* : nullable Object */;
-long var28 /* : Int */;
-long var29 /* : Int */;
-long var31 /* : Int */;
-var_v = p0;
-var_mpropdef = p1;
-var_arguments = p2;
-var = ((val* (*)(val*))(self->class->vft[COLOR_modelize_property__AClassdef__mfree_init]))(self) /* mfree_init on <self:AClassdef>*/;
-var1 = ((short int (*)(val*, val*))(var_mpropdef->class->vft[COLOR_kernel__Object___61d_61d]))(var_mpropdef, var) /* == on <var_mpropdef:MMethodDef>*/;
-if (var1){
-var2 = ((val* (*)(val*))(self->class->vft[COLOR_modelize_property__AClassdef__super_inits]))(self) /* super_inits on <self:AClassdef>*/;
-var_super_inits = var2;
-var3 = NULL;
-if (var_super_inits == NULL) {
-var4 = 0; /* is null */
-} else {
-var4 = 1; /* arg is null and recv is not */
+/* method abstract_compiler#AbstractCompilerVisitor#variable for (self: Object, Variable): RuntimeVariable */
+val* VIRTUAL_abstract_compiler__AbstractCompilerVisitor__variable(val* self, val* p0) {
+val* var /* : RuntimeVariable */;
+val* var1 /* : RuntimeVariable */;
+var1 = abstract_compiler__AbstractCompilerVisitor__variable(self, p0);
+var = var1;
+RET_LABEL:;
+return var;
 }
-if (var4){
-var5 = ((long (*)(val*))(var_arguments->class->vft[COLOR_abstract_collection__Collection__length]))(var_arguments) /* length on <var_arguments:Array[RuntimeVariable]>*/;
-var6 = 1;
-{ /* Inline kernel#Int#== (var5,var6) */
-var9 = var5 == var6;
-var7 = var9;
-goto RET_LABEL8;
-RET_LABEL8:(void)0;
+/* method abstract_compiler#AbstractCompilerVisitor#new_var for (self: AbstractCompilerVisitor, MType): RuntimeVariable */
+val* abstract_compiler__AbstractCompilerVisitor__new_var(val* self, val* p0) {
+val* var /* : RuntimeVariable */;
+val* var_mtype /* var mtype: MType */;
+val* var1 /* : MType */;
+static val* varonce;
+val* var2 /* : String */;
+char* var3 /* : NativeString */;
+long var4 /* : Int */;
+val* var5 /* : FlatString */;
+val* var6 /* : String */;
+val* var_name /* var name: String */;
+val* var7 /* : RuntimeVariable */;
+val* var_res /* var res: RuntimeVariable */;
+val* var8 /* : String */;
+static val* varonce9;
+val* var10 /* : String */;
+char* var11 /* : NativeString */;
+long var12 /* : Int */;
+val* var13 /* : FlatString */;
+static val* varonce14;
+val* var15 /* : String */;
+char* var16 /* : NativeString */;
+long var17 /* : Int */;
+val* var18 /* : FlatString */;
+static val* varonce19;
+val* var20 /* : String */;
+char* var21 /* : NativeString */;
+long var22 /* : Int */;
+val* var23 /* : FlatString */;
+val* var24 /* : Array[Object] */;
+long var25 /* : Int */;
+val* var26 /* : NativeArray[Object] */;
+val* var27 /* : String */;
+var_mtype = p0;
+{
+var1 = abstract_compiler__AbstractCompilerVisitor__anchor(self, var_mtype);
 }
-if (!var7) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Assert failed", "src/abstract_compiler.nit", 1693);
-exit(1);
+var_mtype = var1;
+if (varonce) {
+var2 = varonce;
+} else {
+var3 = "var";
+var4 = 3;
+var5 = string__NativeString__to_s_with_length(var3, var4);
+var2 = var5;
+varonce = var2;
 }
-var10 = ((val* (*)(val*))(var_super_inits->class->vft[COLOR_abstract_collection__Collection__iterator]))(var_super_inits) /* iterator on <var_super_inits:nullable Collection[MMethod](Collection[MMethod])>*/;
-for(;;) {
-var11 = ((short int (*)(val*))(var10->class->vft[COLOR_abstract_collection__Iterator__is_ok]))(var10) /* is_ok on <var10:Iterator[nullable Object]>*/;
-if(!var11) break;
-var12 = ((val* (*)(val*))(var10->class->vft[COLOR_abstract_collection__Iterator__item]))(var10) /* item on <var10:Iterator[nullable Object]>*/;
-var_su = var12;
-var13 = ((val* (*)(val*, val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__send]))(var_v, var_su, var_arguments) /* send on <var_v:AbstractCompilerVisitor>*/;
-var13;
-CONTINUE_label: (void)0;
-((void (*)(val*))(var10->class->vft[COLOR_abstract_collection__Iterator__next]))(var10) /* next on <var10:Iterator[nullable Object]>*/;
+{
+var6 = abstract_compiler__AbstractCompilerVisitor__get_name(self, var2);
 }
-BREAK_label: (void)0;
-goto RET_LABEL;
-} else {
+var_name = var6;
+var7 = NEW_abstract_compiler__RuntimeVariable(&type_abstract_compiler__RuntimeVariable);
+{
+abstract_compiler__RuntimeVariable__init(var7, var_name, var_mtype, var_mtype); /* Direct call abstract_compiler#RuntimeVariable#init on <var7:RuntimeVariable>*/
 }
-var14 = ((val* (*)(val*))(var_arguments->class->vft[COLOR_abstract_collection__Collection__first]))(var_arguments) /* first on <var_arguments:Array[RuntimeVariable]>*/;
-var_recv = var14;
-var15 = 1;
-var_i = var15;
-var16 = ((val* (*)(val*))(self->class->vft[COLOR_parser_nodes__AClassdef__n_propdefs]))(self) /* n_propdefs on <self:AClassdef>*/;
-var17 = ((val* (*)(val*))(var16->class->vft[COLOR_abstract_collection__Collection__iterator]))(var16) /* iterator on <var16:ANodes[APropdef]>*/;
-for(;;) {
-var18 = ((short int (*)(val*))(var17->class->vft[COLOR_abstract_collection__Iterator__is_ok]))(var17) /* is_ok on <var17:Iterator[nullable Object]>*/;
-if(!var18) break;
-var19 = ((val* (*)(val*))(var17->class->vft[COLOR_abstract_collection__Iterator__item]))(var17) /* item on <var17:Iterator[nullable Object]>*/;
-var_npropdef = var19;
-/* <var_npropdef:APropdef> isa AAttrPropdef */
-cltype = type_parser_nodes__AAttrPropdef.color;
-idtype = type_parser_nodes__AAttrPropdef.id;
-if(cltype >= var_npropdef->type->table_size) {
-var21 = 0;
-} else {
-var21 = var_npropdef->type->type_table[cltype] == idtype;
+var_res = var7;
+{
+var8 = ((val* (*)(val*))(var_mtype->class->vft[COLOR_abstract_compiler__MType__ctype]))(var_mtype) /* ctype on <var_mtype:MType>*/;
 }
-var_ = var21;
-if (var21){
-var22 = ((val* (*)(val*))(var_npropdef->class->vft[COLOR_parser_nodes__AAttrPropdef__n_expr]))(var_npropdef) /* n_expr on <var_npropdef:APropdef(AAttrPropdef)>*/;
-var23 = NULL;
-if (var22 == NULL) {
-var24 = 1; /* is null */
+if (varonce9) {
+var10 = varonce9;
 } else {
-var24 = 0; /* arg is null but recv is not */
+var11 = " ";
+var12 = 1;
+var13 = string__NativeString__to_s_with_length(var11, var12);
+var10 = var13;
+varonce9 = var10;
 }
-var20 = var24;
+if (varonce14) {
+var15 = varonce14;
 } else {
-var20 = var_;
+var16 = " /* : ";
+var17 = 6;
+var18 = string__NativeString__to_s_with_length(var16, var17);
+var15 = var18;
+varonce14 = var15;
 }
-if (var20){
-var25 = ((val* (*)(val*))(var_npropdef->class->vft[COLOR_modelize_property__APropdef__mpropdef]))(var_npropdef) /* mpropdef on <var_npropdef:APropdef(AAttrPropdef)>*/;
-if (var25 == NULL) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Reciever is null", "src/abstract_compiler.nit", 1704);
-exit(1);
+if (varonce19) {
+var20 = varonce19;
 } else {
-var26 = ((val* (*)(val*))(var25->class->vft[COLOR_model__MPropDef__mproperty]))(var25) /* mproperty on <var25:nullable MPropDef(nullable MAttributeDef)>*/;
+var21 = " */;";
+var22 = 4;
+var23 = string__NativeString__to_s_with_length(var21, var22);
+var20 = var23;
+varonce19 = var20;
 }
-var27 = ((val* (*)(val*, long))(var_arguments->class->vft[COLOR_abstract_collection__SequenceRead___91d_93d]))(var_arguments, var_i) /* [] on <var_arguments:Array[RuntimeVariable]>*/;
-((void (*)(val*, val*, val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__write_attribute]))(var_v, var26, var_recv, var27) /* write_attribute on <var_v:AbstractCompilerVisitor>*/;
-var28 = 1;
-{ /* Inline kernel#Int#+ (var_i,var28) */
-var31 = var_i + var28;
-var29 = var31;
-goto RET_LABEL30;
-RET_LABEL30:(void)0;
+var24 = NEW_array__Array(&type_array__Arraykernel__Object);
+{ /* var24 = array_instance Array[Object] */
+var25 = 6;
+var26 = NEW_array__NativeArray(var25, &type_array__NativeArraykernel__Object);
+((struct instance_array__NativeArray*)var26)->values[0] = (val*) var8;
+((struct instance_array__NativeArray*)var26)->values[1] = (val*) var10;
+((struct instance_array__NativeArray*)var26)->values[2] = (val*) var_name;
+((struct instance_array__NativeArray*)var26)->values[3] = (val*) var15;
+((struct instance_array__NativeArray*)var26)->values[4] = (val*) var_mtype;
+((struct instance_array__NativeArray*)var26)->values[5] = (val*) var20;
+{
+((void (*)(val*, val*, long))(var24->class->vft[COLOR_array__Array__with_native]))(var24, var26, var25) /* with_native on <var24:Array[Object]>*/;
 }
-var_i = var29;
-} else {
 }
-CONTINUE_label32: (void)0;
-((void (*)(val*))(var17->class->vft[COLOR_abstract_collection__Iterator__next]))(var17) /* next on <var17:Iterator[nullable Object]>*/;
+{
+var27 = ((val* (*)(val*))(var24->class->vft[COLOR_string__Object__to_s]))(var24) /* to_s on <var24:Array[Object]>*/;
 }
-BREAK_label32: (void)0;
-} else {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Aborted", "src/abstract_compiler.nit", 1709);
-exit(1);
+{
+abstract_compiler__AbstractCompilerVisitor__add_decl(self, var27); /* Direct call abstract_compiler#AbstractCompilerVisitor#add_decl on <self:AbstractCompilerVisitor>*/
 }
+var = var_res;
+goto RET_LABEL;
 RET_LABEL:;
+return var;
 }
-/* method abstract_compiler#AClassdef#compile_to_c for (self: Object, AbstractCompilerVisitor, MMethodDef, Array[RuntimeVariable]) */
-void VIRTUAL_abstract_compiler__AClassdef__compile_to_c(val* self, val* p0, val* p1, val* p2) {
-abstract_compiler__AClassdef__compile_to_c(self, p0, p1, p2);
+/* method abstract_compiler#AbstractCompilerVisitor#new_var for (self: Object, MType): RuntimeVariable */
+val* VIRTUAL_abstract_compiler__AbstractCompilerVisitor__new_var(val* self, val* p0) {
+val* var /* : RuntimeVariable */;
+val* var1 /* : RuntimeVariable */;
+var1 = abstract_compiler__AbstractCompilerVisitor__new_var(self, p0);
+var = var1;
 RET_LABEL:;
+return var;
 }
-/* method abstract_compiler#ADeferredMethPropdef#compile_to_c for (self: ADeferredMethPropdef, AbstractCompilerVisitor, MMethodDef, Array[RuntimeVariable]) */
-void abstract_compiler__ADeferredMethPropdef__compile_to_c(val* self, val* p0, val* p1, val* p2) {
-val* var_v /* var v: AbstractCompilerVisitor */;
-val* var_mpropdef /* var mpropdef: MMethodDef */;
-val* var_arguments /* var arguments: Array[RuntimeVariable] */;
+/* method abstract_compiler#AbstractCompilerVisitor#new_var_extern for (self: AbstractCompilerVisitor, MType): RuntimeVariable */
+val* abstract_compiler__AbstractCompilerVisitor__new_var_extern(val* self, val* p0) {
+val* var /* : RuntimeVariable */;
+val* var_mtype /* var mtype: MType */;
+val* var1 /* : MType */;
 static val* varonce;
-val* var /* : String */;
-char* var1 /* : NativeString */;
-long var2 /* : Int */;
-val* var3 /* : String */;
-var_v = p0;
-var_mpropdef = p1;
-var_arguments = p2;
+val* var2 /* : String */;
+char* var3 /* : NativeString */;
+long var4 /* : Int */;
+val* var5 /* : FlatString */;
+val* var6 /* : String */;
+val* var_name /* var name: String */;
+val* var7 /* : RuntimeVariable */;
+val* var_res /* var res: RuntimeVariable */;
+val* var8 /* : String */;
+static val* varonce9;
+val* var10 /* : String */;
+char* var11 /* : NativeString */;
+long var12 /* : Int */;
+val* var13 /* : FlatString */;
+static val* varonce14;
+val* var15 /* : String */;
+char* var16 /* : NativeString */;
+long var17 /* : Int */;
+val* var18 /* : FlatString */;
+static val* varonce19;
+val* var20 /* : String */;
+char* var21 /* : NativeString */;
+long var22 /* : Int */;
+val* var23 /* : FlatString */;
+val* var24 /* : Array[Object] */;
+long var25 /* : Int */;
+val* var26 /* : NativeArray[Object] */;
+val* var27 /* : String */;
+var_mtype = p0;
+{
+var1 = abstract_compiler__AbstractCompilerVisitor__anchor(self, var_mtype);
+}
+var_mtype = var1;
 if (varonce) {
-var = varonce;
+var2 = varonce;
 } else {
-var1 = "Deferred method called";
-var2 = 22;
-var3 = string__NativeString__to_s_with_length(var1, var2);
-var = var3;
-varonce = var;
+var3 = "var";
+var4 = 3;
+var5 = string__NativeString__to_s_with_length(var3, var4);
+var2 = var5;
+varonce = var2;
 }
-((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add_abort]))(var_v, var) /* add_abort on <var_v:AbstractCompilerVisitor>*/;
-RET_LABEL:;
+{
+var6 = abstract_compiler__AbstractCompilerVisitor__get_name(self, var2);
 }
-/* method abstract_compiler#ADeferredMethPropdef#compile_to_c for (self: Object, AbstractCompilerVisitor, MMethodDef, Array[RuntimeVariable]) */
-void VIRTUAL_abstract_compiler__ADeferredMethPropdef__compile_to_c(val* self, val* p0, val* p1, val* p2) {
-abstract_compiler__ADeferredMethPropdef__compile_to_c(self, p0, p1, p2);
-RET_LABEL:;
+var_name = var6;
+var7 = NEW_abstract_compiler__RuntimeVariable(&type_abstract_compiler__RuntimeVariable);
+{
+abstract_compiler__RuntimeVariable__init(var7, var_name, var_mtype, var_mtype); /* Direct call abstract_compiler#RuntimeVariable#init on <var7:RuntimeVariable>*/
 }
-/* method abstract_compiler#ADeferredMethPropdef#can_inline for (self: ADeferredMethPropdef): Bool */
-short int abstract_compiler__ADeferredMethPropdef__can_inline(val* self) {
-short int var /* : Bool */;
-short int var1 /* : Bool */;
-var1 = 1;
-var = var1;
+var_res = var7;
+{
+var8 = ((val* (*)(val*))(var_mtype->class->vft[COLOR_abstract_compiler__MType__ctype_extern]))(var_mtype) /* ctype_extern on <var_mtype:MType>*/;
+}
+if (varonce9) {
+var10 = varonce9;
+} else {
+var11 = " ";
+var12 = 1;
+var13 = string__NativeString__to_s_with_length(var11, var12);
+var10 = var13;
+varonce9 = var10;
+}
+if (varonce14) {
+var15 = varonce14;
+} else {
+var16 = " /* : ";
+var17 = 6;
+var18 = string__NativeString__to_s_with_length(var16, var17);
+var15 = var18;
+varonce14 = var15;
+}
+if (varonce19) {
+var20 = varonce19;
+} else {
+var21 = " for extern */;";
+var22 = 15;
+var23 = string__NativeString__to_s_with_length(var21, var22);
+var20 = var23;
+varonce19 = var20;
+}
+var24 = NEW_array__Array(&type_array__Arraykernel__Object);
+{ /* var24 = array_instance Array[Object] */
+var25 = 6;
+var26 = NEW_array__NativeArray(var25, &type_array__NativeArraykernel__Object);
+((struct instance_array__NativeArray*)var26)->values[0] = (val*) var8;
+((struct instance_array__NativeArray*)var26)->values[1] = (val*) var10;
+((struct instance_array__NativeArray*)var26)->values[2] = (val*) var_name;
+((struct instance_array__NativeArray*)var26)->values[3] = (val*) var15;
+((struct instance_array__NativeArray*)var26)->values[4] = (val*) var_mtype;
+((struct instance_array__NativeArray*)var26)->values[5] = (val*) var20;
+{
+((void (*)(val*, val*, long))(var24->class->vft[COLOR_array__Array__with_native]))(var24, var26, var25) /* with_native on <var24:Array[Object]>*/;
+}
+}
+{
+var27 = ((val* (*)(val*))(var24->class->vft[COLOR_string__Object__to_s]))(var24) /* to_s on <var24:Array[Object]>*/;
+}
+{
+abstract_compiler__AbstractCompilerVisitor__add_decl(self, var27); /* Direct call abstract_compiler#AbstractCompilerVisitor#add_decl on <self:AbstractCompilerVisitor>*/
+}
+var = var_res;
 goto RET_LABEL;
 RET_LABEL:;
 return var;
 }
-/* method abstract_compiler#ADeferredMethPropdef#can_inline for (self: Object): Bool */
-short int VIRTUAL_abstract_compiler__ADeferredMethPropdef__can_inline(val* self) {
-short int var /* : Bool */;
-short int var1 /* : Bool */;
-var1 = abstract_compiler__ADeferredMethPropdef__can_inline(self);
+/* method abstract_compiler#AbstractCompilerVisitor#new_var_extern for (self: Object, MType): RuntimeVariable */
+val* VIRTUAL_abstract_compiler__AbstractCompilerVisitor__new_var_extern(val* self, val* p0) {
+val* var /* : RuntimeVariable */;
+val* var1 /* : RuntimeVariable */;
+var1 = abstract_compiler__AbstractCompilerVisitor__new_var_extern(self, p0);
 var = var1;
 RET_LABEL:;
 return var;
 }
-/* method abstract_compiler#AExpr#expr for (self: AExpr, AbstractCompilerVisitor): nullable RuntimeVariable */
-val* abstract_compiler__AExpr__expr(val* self, val* p0) {
-val* var /* : nullable RuntimeVariable */;
-val* var_v /* var v: AbstractCompilerVisitor */;
+/* method abstract_compiler#AbstractCompilerVisitor#new_named_var for (self: AbstractCompilerVisitor, MType, String): RuntimeVariable */
+val* abstract_compiler__AbstractCompilerVisitor__new_named_var(val* self, val* p0, val* p1) {
+val* var /* : RuntimeVariable */;
+val* var_mtype /* var mtype: MType */;
+val* var_name /* var name: String */;
+val* var1 /* : MType */;
+val* var2 /* : RuntimeVariable */;
+val* var_res /* var res: RuntimeVariable */;
+val* var3 /* : String */;
 static val* varonce;
-val* var1 /* : String */;
-char* var2 /* : NativeString */;
-long var3 /* : Int */;
 val* var4 /* : String */;
-val* var5 /* : String */;
-static val* varonce6;
-val* var7 /* : String */;
-char* var8 /* : NativeString */;
-long var9 /* : Int */;
-val* var10 /* : String */;
-val* var11 /* : Location */;
-val* var12 /* : String */;
+char* var5 /* : NativeString */;
+long var6 /* : Int */;
+val* var7 /* : FlatString */;
+static val* varonce8;
+val* var9 /* : String */;
+char* var10 /* : NativeString */;
+long var11 /* : Int */;
+val* var12 /* : FlatString */;
 static val* varonce13;
 val* var14 /* : String */;
 char* var15 /* : NativeString */;
 long var16 /* : Int */;
-val* var17 /* : String */;
+val* var17 /* : FlatString */;
 val* var18 /* : Array[Object] */;
 long var19 /* : Int */;
 val* var20 /* : NativeArray[Object] */;
 val* var21 /* : String */;
-val* var22 /* : nullable MType */;
-val* var_mtype /* var mtype: nullable MType */;
-val* var23 /* : null */;
-short int var24 /* : Bool */;
-val* var25 /* : null */;
-val* var26 /* : RuntimeVariable */;
-val* var_res /* var res: RuntimeVariable */;
-static val* varonce27;
-val* var28 /* : String */;
-char* var29 /* : NativeString */;
-long var30 /* : Int */;
-val* var31 /* : String */;
-static val* varonce32;
-val* var33 /* : String */;
-char* var34 /* : NativeString */;
-long var35 /* : Int */;
-val* var36 /* : String */;
-val* var37 /* : String */;
-static val* varonce38;
-val* var39 /* : String */;
-char* var40 /* : NativeString */;
-long var41 /* : Int */;
-val* var42 /* : String */;
-val* var43 /* : Array[Object] */;
-long var44 /* : Int */;
-val* var45 /* : NativeArray[Object] */;
-val* var46 /* : String */;
-var_v = p0;
+var_mtype = p0;
+var_name = p1;
+{
+var1 = abstract_compiler__AbstractCompilerVisitor__anchor(self, var_mtype);
+}
+var_mtype = var1;
+var2 = NEW_abstract_compiler__RuntimeVariable(&type_abstract_compiler__RuntimeVariable);
+{
+abstract_compiler__RuntimeVariable__init(var2, var_name, var_mtype, var_mtype); /* Direct call abstract_compiler#RuntimeVariable#init on <var2:RuntimeVariable>*/
+}
+var_res = var2;
+{
+var3 = ((val* (*)(val*))(var_mtype->class->vft[COLOR_abstract_compiler__MType__ctype]))(var_mtype) /* ctype on <var_mtype:MType>*/;
+}
 if (varonce) {
-var1 = varonce;
+var4 = varonce;
 } else {
-var2 = "printf(\"NOT YET IMPLEMENTED ";
-var3 = 28;
-var4 = string__NativeString__to_s_with_length(var2, var3);
-var1 = var4;
-varonce = var1;
+var5 = " ";
+var6 = 1;
+var7 = string__NativeString__to_s_with_length(var5, var6);
+var4 = var7;
+varonce = var4;
 }
-var5 = ((val* (*)(val*))(self->class->vft[COLOR_string__Object__class_name]))(self) /* class_name on <self:AExpr>*/;
-if (varonce6) {
-var7 = varonce6;
+if (varonce8) {
+var9 = varonce8;
 } else {
-var8 = ":";
-var9 = 1;
-var10 = string__NativeString__to_s_with_length(var8, var9);
-var7 = var10;
-varonce6 = var7;
+var10 = " /* : ";
+var11 = 6;
+var12 = string__NativeString__to_s_with_length(var10, var11);
+var9 = var12;
+varonce8 = var9;
 }
-var11 = ((val* (*)(val*))(self->class->vft[COLOR_parser_nodes__ANode__location]))(self) /* location on <self:AExpr>*/;
-var12 = ((val* (*)(val*))(var11->class->vft[COLOR_string__Object__to_s]))(var11) /* to_s on <var11:Location>*/;
 if (varonce13) {
 var14 = varonce13;
 } else {
-var15 = "\\n\");";
-var16 = 5;
+var15 = " */;";
+var16 = 4;
 var17 = string__NativeString__to_s_with_length(var15, var16);
 var14 = var17;
 varonce13 = var14;
 }
 var18 = NEW_array__Array(&type_array__Arraykernel__Object);
 { /* var18 = array_instance Array[Object] */
-var19 = 5;
+var19 = 6;
 var20 = NEW_array__NativeArray(var19, &type_array__NativeArraykernel__Object);
-((struct instance_array__NativeArray*)var20)->values[0] = (val*) var1;
-((struct instance_array__NativeArray*)var20)->values[1] = (val*) var5;
-((struct instance_array__NativeArray*)var20)->values[2] = (val*) var7;
-((struct instance_array__NativeArray*)var20)->values[3] = (val*) var12;
-((struct instance_array__NativeArray*)var20)->values[4] = (val*) var14;
+((struct instance_array__NativeArray*)var20)->values[0] = (val*) var3;
+((struct instance_array__NativeArray*)var20)->values[1] = (val*) var4;
+((struct instance_array__NativeArray*)var20)->values[2] = (val*) var_name;
+((struct instance_array__NativeArray*)var20)->values[3] = (val*) var9;
+((struct instance_array__NativeArray*)var20)->values[4] = (val*) var_mtype;
+((struct instance_array__NativeArray*)var20)->values[5] = (val*) var14;
+{
 ((void (*)(val*, val*, long))(var18->class->vft[COLOR_array__Array__with_native]))(var18, var20, var19) /* with_native on <var18:Array[Object]>*/;
-CHECK_NEW_array__Array(var18);
 }
+}
+{
 var21 = ((val* (*)(val*))(var18->class->vft[COLOR_string__Object__to_s]))(var18) /* to_s on <var18:Array[Object]>*/;
-((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(var_v, var21) /* add on <var_v:AbstractCompilerVisitor>*/;
-var22 = ((val* (*)(val*))(self->class->vft[COLOR_typing__AExpr__mtype]))(self) /* mtype on <self:AExpr>*/;
-var_mtype = var22;
-var23 = NULL;
-if (var_mtype == NULL) {
-var24 = 1; /* is null */
-} else {
-var24 = 0; /* arg is null but recv is not */
-}
-if (var24){
-var25 = NULL;
-var = var25;
-goto RET_LABEL;
-} else {
-var26 = ((val* (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__new_var]))(var_v, var_mtype) /* new_var on <var_v:AbstractCompilerVisitor>*/;
-var_res = var26;
-if (varonce27) {
-var28 = varonce27;
-} else {
-var29 = "/* ";
-var30 = 3;
-var31 = string__NativeString__to_s_with_length(var29, var30);
-var28 = var31;
-varonce27 = var28;
 }
-if (varonce32) {
-var33 = varonce32;
-} else {
-var34 = " = NOT YET ";
-var35 = 11;
-var36 = string__NativeString__to_s_with_length(var34, var35);
-var33 = var36;
-varonce32 = var33;
+{
+abstract_compiler__AbstractCompilerVisitor__add_decl(self, var21); /* Direct call abstract_compiler#AbstractCompilerVisitor#add_decl on <self:AbstractCompilerVisitor>*/
 }
-var37 = ((val* (*)(val*))(self->class->vft[COLOR_string__Object__class_name]))(self) /* class_name on <self:AExpr>*/;
-if (varonce38) {
-var39 = varonce38;
-} else {
-var40 = " */";
-var41 = 3;
-var42 = string__NativeString__to_s_with_length(var40, var41);
-var39 = var42;
-varonce38 = var39;
-}
-var43 = NEW_array__Array(&type_array__Arraykernel__Object);
-{ /* var43 = array_instance Array[Object] */
-var44 = 5;
-var45 = NEW_array__NativeArray(var44, &type_array__NativeArraykernel__Object);
-((struct instance_array__NativeArray*)var45)->values[0] = (val*) var28;
-((struct instance_array__NativeArray*)var45)->values[1] = (val*) var_res;
-((struct instance_array__NativeArray*)var45)->values[2] = (val*) var33;
-((struct instance_array__NativeArray*)var45)->values[3] = (val*) var37;
-((struct instance_array__NativeArray*)var45)->values[4] = (val*) var39;
-((void (*)(val*, val*, long))(var43->class->vft[COLOR_array__Array__with_native]))(var43, var45, var44) /* with_native on <var43:Array[Object]>*/;
-CHECK_NEW_array__Array(var43);
-}
-var46 = ((val* (*)(val*))(var43->class->vft[COLOR_string__Object__to_s]))(var43) /* to_s on <var43:Array[Object]>*/;
-((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(var_v, var46) /* add on <var_v:AbstractCompilerVisitor>*/;
 var = var_res;
 goto RET_LABEL;
-}
 RET_LABEL:;
 return var;
 }
-/* method abstract_compiler#AExpr#expr for (self: Object, AbstractCompilerVisitor): nullable RuntimeVariable */
-val* VIRTUAL_abstract_compiler__AExpr__expr(val* self, val* p0) {
-val* var /* : nullable RuntimeVariable */;
-val* var1 /* : nullable RuntimeVariable */;
-var1 = abstract_compiler__AExpr__expr(self, p0);
+/* method abstract_compiler#AbstractCompilerVisitor#new_named_var for (self: Object, MType, String): RuntimeVariable */
+val* VIRTUAL_abstract_compiler__AbstractCompilerVisitor__new_named_var(val* self, val* p0, val* p1) {
+val* var /* : RuntimeVariable */;
+val* var1 /* : RuntimeVariable */;
+var1 = abstract_compiler__AbstractCompilerVisitor__new_named_var(self, p0, p1);
 var = var1;
 RET_LABEL:;
 return var;
 }
-/* method abstract_compiler#AExpr#stmt for (self: AExpr, AbstractCompilerVisitor) */
-void abstract_compiler__AExpr__stmt(val* self, val* p0) {
-val* var_v /* var v: AbstractCompilerVisitor */;
-val* var /* : nullable RuntimeVariable */;
-val* var_res /* var res: nullable RuntimeVariable */;
-val* var1 /* : null */;
-short int var2 /* : Bool */;
+/* method abstract_compiler#AbstractCompilerVisitor#assign for (self: AbstractCompilerVisitor, RuntimeVariable, RuntimeVariable) */
+void abstract_compiler__AbstractCompilerVisitor__assign(val* self, val* p0, val* p1) {
+val* var_left /* var left: RuntimeVariable */;
+val* var_right /* var right: RuntimeVariable */;
+val* var /* : MType */;
+val* var2 /* : MType */;
+val* var3 /* : RuntimeVariable */;
 static val* varonce;
-val* var3 /* : String */;
-char* var4 /* : NativeString */;
-long var5 /* : Int */;
-val* var6 /* : String */;
-val* var7 /* : Array[Object] */;
-long var8 /* : Int */;
-val* var9 /* : NativeArray[Object] */;
-val* var10 /* : String */;
-var_v = p0;
-var = ((val* (*)(val*, val*))(self->class->vft[COLOR_abstract_compiler__AExpr__expr]))(self, var_v) /* expr on <self:AExpr>*/;
-var_res = var;
-var1 = NULL;
-if (var_res == NULL) {
-var2 = 0; /* is null */
-} else {
-var2 = 1; /* arg is null and recv is not */
+val* var4 /* : String */;
+char* var5 /* : NativeString */;
+long var6 /* : Int */;
+val* var7 /* : FlatString */;
+static val* varonce8;
+val* var9 /* : String */;
+char* var10 /* : NativeString */;
+long var11 /* : Int */;
+val* var12 /* : FlatString */;
+val* var13 /* : Array[Object] */;
+long var14 /* : Int */;
+val* var15 /* : NativeArray[Object] */;
+val* var16 /* : String */;
+var_left = p0;
+var_right = p1;
+{
+{ /* Inline abstract_compiler#RuntimeVariable#mtype (var_left) on <var_left:RuntimeVariable> */
+var2 = var_left->attrs[COLOR_abstract_compiler__RuntimeVariable___mtype].val; /* _mtype on <var_left:RuntimeVariable> */
+if (unlikely(var2 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _mtype");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 1634);
+show_backtrace(1);
 }
-if (var2){
+var = var2;
+RET_LABEL1:(void)0;
+}
+}
+{
+var3 = separate_compiler__SeparateCompilerVisitor__autobox(self, var_right, var);
+}
+var_right = var3;
 if (varonce) {
-var3 = varonce;
+var4 = varonce;
+} else {
+var5 = " = ";
+var6 = 3;
+var7 = string__NativeString__to_s_with_length(var5, var6);
+var4 = var7;
+varonce = var4;
+}
+if (varonce8) {
+var9 = varonce8;
+} else {
+var10 = ";";
+var11 = 1;
+var12 = string__NativeString__to_s_with_length(var10, var11);
+var9 = var12;
+varonce8 = var9;
+}
+var13 = NEW_array__Array(&type_array__Arraykernel__Object);
+{ /* var13 = array_instance Array[Object] */
+var14 = 4;
+var15 = NEW_array__NativeArray(var14, &type_array__NativeArraykernel__Object);
+((struct instance_array__NativeArray*)var15)->values[0] = (val*) var_left;
+((struct instance_array__NativeArray*)var15)->values[1] = (val*) var4;
+((struct instance_array__NativeArray*)var15)->values[2] = (val*) var_right;
+((struct instance_array__NativeArray*)var15)->values[3] = (val*) var9;
+{
+((void (*)(val*, val*, long))(var13->class->vft[COLOR_array__Array__with_native]))(var13, var15, var14) /* with_native on <var13:Array[Object]>*/;
+}
+}
+{
+var16 = ((val* (*)(val*))(var13->class->vft[COLOR_string__Object__to_s]))(var13) /* to_s on <var13:Array[Object]>*/;
+}
+{
+abstract_compiler__AbstractCompilerVisitor__add(self, var16); /* Direct call abstract_compiler#AbstractCompilerVisitor#add on <self:AbstractCompilerVisitor>*/
+}
+RET_LABEL:;
+}
+/* method abstract_compiler#AbstractCompilerVisitor#assign for (self: Object, RuntimeVariable, RuntimeVariable) */
+void VIRTUAL_abstract_compiler__AbstractCompilerVisitor__assign(val* self, val* p0, val* p1) {
+abstract_compiler__AbstractCompilerVisitor__assign(self, p0, p1); /* Direct call abstract_compiler#AbstractCompilerVisitor#assign on <self:Object(AbstractCompilerVisitor)>*/
+RET_LABEL:;
+}
+/* method abstract_compiler#AbstractCompilerVisitor#set_finalizer for (self: AbstractCompilerVisitor, RuntimeVariable) */
+void abstract_compiler__AbstractCompilerVisitor__set_finalizer(val* self, val* p0) {
+val* var_recv /* var recv: RuntimeVariable */;
+val* var /* : MType */;
+val* var2 /* : MType */;
+val* var_mtype /* var mtype: MType */;
+val* var3 /* : AbstractCompiler */;
+val* var5 /* : AbstractCompiler */;
+val* var6 /* : MModule */;
+val* var8 /* : MModule */;
+val* var9 /* : nullable MClassType */;
+val* var_finalizable_type /* var finalizable_type: nullable MClassType */;
+short int var10 /* : Bool */;
+short int var11 /* : Bool */;
+val* var12 /* : null */;
+short int var13 /* : Bool */;
+short int var14 /* : Bool */;
+val* var_other /* var other: nullable Object */;
+short int var16 /* : Bool */;
+short int var17 /* : Bool */;
+short int var18 /* : Bool */;
+short int var_ /* var : Bool */;
+short int var19 /* : Bool */;
+short int var20 /* : Bool */;
+short int var_21 /* var : Bool */;
+val* var22 /* : AbstractCompiler */;
+val* var24 /* : AbstractCompiler */;
+val* var25 /* : MModule */;
+val* var27 /* : MModule */;
+val* var28 /* : null */;
+short int var29 /* : Bool */;
+static val* varonce;
+val* var30 /* : String */;
+char* var31 /* : NativeString */;
+long var32 /* : Int */;
+val* var33 /* : FlatString */;
+static val* varonce34;
+val* var35 /* : String */;
+char* var36 /* : NativeString */;
+long var37 /* : Int */;
+val* var38 /* : FlatString */;
+val* var39 /* : Array[Object] */;
+long var40 /* : Int */;
+val* var41 /* : NativeArray[Object] */;
+val* var42 /* : String */;
+var_recv = p0;
+{
+{ /* Inline abstract_compiler#RuntimeVariable#mtype (var_recv) on <var_recv:RuntimeVariable> */
+var2 = var_recv->attrs[COLOR_abstract_compiler__RuntimeVariable___mtype].val; /* _mtype on <var_recv:RuntimeVariable> */
+if (unlikely(var2 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _mtype");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 1634);
+show_backtrace(1);
+}
+var = var2;
+RET_LABEL1:(void)0;
+}
+}
+var_mtype = var;
+{
+{ /* Inline abstract_compiler#AbstractCompilerVisitor#compiler (self) on <self:AbstractCompilerVisitor> */
+var5 = self->attrs[COLOR_abstract_compiler__AbstractCompilerVisitor___compiler].val; /* _compiler on <self:AbstractCompilerVisitor> */
+if (unlikely(var5 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _compiler");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 1041);
+show_backtrace(1);
+}
+var3 = var5;
+RET_LABEL4:(void)0;
+}
+}
+{
+{ /* Inline abstract_compiler#AbstractCompiler#mainmodule (var3) on <var3:AbstractCompiler> */
+var8 = var3->attrs[COLOR_abstract_compiler__AbstractCompiler___mainmodule].val; /* _mainmodule on <var3:AbstractCompiler> */
+if (unlikely(var8 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _mainmodule");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 463);
+show_backtrace(1);
+}
+var6 = var8;
+RET_LABEL7:(void)0;
+}
+}
+{
+var9 = model__MModule__finalizable_type(var6);
+}
+var_finalizable_type = var9;
+var12 = NULL;
+if (var_finalizable_type == NULL) {
+var13 = 0; /* is null */
+} else {
+var13 = 1; /* arg is null and recv is not */
+}
+if (0) {
+{ /* Inline kernel#Object#!= (var_finalizable_type,var12) on <var_finalizable_type:nullable MClassType> */
+var_other = var12;
+{
+var17 = ((short int (*)(val*, val*))(var_finalizable_type->class->vft[COLOR_kernel__Object___61d_61d]))(var_finalizable_type, var_other) /* == on <var_finalizable_type:nullable MClassType(MClassType)>*/;
+var16 = var17;
+}
+var18 = !var16;
+var14 = var18;
+goto RET_LABEL15;
+RET_LABEL15:(void)0;
+}
+var13 = var14;
+}
+var_ = var13;
+if (var13){
+{
+var19 = ((short int (*)(val*))(var_mtype->class->vft[COLOR_model__MType__need_anchor]))(var_mtype) /* need_anchor on <var_mtype:MType>*/;
+}
+var20 = !var19;
+var11 = var20;
 } else {
-var4 = ";";
-var5 = 1;
-var6 = string__NativeString__to_s_with_length(var4, var5);
-var3 = var6;
-varonce = var3;
+var11 = var_;
+}
+var_21 = var11;
+if (var11){
+{
+{ /* Inline abstract_compiler#AbstractCompilerVisitor#compiler (self) on <self:AbstractCompilerVisitor> */
+var24 = self->attrs[COLOR_abstract_compiler__AbstractCompilerVisitor___compiler].val; /* _compiler on <self:AbstractCompilerVisitor> */
+if (unlikely(var24 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _compiler");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 1041);
+show_backtrace(1);
 }
-var7 = NEW_array__Array(&type_array__Arraykernel__Object);
-{ /* var7 = array_instance Array[Object] */
-var8 = 2;
-var9 = NEW_array__NativeArray(var8, &type_array__NativeArraykernel__Object);
-((struct instance_array__NativeArray*)var9)->values[0] = (val*) var_res;
-((struct instance_array__NativeArray*)var9)->values[1] = (val*) var3;
-((void (*)(val*, val*, long))(var7->class->vft[COLOR_array__Array__with_native]))(var7, var9, var8) /* with_native on <var7:Array[Object]>*/;
-CHECK_NEW_array__Array(var7);
+var22 = var24;
+RET_LABEL23:(void)0;
 }
-var10 = ((val* (*)(val*))(var7->class->vft[COLOR_string__Object__to_s]))(var7) /* to_s on <var7:Array[Object]>*/;
-((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(var_v, var10) /* add on <var_v:AbstractCompilerVisitor>*/;
-} else {
 }
-RET_LABEL:;
+{
+{ /* Inline abstract_compiler#AbstractCompiler#mainmodule (var22) on <var22:AbstractCompiler> */
+var27 = var22->attrs[COLOR_abstract_compiler__AbstractCompiler___mainmodule].val; /* _mainmodule on <var22:AbstractCompiler> */
+if (unlikely(var27 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _mainmodule");
+PRINT_ERROR(" (%s:%d)\n", "compiler/abstract_compiler.nit", 463);
+show_backtrace(1);
 }
-/* method abstract_compiler#AExpr#stmt for (self: Object, AbstractCompilerVisitor) */
-void VIRTUAL_abstract_compiler__AExpr__stmt(val* self, val* p0) {
-abstract_compiler__AExpr__stmt(self, p0);
-RET_LABEL:;
+var25 = var27;
+RET_LABEL26:(void)0;
 }
-/* method abstract_compiler#ABlockExpr#stmt for (self: ABlockExpr, AbstractCompilerVisitor) */
-void abstract_compiler__ABlockExpr__stmt(val* self, val* p0) {
-val* var_v /* var v: AbstractCompilerVisitor */;
-val* var /* : ANodes[AExpr] */;
-val* var1 /* : Iterator[nullable Object] */;
-short int var2 /* : Bool */;
-val* var3 /* : nullable Object */;
-val* var_e /* var e: AExpr */;
-var_v = p0;
-var = ((val* (*)(val*))(self->class->vft[COLOR_parser_nodes__ABlockExpr__n_expr]))(self) /* n_expr on <self:ABlockExpr>*/;
-var1 = ((val* (*)(val*))(var->class->vft[COLOR_abstract_collection__Collection__iterator]))(var) /* iterator on <var:ANodes[AExpr]>*/;
-for(;;) {
-var2 = ((short int (*)(val*))(var1->class->vft[COLOR_abstract_collection__Iterator__is_ok]))(var1) /* is_ok on <var1:Iterator[nullable Object]>*/;
-if(!var2) break;
-var3 = ((val* (*)(val*))(var1->class->vft[COLOR_abstract_collection__Iterator__item]))(var1) /* item on <var1:Iterator[nullable Object]>*/;
-var_e = var3;
-((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__stmt]))(var_v, var_e) /* stmt on <var_v:AbstractCompilerVisitor>*/;
-CONTINUE_label: (void)0;
-((void (*)(val*))(var1->class->vft[COLOR_abstract_collection__Iterator__next]))(var1) /* next on <var1:Iterator[nullable Object]>*/;
 }
-BREAK_label: (void)0;
-RET_LABEL:;
+var28 = NULL;
+{
+var29 = model__MType__is_subtype(var_mtype, var25, var28, var_finalizable_type);
 }
-/* method abstract_compiler#ABlockExpr#stmt for (self: Object, AbstractCompilerVisitor) */
-void VIRTUAL_abstract_compiler__ABlockExpr__stmt(val* self, val* p0) {
-abstract_compiler__ABlockExpr__stmt(self, p0);
-RET_LABEL:;
+var10 = var29;
+} else {
+var10 = var_21;
 }
-/* method abstract_compiler#ABlockExpr#expr for (self: ABlockExpr, AbstractCompilerVisitor): nullable RuntimeVariable */
-val* abstract_compiler__ABlockExpr__expr(val* self, val* p0) {
-val* var /* : nullable RuntimeVariable */;
-val* var_v /* var v: AbstractCompilerVisitor */;
-val* var1 /* : ANodes[AExpr] */;
-val* var2 /* : nullable Object */;
-val* var_last /* var last: AExpr */;
-val* var3 /* : ANodes[AExpr] */;
-val* var4 /* : Iterator[nullable Object] */;
-short int var5 /* : Bool */;
-val* var6 /* : nullable Object */;
-val* var_e /* var e: AExpr */;
-short int var7 /* : Bool */;
-val* var8 /* : null */;
-val* var9 /* : RuntimeVariable */;
-var_v = p0;
-var1 = ((val* (*)(val*))(self->class->vft[COLOR_parser_nodes__ABlockExpr__n_expr]))(self) /* n_expr on <self:ABlockExpr>*/;
-var2 = ((val* (*)(val*))(var1->class->vft[COLOR_abstract_collection__SequenceRead__last]))(var1) /* last on <var1:ANodes[AExpr]>*/;
-var_last = var2;
-var3 = ((val* (*)(val*))(self->class->vft[COLOR_parser_nodes__ABlockExpr__n_expr]))(self) /* n_expr on <self:ABlockExpr>*/;
-var4 = ((val* (*)(val*))(var3->class->vft[COLOR_abstract_collection__Collection__iterator]))(var3) /* iterator on <var3:ANodes[AExpr]>*/;
-for(;;) {
-var5 = ((short int (*)(val*))(var4->class->vft[COLOR_abstract_collection__Iterator__is_ok]))(var4) /* is_ok on <var4:Iterator[nullable Object]>*/;
-if(!var5) break;
-var6 = ((val* (*)(val*))(var4->class->vft[COLOR_abstract_collection__Iterator__item]))(var4) /* item on <var4:Iterator[nullable Object]>*/;
-var_e = var6;
-var7 = ((short int (*)(val*, val*))(var_e->class->vft[COLOR_kernel__Object___61d_61d]))(var_e, var_last) /* == on <var_e:AExpr>*/;
-if (var7){
-goto BREAK_label;
+if (var10){
+if (varonce) {
+var30 = varonce;
 } else {
+var31 = "gc_register_finalizer(";
+var32 = 22;
+var33 = string__NativeString__to_s_with_length(var31, var32);
+var30 = var33;
+varonce = var30;
 }
-((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__stmt]))(var_v, var_e) /* stmt on <var_v:AbstractCompilerVisitor>*/;
-CONTINUE_label: (void)0;
-((void (*)(val*))(var4->class->vft[COLOR_abstract_collection__Iterator__next]))(var4) /* next on <var4:Iterator[nullable Object]>*/;
+if (varonce34) {
+var35 = varonce34;
+} else {
+var36 = ");";
+var37 = 2;
+var38 = string__NativeString__to_s_with_length(var36, var37);
+var35 = var38;
+varonce34 = var35;
 }
-BREAK_label: (void)0;
-var8 = NULL;
-var9 = ((val* (*)(val*, val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__expr]))(var_v, var_last, var8) /* expr on <var_v:AbstractCompilerVisitor>*/;
-var = var9;
-goto RET_LABEL;
-RET_LABEL:;
-return var;
+var39 = NEW_array__Array(&type_array__Arraykernel__Object);
+{ /* var39 = array_instance Array[Object] */
+var40 = 3;
+var41 = NEW_array__NativeArray(var40, &type_array__NativeArraykernel__Object);
+((struct instance_array__NativeArray*)var41)->values[0] = (val*) var30;
+((struct instance_array__NativeArray*)var41)->values[1] = (val*) var_recv;
+((struct instance_array__NativeArray*)var41)->values[2] = (val*) var35;
+{
+((void (*)(val*, val*, long))(var39->class->vft[COLOR_array__Array__with_native]))(var39, var41, var40) /* with_native on <var39:Array[Object]>*/;
 }
-/* method abstract_compiler#ABlockExpr#expr for (self: Object, AbstractCompilerVisitor): nullable RuntimeVariable */
-val* VIRTUAL_abstract_compiler__ABlockExpr__expr(val* self, val* p0) {
-val* var /* : nullable RuntimeVariable */;
-val* var1 /* : nullable RuntimeVariable */;
-var1 = abstract_compiler__ABlockExpr__expr(self, p0);
-var = var1;
-RET_LABEL:;
-return var;
 }
-/* method abstract_compiler#AVardeclExpr#stmt for (self: AVardeclExpr, AbstractCompilerVisitor) */
-void abstract_compiler__AVardeclExpr__stmt(val* self, val* p0) {
-val* var_v /* var v: AbstractCompilerVisitor */;
-val* var /* : nullable Variable */;
-val* var_variable /* var variable: Variable */;
-val* var1 /* : nullable AExpr */;
-val* var_ne /* var ne: nullable AExpr */;
-val* var2 /* : null */;
-short int var3 /* : Bool */;
-val* var4 /* : nullable MType */;
-val* var5 /* : RuntimeVariable */;
-val* var_i /* var i: RuntimeVariable */;
-val* var6 /* : RuntimeVariable */;
-var_v = p0;
-var = ((val* (*)(val*))(self->class->vft[COLOR_scope__AVardeclExpr__variable]))(self) /* variable on <self:AVardeclExpr>*/;
-if (var == NULL) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "src/abstract_compiler.nit", 1763);
-exit(1);
+{
+var42 = ((val* (*)(val*))(var39->class->vft[COLOR_string__Object__to_s]))(var39) /* to_s on <var39:Array[Object]>*/;
 }
-var_variable = var;
-var1 = ((val* (*)(val*))(self->class->vft[COLOR_parser_nodes__AVardeclExpr__n_expr]))(self) /* n_expr on <self:AVardeclExpr>*/;
-var_ne = var1;
-var2 = NULL;
-if (var_ne == NULL) {
-var3 = 0; /* is null */
-} else {
-var3 = 1; /* arg is null and recv is not */
+{
+abstract_compiler__AbstractCompilerVisitor__add(self, var42); /* Direct call abstract_compiler#AbstractCompilerVisitor#add on <self:AbstractCompilerVisitor>*/
 }
-if (var3){
-var4 = ((val* (*)(val*))(var_variable->class->vft[COLOR_typing__Variable__declared_type]))(var_variable) /* declared_type on <var_variable:Variable>*/;
-var5 = ((val* (*)(val*, val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__expr]))(var_v, var_ne, var4) /* expr on <var_v:AbstractCompilerVisitor>*/;
-var_i = var5;
-var6 = ((val* (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__variable]))(var_v, var_variable) /* variable on <var_v:AbstractCompilerVisitor>*/;
-((void (*)(val*, val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__assign]))(var_v, var6, var_i) /* assign on <var_v:AbstractCompilerVisitor>*/;
 } else {
 }
 RET_LABEL:;
 }
-/* method abstract_compiler#AVardeclExpr#stmt for (self: Object, AbstractCompilerVisitor) */
-void VIRTUAL_abstract_compiler__AVardeclExpr__stmt(val* self, val* p0) {
-abstract_compiler__AVardeclExpr__stmt(self, p0);
+/* method abstract_compiler#AbstractCompilerVisitor#set_finalizer for (self: Object, RuntimeVariable) */
+void VIRTUAL_abstract_compiler__AbstractCompilerVisitor__set_finalizer(val* self, val* p0) {
+abstract_compiler__AbstractCompilerVisitor__set_finalizer(self, p0); /* Direct call abstract_compiler#AbstractCompilerVisitor#set_finalizer on <self:Object(AbstractCompilerVisitor)>*/
 RET_LABEL:;
 }
-/* method abstract_compiler#AVarExpr#expr for (self: AVarExpr, AbstractCompilerVisitor): nullable RuntimeVariable */
-val* abstract_compiler__AVarExpr__expr(val* self, val* p0) {
-val* var /* : nullable RuntimeVariable */;
-val* var_v /* var v: AbstractCompilerVisitor */;
-val* var1 /* : nullable Variable */;
-val* var2 /* : RuntimeVariable */;
+/* method abstract_compiler#AbstractCompilerVisitor#int_instance for (self: AbstractCompilerVisitor, Int): RuntimeVariable */
+val* abstract_compiler__AbstractCompilerVisitor__int_instance(val* self, long p0) {
+val* var /* : RuntimeVariable */;
+long var_value /* var value: Int */;
+static val* varonce;
+val* var1 /* : String */;
+char* var2 /* : NativeString */;
+long var3 /* : Int */;
+val* var4 /* : FlatString */;
+val* var5 /* : MClass */;
+val* var6 /* : MClassType */;
+val* var8 /* : MClassType */;
+val* var9 /* : RuntimeVariable */;
 val* var_res /* var res: RuntimeVariable */;
-val* var3 /* : nullable MType */;
-val* var_mtype /* var mtype: MType */;
-val* var4 /* : RuntimeVariable */;
-var_v = p0;
-var1 = ((val* (*)(val*))(self->class->vft[COLOR_scope__AVarFormExpr__variable]))(self) /* variable on <self:AVarExpr>*/;
-if (var1 == NULL) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "src/abstract_compiler.nit", 1775);
-exit(1);
-}
-var2 = ((val* (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__variable]))(var_v, var1) /* variable on <var_v:AbstractCompilerVisitor>*/;
-var_res = var2;
-var3 = ((val* (*)(val*))(self->class->vft[COLOR_typing__AExpr__mtype]))(self) /* mtype on <self:AVarExpr>*/;
-if (var3 == NULL) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "src/abstract_compiler.nit", 1776);
-exit(1);
-}
-var_mtype = var3;
-var4 = ((val* (*)(val*, val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__autoadapt]))(var_v, var_res, var_mtype) /* autoadapt on <var_v:AbstractCompilerVisitor>*/;
-var = var4;
-goto RET_LABEL;
-RET_LABEL:;
-return var;
+static val* varonce10;
+val* var11 /* : String */;
+char* var12 /* : NativeString */;
+long var13 /* : Int */;
+val* var14 /* : FlatString */;
+static val* varonce15;
+val* var16 /* : String */;
+char* var17 /* : NativeString */;
+long var18 /* : Int */;
+val* var19 /* : FlatString */;
+val* var20 /* : Array[Object] */;
+long var21 /* : Int */;
+val* var22 /* : NativeArray[Object] */;
+val* var23 /* : Object */;
+val* var24 /* : String */;
+var_value = p0;
+if (varonce) {
+var1 = varonce;
+} else {
+var2 = "Int";
+var3 = 3;
+var4 = string__NativeString__to_s_with_length(var2, var3);
+var1 = var4;
+varonce = var1;
 }
-/* method abstract_compiler#AVarExpr#expr for (self: Object, AbstractCompilerVisitor): nullable RuntimeVariable */
-val* VIRTUAL_abstract_compiler__AVarExpr__expr(val* self, val* p0) {
-val* var /* : nullable RuntimeVariable */;
-val* var1 /* : nullable RuntimeVariable */;
-var1 = abstract_compiler__AVarExpr__expr(self, p0);
-var = var1;
-RET_LABEL:;
-return var;
+{
+var5 = abstract_compiler__AbstractCompilerVisitor__get_class(self, var1);
 }
-/* method abstract_compiler#AVarAssignExpr#stmt for (self: AVarAssignExpr, AbstractCompilerVisitor) */
-void abstract_compiler__AVarAssignExpr__stmt(val* self, val* p0) {
-val* var_v /* var v: AbstractCompilerVisitor */;
-val* var /* : nullable Variable */;
-val* var_variable /* var variable: Variable */;
-val* var1 /* : AExpr */;
-val* var2 /* : nullable MType */;
-val* var3 /* : RuntimeVariable */;
-val* var_i /* var i: RuntimeVariable */;
-val* var4 /* : RuntimeVariable */;
-var_v = p0;
-var = ((val* (*)(val*))(self->class->vft[COLOR_scope__AVarFormExpr__variable]))(self) /* variable on <self:AVarAssignExpr>*/;
-if (var == NULL) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "src/abstract_compiler.nit", 1784);
-exit(1);
-}
-var_variable = var;
-var1 = ((val* (*)(val*))(self->class->vft[COLOR_parser_nodes__AAssignFormExpr__n_value]))(self) /* n_value on <self:AVarAssignExpr>*/;
-var2 = ((val* (*)(val*))(var_variable->class->vft[COLOR_typing__Variable__declared_type]))(var_variable) /* declared_type on <var_variable:Variable>*/;
-var3 = ((val* (*)(val*, val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__expr]))(var_v, var1, var2) /* expr on <var_v:AbstractCompilerVisitor>*/;
-var_i = var3;
-var4 = ((val* (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__variable]))(var_v, var_variable) /* variable on <var_v:AbstractCompilerVisitor>*/;
-((void (*)(val*, val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__assign]))(var_v, var4, var_i) /* assign on <var_v:AbstractCompilerVisitor>*/;
-RET_LABEL:;
+{
+{ /* Inline model#MClass#mclass_type (var5) on <var5:MClass> */
+var8 = var5->attrs[COLOR_model__MClass___mclass_type].val; /* _mclass_type on <var5:MClass> */
+if (unlikely(var8 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _mclass_type");
+PRINT_ERROR(" (%s:%d)\n", "model/model.nit", 435);
+show_backtrace(1);
 }
-/* method abstract_compiler#AVarAssignExpr#stmt for (self: Object, AbstractCompilerVisitor) */
-void VIRTUAL_abstract_compiler__AVarAssignExpr__stmt(val* self, val* p0) {
-abstract_compiler__AVarAssignExpr__stmt(self, p0);
-RET_LABEL:;
+var6 = var8;
+RET_LABEL7:(void)0;
 }
-/* method abstract_compiler#AVarAssignExpr#expr for (self: AVarAssignExpr, AbstractCompilerVisitor): nullable RuntimeVariable */
-val* abstract_compiler__AVarAssignExpr__expr(val* self, val* p0) {
-val* var /* : nullable RuntimeVariable */;
-val* var_v /* var v: AbstractCompilerVisitor */;
-val* var1 /* : nullable Variable */;
-val* var_variable /* var variable: Variable */;
-val* var2 /* : AExpr */;
-val* var3 /* : nullable MType */;
-val* var4 /* : RuntimeVariable */;
-val* var_i /* var i: RuntimeVariable */;
-val* var5 /* : RuntimeVariable */;
-var_v = p0;
-var1 = ((val* (*)(val*))(self->class->vft[COLOR_scope__AVarFormExpr__variable]))(self) /* variable on <self:AVarAssignExpr>*/;
-if (var1 == NULL) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "src/abstract_compiler.nit", 1790);
-exit(1);
-}
-var_variable = var1;
-var2 = ((val* (*)(val*))(self->class->vft[COLOR_parser_nodes__AAssignFormExpr__n_value]))(self) /* n_value on <self:AVarAssignExpr>*/;
-var3 = ((val* (*)(val*))(var_variable->class->vft[COLOR_typing__Variable__declared_type]))(var_variable) /* declared_type on <var_variable:Variable>*/;
-var4 = ((val* (*)(val*, val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__expr]))(var_v, var2, var3) /* expr on <var_v:AbstractCompilerVisitor>*/;
-var_i = var4;
-var5 = ((val* (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__variable]))(var_v, var_variable) /* variable on <var_v:AbstractCompilerVisitor>*/;
-((void (*)(val*, val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__assign]))(var_v, var5, var_i) /* assign on <var_v:AbstractCompilerVisitor>*/;
-var = var_i;
-goto RET_LABEL;
-RET_LABEL:;
-return var;
 }
-/* method abstract_compiler#AVarAssignExpr#expr for (self: Object, AbstractCompilerVisitor): nullable RuntimeVariable */
-val* VIRTUAL_abstract_compiler__AVarAssignExpr__expr(val* self, val* p0) {
-val* var /* : nullable RuntimeVariable */;
-val* var1 /* : nullable RuntimeVariable */;
-var1 = abstract_compiler__AVarAssignExpr__expr(self, p0);
-var = var1;
-RET_LABEL:;
-return var;
+{
+var9 = abstract_compiler__AbstractCompilerVisitor__new_var(self, var6);
 }
-/* method abstract_compiler#AVarReassignExpr#stmt for (self: AVarReassignExpr, AbstractCompilerVisitor) */
-void abstract_compiler__AVarReassignExpr__stmt(val* self, val* p0) {
-val* var_v /* var v: AbstractCompilerVisitor */;
-val* var /* : nullable Variable */;
-val* var_variable /* var variable: Variable */;
-val* var1 /* : RuntimeVariable */;
-val* var_vari /* var vari: RuntimeVariable */;
-val* var2 /* : AExpr */;
-val* var3 /* : nullable MType */;
-val* var4 /* : RuntimeVariable */;
-val* var_value /* var value: RuntimeVariable */;
-val* var5 /* : nullable CallSite */;
-val* var6 /* : Array[RuntimeVariable] */;
-long var7 /* : Int */;
-val* var8 /* : NativeArray[RuntimeVariable] */;
-val* var9 /* : nullable RuntimeVariable */;
-val* var_res /* var res: nullable RuntimeVariable */;
-val* var10 /* : null */;
-short int var11 /* : Bool */;
-val* var12 /* : RuntimeVariable */;
-var_v = p0;
-var = ((val* (*)(val*))(self->class->vft[COLOR_scope__AVarFormExpr__variable]))(self) /* variable on <self:AVarReassignExpr>*/;
-if (var == NULL) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "src/abstract_compiler.nit", 1800);
-exit(1);
-}
-var_variable = var;
-var1 = ((val* (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__variable]))(var_v, var_variable) /* variable on <var_v:AbstractCompilerVisitor>*/;
-var_vari = var1;
-var2 = ((val* (*)(val*))(self->class->vft[COLOR_parser_nodes__AReassignFormExpr__n_value]))(self) /* n_value on <self:AVarReassignExpr>*/;
-var3 = ((val* (*)(val*))(var_variable->class->vft[COLOR_typing__Variable__declared_type]))(var_variable) /* declared_type on <var_variable:Variable>*/;
-var4 = ((val* (*)(val*, val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__expr]))(var_v, var2, var3) /* expr on <var_v:AbstractCompilerVisitor>*/;
-var_value = var4;
-var5 = ((val* (*)(val*))(self->class->vft[COLOR_typing__AReassignFormExpr__reassign_callsite]))(self) /* reassign_callsite on <self:AVarReassignExpr>*/;
-if (var5 == NULL) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "src/abstract_compiler.nit", 1803);
-exit(1);
-}
-var6 = NEW_array__Array(&type_array__Arrayabstract_compiler__RuntimeVariable);
-{ /* var6 = array_instance Array[RuntimeVariable] */
-var7 = 2;
-var8 = NEW_array__NativeArray(var7, &type_array__NativeArrayabstract_compiler__RuntimeVariable);
-((struct instance_array__NativeArray*)var8)->values[0] = (val*) var_vari;
-((struct instance_array__NativeArray*)var8)->values[1] = (val*) var_value;
-((void (*)(val*, val*, long))(var6->class->vft[COLOR_array__Array__with_native]))(var6, var8, var7) /* with_native on <var6:Array[RuntimeVariable]>*/;
-CHECK_NEW_array__Array(var6);
-}
-var9 = ((val* (*)(val*, val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__compile_callsite]))(var_v, var5, var6) /* compile_callsite on <var_v:AbstractCompilerVisitor>*/;
 var_res = var9;
-var10 = NULL;
-if (var_res == NULL) {
-var11 = 0; /* is null */
+if (varonce10) {
+var11 = varonce10;
+} else {
+var12 = " = ";
+var13 = 3;
+var14 = string__NativeString__to_s_with_length(var12, var13);
+var11 = var14;
+varonce10 = var11;
+}
+if (varonce15) {
+var16 = varonce15;
 } else {
-var11 = 1; /* arg is null and recv is not */
+var17 = ";";
+var18 = 1;
+var19 = string__NativeString__to_s_with_length(var17, var18);
+var16 = var19;
+varonce15 = var16;
 }
-if (!var11) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Assert failed", "src/abstract_compiler.nit", 1804);
-exit(1);
+var20 = NEW_array__Array(&type_array__Arraykernel__Object);
+{ /* var20 = array_instance Array[Object] */
+var21 = 4;
+var22 = NEW_array__NativeArray(var21, &type_array__NativeArraykernel__Object);
+((struct instance_array__NativeArray*)var22)->values[0] = (val*) var_res;
+((struct instance_array__NativeArray*)var22)->values[1] = (val*) var11;
+var23 = BOX_kernel__Int(var_value); /* autobox from Int to Object */
+((struct instance_array__NativeArray*)var22)->values[2] = (val*) var23;
+((struct instance_array__NativeArray*)var22)->values[3] = (val*) var16;
+{
+((void (*)(val*, val*, long))(var20->class->vft[COLOR_array__Array__with_native]))(var20, var22, var21) /* with_native on <var20:Array[Object]>*/;
 }
-var12 = ((val* (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__variable]))(var_v, var_variable) /* variable on <var_v:AbstractCompilerVisitor>*/;
-((void (*)(val*, val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__assign]))(var_v, var12, var_res) /* assign on <var_v:AbstractCompilerVisitor>*/;
-RET_LABEL:;
 }
-/* method abstract_compiler#AVarReassignExpr#stmt for (self: Object, AbstractCompilerVisitor) */
-void VIRTUAL_abstract_compiler__AVarReassignExpr__stmt(val* self, val* p0) {
-abstract_compiler__AVarReassignExpr__stmt(self, p0);
-RET_LABEL:;
+{
+var24 = ((val* (*)(val*))(var20->class->vft[COLOR_string__Object__to_s]))(var20) /* to_s on <var20:Array[Object]>*/;
 }
-/* method abstract_compiler#ASelfExpr#expr for (self: ASelfExpr, AbstractCompilerVisitor): nullable RuntimeVariable */
-val* abstract_compiler__ASelfExpr__expr(val* self, val* p0) {
-val* var /* : nullable RuntimeVariable */;
-val* var_v /* var v: AbstractCompilerVisitor */;
-val* var1 /* : nullable Frame */;
-val* var2 /* : Array[RuntimeVariable] */;
-val* var3 /* : nullable Object */;
-var_v = p0;
-var1 = ((val* (*)(val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__frame]))(var_v) /* frame on <var_v:AbstractCompilerVisitor>*/;
-if (var1 == NULL) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Reciever is null", "src/abstract_compiler.nit", 1810);
-exit(1);
-} else {
-var2 = ((val* (*)(val*))(var1->class->vft[COLOR_abstract_compiler__Frame__arguments]))(var1) /* arguments on <var1:nullable Frame>*/;
+{
+abstract_compiler__AbstractCompilerVisitor__add(self, var24); /* Direct call abstract_compiler#AbstractCompilerVisitor#add on <self:AbstractCompilerVisitor>*/
 }
-var3 = ((val* (*)(val*))(var2->class->vft[COLOR_abstract_collection__Collection__first]))(var2) /* first on <var2:Array[RuntimeVariable]>*/;
-var = var3;
+var = var_res;
 goto RET_LABEL;
 RET_LABEL:;
 return var;
 }
-/* method abstract_compiler#ASelfExpr#expr for (self: Object, AbstractCompilerVisitor): nullable RuntimeVariable */
-val* VIRTUAL_abstract_compiler__ASelfExpr__expr(val* self, val* p0) {
-val* var /* : nullable RuntimeVariable */;
-val* var1 /* : nullable RuntimeVariable */;
-var1 = abstract_compiler__ASelfExpr__expr(self, p0);
+/* method abstract_compiler#AbstractCompilerVisitor#int_instance for (self: Object, Int): RuntimeVariable */
+val* VIRTUAL_abstract_compiler__AbstractCompilerVisitor__int_instance(val* self, long p0) {
+val* var /* : RuntimeVariable */;
+val* var1 /* : RuntimeVariable */;
+var1 = abstract_compiler__AbstractCompilerVisitor__int_instance(self, p0);
 var = var1;
 RET_LABEL:;
 return var;
 }
-/* method abstract_compiler#AContinueExpr#stmt for (self: AContinueExpr, AbstractCompilerVisitor) */
-void abstract_compiler__AContinueExpr__stmt(val* self, val* p0) {
-val* var_v /* var v: AbstractCompilerVisitor */;
+/* method abstract_compiler#AbstractCompilerVisitor#bool_instance for (self: AbstractCompilerVisitor, Bool): RuntimeVariable */
+val* abstract_compiler__AbstractCompilerVisitor__bool_instance(val* self, short int p0) {
+val* var /* : RuntimeVariable */;
+short int var_value /* var value: Bool */;
 static val* varonce;
-val* var /* : String */;
-char* var1 /* : NativeString */;
-long var2 /* : Int */;
-val* var3 /* : String */;
-val* var4 /* : nullable EscapeMark */;
-val* var5 /* : String */;
-static val* varonce6;
-val* var7 /* : String */;
-char* var8 /* : NativeString */;
-long var9 /* : Int */;
-val* var10 /* : String */;
-val* var11 /* : Array[Object] */;
-long var12 /* : Int */;
-val* var13 /* : NativeArray[Object] */;
-val* var14 /* : String */;
-var_v = p0;
+val* var1 /* : String */;
+char* var2 /* : NativeString */;
+long var3 /* : Int */;
+val* var4 /* : FlatString */;
+val* var5 /* : MClass */;
+val* var6 /* : MClassType */;
+val* var8 /* : MClassType */;
+val* var9 /* : RuntimeVariable */;
+val* var_res /* var res: RuntimeVariable */;
+static val* varonce10;
+val* var11 /* : String */;
+char* var12 /* : NativeString */;
+long var13 /* : Int */;
+val* var14 /* : FlatString */;
+val* var15 /* : Array[Object] */;
+long var16 /* : Int */;
+val* var17 /* : NativeArray[Object] */;
+val* var18 /* : String */;
+static val* varonce19;
+val* var20 /* : String */;
+char* var21 /* : NativeString */;
+long var22 /* : Int */;
+val* var23 /* : FlatString */;
+val* var24 /* : Array[Object] */;
+long var25 /* : Int */;
+val* var26 /* : NativeArray[Object] */;
+val* var27 /* : String */;
+var_value = p0;
 if (varonce) {
-var = varonce;
+var1 = varonce;
 } else {
-var1 = "goto CONTINUE_";
-var2 = 14;
-var3 = string__NativeString__to_s_with_length(var1, var2);
-var = var3;
-varonce = var;
-}
-var4 = ((val* (*)(val*))(self->class->vft[COLOR_scope__AContinueExpr__escapemark]))(self) /* escapemark on <self:AContinueExpr>*/;
-var5 = ((val* (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__escapemark_name]))(var_v, var4) /* escapemark_name on <var_v:AbstractCompilerVisitor>*/;
-if (varonce6) {
-var7 = varonce6;
-} else {
-var8 = ";";
-var9 = 1;
-var10 = string__NativeString__to_s_with_length(var8, var9);
-var7 = var10;
-varonce6 = var7;
-}
-var11 = NEW_array__Array(&type_array__Arraykernel__Object);
-{ /* var11 = array_instance Array[Object] */
-var12 = 3;
-var13 = NEW_array__NativeArray(var12, &type_array__NativeArraykernel__Object);
-((struct instance_array__NativeArray*)var13)->values[0] = (val*) var;
-((struct instance_array__NativeArray*)var13)->values[1] = (val*) var5;
-((struct instance_array__NativeArray*)var13)->values[2] = (val*) var7;
-((void (*)(val*, val*, long))(var11->class->vft[COLOR_array__Array__with_native]))(var11, var13, var12) /* with_native on <var11:Array[Object]>*/;
-CHECK_NEW_array__Array(var11);
-}
-var14 = ((val* (*)(val*))(var11->class->vft[COLOR_string__Object__to_s]))(var11) /* to_s on <var11:Array[Object]>*/;
-((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(var_v, var14) /* add on <var_v:AbstractCompilerVisitor>*/;
-RET_LABEL:;
-}
-/* method abstract_compiler#AContinueExpr#stmt for (self: Object, AbstractCompilerVisitor) */
-void VIRTUAL_abstract_compiler__AContinueExpr__stmt(val* self, val* p0) {
-abstract_compiler__AContinueExpr__stmt(self, p0);
-RET_LABEL:;
+var2 = "Bool";
+var3 = 4;
+var4 = string__NativeString__to_s_with_length(var2, var3);
+var1 = var4;
+varonce = var1;
 }
-/* method abstract_compiler#ABreakExpr#stmt for (self: ABreakExpr, AbstractCompilerVisitor) */
-void abstract_compiler__ABreakExpr__stmt(val* self, val* p0) {
-val* var_v /* var v: AbstractCompilerVisitor */;
-static val* varonce;
-val* var /* : String */;
-char* var1 /* : NativeString */;
-long var2 /* : Int */;
-val* var3 /* : String */;
-val* var4 /* : nullable EscapeMark */;
-val* var5 /* : String */;
-static val* varonce6;
-val* var7 /* : String */;
-char* var8 /* : NativeString */;
-long var9 /* : Int */;
-val* var10 /* : String */;
-val* var11 /* : Array[Object] */;
-long var12 /* : Int */;
-val* var13 /* : NativeArray[Object] */;
-val* var14 /* : String */;
-var_v = p0;
-if (varonce) {
-var = varonce;
-} else {
-var1 = "goto BREAK_";
-var2 = 11;
-var3 = string__NativeString__to_s_with_length(var1, var2);
-var = var3;
-varonce = var;
-}
-var4 = ((val* (*)(val*))(self->class->vft[COLOR_scope__ABreakExpr__escapemark]))(self) /* escapemark on <self:ABreakExpr>*/;
-var5 = ((val* (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__escapemark_name]))(var_v, var4) /* escapemark_name on <var_v:AbstractCompilerVisitor>*/;
-if (varonce6) {
-var7 = varonce6;
-} else {
-var8 = ";";
-var9 = 1;
-var10 = string__NativeString__to_s_with_length(var8, var9);
-var7 = var10;
-varonce6 = var7;
-}
-var11 = NEW_array__Array(&type_array__Arraykernel__Object);
-{ /* var11 = array_instance Array[Object] */
-var12 = 3;
-var13 = NEW_array__NativeArray(var12, &type_array__NativeArraykernel__Object);
-((struct instance_array__NativeArray*)var13)->values[0] = (val*) var;
-((struct instance_array__NativeArray*)var13)->values[1] = (val*) var5;
-((struct instance_array__NativeArray*)var13)->values[2] = (val*) var7;
-((void (*)(val*, val*, long))(var11->class->vft[COLOR_array__Array__with_native]))(var11, var13, var12) /* with_native on <var11:Array[Object]>*/;
-CHECK_NEW_array__Array(var11);
-}
-var14 = ((val* (*)(val*))(var11->class->vft[COLOR_string__Object__to_s]))(var11) /* to_s on <var11:Array[Object]>*/;
-((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(var_v, var14) /* add on <var_v:AbstractCompilerVisitor>*/;
-RET_LABEL:;
+{
+var5 = abstract_compiler__AbstractCompilerVisitor__get_class(self, var1);
 }
-/* method abstract_compiler#ABreakExpr#stmt for (self: Object, AbstractCompilerVisitor) */
-void VIRTUAL_abstract_compiler__ABreakExpr__stmt(val* self, val* p0) {
-abstract_compiler__ABreakExpr__stmt(self, p0);
-RET_LABEL:;
+{
+{ /* Inline model#MClass#mclass_type (var5) on <var5:MClass> */
+var8 = var5->attrs[COLOR_model__MClass___mclass_type].val; /* _mclass_type on <var5:MClass> */
+if (unlikely(var8 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _mclass_type");
+PRINT_ERROR(" (%s:%d)\n", "model/model.nit", 435);
+show_backtrace(1);
 }
-/* method abstract_compiler#AReturnExpr#stmt for (self: AReturnExpr, AbstractCompilerVisitor) */
-void abstract_compiler__AReturnExpr__stmt(val* self, val* p0) {
-val* var_v /* var v: AbstractCompilerVisitor */;
-val* var /* : nullable AExpr */;
-val* var_nexpr /* var nexpr: nullable AExpr */;
-val* var1 /* : null */;
-short int var2 /* : Bool */;
-val* var3 /* : nullable Frame */;
-val* var4 /* : nullable RuntimeVariable */;
-val* var_returnvar /* var returnvar: RuntimeVariable */;
-val* var5 /* : MType */;
-val* var6 /* : RuntimeVariable */;
-val* var_i /* var i: RuntimeVariable */;
-static val* varonce;
-val* var7 /* : String */;
-char* var8 /* : NativeString */;
-long var9 /* : Int */;
-val* var10 /* : String */;
-val* var11 /* : nullable Frame */;
-val* var12 /* : nullable String */;
-static val* varonce13;
-val* var14 /* : String */;
-char* var15 /* : NativeString */;
-long var16 /* : Int */;
-val* var17 /* : String */;
-val* var18 /* : Array[Object] */;
-long var19 /* : Int */;
-val* var20 /* : NativeArray[Object] */;
-val* var21 /* : String */;
-var_v = p0;
-var = ((val* (*)(val*))(self->class->vft[COLOR_parser_nodes__AReturnExpr__n_expr]))(self) /* n_expr on <self:AReturnExpr>*/;
-var_nexpr = var;
-var1 = NULL;
-if (var_nexpr == NULL) {
-var2 = 0; /* is null */
-} else {
-var2 = 1; /* arg is null and recv is not */
+var6 = var8;
+RET_LABEL7:(void)0;
 }
-if (var2){
-var3 = ((val* (*)(val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__frame]))(var_v) /* frame on <var_v:AbstractCompilerVisitor>*/;
-if (var3 == NULL) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Reciever is null", "src/abstract_compiler.nit", 1826);
-exit(1);
-} else {
-var4 = ((val* (*)(val*))(var3->class->vft[COLOR_abstract_compiler__Frame__returnvar]))(var3) /* returnvar on <var3:nullable Frame>*/;
 }
-if (var4 == NULL) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "src/abstract_compiler.nit", 1826);
-exit(1);
+{
+var9 = abstract_compiler__AbstractCompilerVisitor__new_var(self, var6);
 }
-var_returnvar = var4;
-var5 = ((val* (*)(val*))(var_returnvar->class->vft[COLOR_abstract_compiler__RuntimeVariable__mtype]))(var_returnvar) /* mtype on <var_returnvar:RuntimeVariable>*/;
-var6 = ((val* (*)(val*, val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__expr]))(var_v, var_nexpr, var5) /* expr on <var_v:AbstractCompilerVisitor>*/;
-var_i = var6;
-((void (*)(val*, val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__assign]))(var_v, var_returnvar, var_i) /* assign on <var_v:AbstractCompilerVisitor>*/;
+var_res = var9;
+if (var_value){
+if (varonce10) {
+var11 = varonce10;
 } else {
+var12 = " = 1;";
+var13 = 5;
+var14 = string__NativeString__to_s_with_length(var12, var13);
+var11 = var14;
+varonce10 = var11;
 }
-if (varonce) {
-var7 = varonce;
-} else {
-var8 = "goto ";
-var9 = 5;
-var10 = string__NativeString__to_s_with_length(var8, var9);
-var7 = var10;
-varonce = var7;
+var15 = NEW_array__Array(&type_array__Arraykernel__Object);
+{ /* var15 = array_instance Array[Object] */
+var16 = 2;
+var17 = NEW_array__NativeArray(var16, &type_array__NativeArraykernel__Object);
+((struct instance_array__NativeArray*)var17)->values[0] = (val*) var_res;
+((struct instance_array__NativeArray*)var17)->values[1] = (val*) var11;
+{
+((void (*)(val*, val*, long))(var15->class->vft[COLOR_array__Array__with_native]))(var15, var17, var16) /* with_native on <var15:Array[Object]>*/;
 }
-var11 = ((val* (*)(val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__frame]))(var_v) /* frame on <var_v:AbstractCompilerVisitor>*/;
-if (var11 == NULL) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Reciever is null", "src/abstract_compiler.nit", 1830);
-exit(1);
-} else {
-var12 = ((val* (*)(val*))(var11->class->vft[COLOR_abstract_compiler__Frame__returnlabel]))(var11) /* returnlabel on <var11:nullable Frame>*/;
 }
-if (var12 == NULL) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "src/abstract_compiler.nit", 1830);
-exit(1);
+{
+var18 = ((val* (*)(val*))(var15->class->vft[COLOR_string__Object__to_s]))(var15) /* to_s on <var15:Array[Object]>*/;
+}
+{
+abstract_compiler__AbstractCompilerVisitor__add(self, var18); /* Direct call abstract_compiler#AbstractCompilerVisitor#add on <self:AbstractCompilerVisitor>*/
 }
-if (varonce13) {
-var14 = varonce13;
 } else {
-var15 = ";";
-var16 = 1;
-var17 = string__NativeString__to_s_with_length(var15, var16);
-var14 = var17;
-varonce13 = var14;
+if (varonce19) {
+var20 = varonce19;
+} else {
+var21 = " = 0;";
+var22 = 5;
+var23 = string__NativeString__to_s_with_length(var21, var22);
+var20 = var23;
+varonce19 = var20;
 }
-var18 = NEW_array__Array(&type_array__Arraykernel__Object);
-{ /* var18 = array_instance Array[Object] */
-var19 = 3;
-var20 = NEW_array__NativeArray(var19, &type_array__NativeArraykernel__Object);
-((struct instance_array__NativeArray*)var20)->values[0] = (val*) var7;
-((struct instance_array__NativeArray*)var20)->values[1] = (val*) var12;
-((struct instance_array__NativeArray*)var20)->values[2] = (val*) var14;
-((void (*)(val*, val*, long))(var18->class->vft[COLOR_array__Array__with_native]))(var18, var20, var19) /* with_native on <var18:Array[Object]>*/;
-CHECK_NEW_array__Array(var18);
+var24 = NEW_array__Array(&type_array__Arraykernel__Object);
+{ /* var24 = array_instance Array[Object] */
+var25 = 2;
+var26 = NEW_array__NativeArray(var25, &type_array__NativeArraykernel__Object);
+((struct instance_array__NativeArray*)var26)->values[0] = (val*) var_res;
+((struct instance_array__NativeArray*)var26)->values[1] = (val*) var20;
+{
+((void (*)(val*, val*, long))(var24->class->vft[COLOR_array__Array__with_native]))(var24, var26, var25) /* with_native on <var24:Array[Object]>*/;
 }
-var21 = ((val* (*)(val*))(var18->class->vft[COLOR_string__Object__to_s]))(var18) /* to_s on <var18:Array[Object]>*/;
-((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add]))(var_v, var21) /* add on <var_v:AbstractCompilerVisitor>*/;
-RET_LABEL:;
 }
-/* method abstract_compiler#AReturnExpr#stmt for (self: Object, AbstractCompilerVisitor) */
-void VIRTUAL_abstract_compiler__AReturnExpr__stmt(val* self, val* p0) {
-abstract_compiler__AReturnExpr__stmt(self, p0);
-RET_LABEL:;
+{
+var27 = ((val* (*)(val*))(var24->class->vft[COLOR_string__Object__to_s]))(var24) /* to_s on <var24:Array[Object]>*/;
+}
+{
+abstract_compiler__AbstractCompilerVisitor__add(self, var27); /* Direct call abstract_compiler#AbstractCompilerVisitor#add on <self:AbstractCompilerVisitor>*/
 }
-/* method abstract_compiler#AAbortExpr#stmt for (self: AAbortExpr, AbstractCompilerVisitor) */
-void abstract_compiler__AAbortExpr__stmt(val* self, val* p0) {
-val* var_v /* var v: AbstractCompilerVisitor */;
-static val* varonce;
-val* var /* : String */;
-char* var1 /* : NativeString */;
-long var2 /* : Int */;
-val* var3 /* : String */;
-var_v = p0;
-if (varonce) {
-var = varonce;
-} else {
-var1 = "Aborted";
-var2 = 7;
-var3 = string__NativeString__to_s_with_length(var1, var2);
-var = var3;
-varonce = var;
 }
-((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add_abort]))(var_v, var) /* add_abort on <var_v:AbstractCompilerVisitor>*/;
+var = var_res;
+goto RET_LABEL;
 RET_LABEL:;
+return var;
 }
-/* method abstract_compiler#AAbortExpr#stmt for (self: Object, AbstractCompilerVisitor) */
-void VIRTUAL_abstract_compiler__AAbortExpr__stmt(val* self, val* p0) {
-abstract_compiler__AAbortExpr__stmt(self, p0);
+/* method abstract_compiler#AbstractCompilerVisitor#bool_instance for (self: Object, Bool): RuntimeVariable */
+val* VIRTUAL_abstract_compiler__AbstractCompilerVisitor__bool_instance(val* self, short int p0) {
+val* var /* : RuntimeVariable */;
+val* var1 /* : RuntimeVariable */;
+var1 = abstract_compiler__AbstractCompilerVisitor__bool_instance(self, p0);
+var = var1;
 RET_LABEL:;
+return var;
 }