c_src: Fix uname in Makefile
[nit.git] / c_src / abstract_compiler.sep.2.c
index 802a1b6..791349f 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 */
-} else {
-var2 = 0; /* arg is null but recv is not */
+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* var122 /* : ArrayIterator[nullable Object] */;
+short int var123 /* : Bool */;
+val* var124 /* : nullable Object */;
+val* var_tag /* var tag: String */;
+static val* varonce125;
+val* var126 /* : String */;
+char* var127 /* : NativeString */;
+long var128 /* : Int */;
+val* var129 /* : FlatString */;
+static val* varonce130;
+val* var131 /* : String */;
+char* var132 /* : NativeString */;
+long var133 /* : Int */;
+val* var134 /* : FlatString */;
+val* var135 /* : Array[Object] */;
+long var136 /* : Int */;
+val* var137 /* : NativeArray[Object] */;
+val* var138 /* : String */;
+static val* varonce139;
+val* var140 /* : String */;
+char* var141 /* : NativeString */;
+long var142 /* : Int */;
+val* var143 /* : FlatString */;
+static val* varonce144;
+val* var145 /* : String */;
+char* var146 /* : NativeString */;
+long var147 /* : Int */;
+val* var148 /* : FlatString */;
+val* var149 /* : Array[Object] */;
+long var150 /* : Int */;
+val* var151 /* : NativeArray[Object] */;
+val* var152 /* : String */;
+static val* varonce153;
+val* var154 /* : String */;
+char* var155 /* : NativeString */;
+long var156 /* : Int */;
+val* var157 /* : FlatString */;
+static val* varonce158;
+val* var159 /* : String */;
+char* var160 /* : NativeString */;
+long var161 /* : Int */;
+val* var162 /* : FlatString */;
+val* var163 /* : Array[Object] */;
+long var164 /* : Int */;
+val* var165 /* : NativeArray[Object] */;
+val* var166 /* : String */;
+val* var167 /* : AbstractCompiler */;
+val* var169 /* : AbstractCompiler */;
+val* var170 /* : CodeWriter */;
+val* var172 /* : CodeWriter */;
+static val* varonce173;
+val* var174 /* : String */;
+char* var175 /* : NativeString */;
+long var176 /* : Int */;
+val* var177 /* : FlatString */;
+static val* varonce178;
+val* var179 /* : String */;
+char* var180 /* : NativeString */;
+long var181 /* : Int */;
+val* var182 /* : FlatString */;
+val* var183 /* : Array[Object] */;
+long var184 /* : Int */;
+val* var185 /* : NativeArray[Object] */;
+val* var186 /* : String */;
+val* var187 /* : AbstractCompiler */;
+val* var189 /* : AbstractCompiler */;
+val* var190 /* : CodeWriter */;
+val* var192 /* : CodeWriter */;
+static val* varonce193;
+val* var194 /* : String */;
+char* var195 /* : NativeString */;
+long var196 /* : Int */;
+val* var197 /* : FlatString */;
+static val* varonce198;
+val* var199 /* : String */;
+char* var200 /* : NativeString */;
+long var201 /* : Int */;
+val* var202 /* : FlatString */;
+val* var203 /* : Array[Object] */;
+long var204 /* : Int */;
+val* var205 /* : NativeArray[Object] */;
+val* var206 /* : String */;
+val* var207 /* : AbstractCompiler */;
+val* var209 /* : AbstractCompiler */;
+val* var210 /* : CodeWriter */;
+val* var212 /* : CodeWriter */;
+static val* varonce213;
+val* var214 /* : String */;
+char* var215 /* : NativeString */;
+long var216 /* : Int */;
+val* var217 /* : FlatString */;
+static val* varonce218;
+val* var219 /* : String */;
+char* var220 /* : NativeString */;
+long var221 /* : Int */;
+val* var222 /* : FlatString */;
+val* var223 /* : Array[Object] */;
+long var224 /* : Int */;
+val* var225 /* : NativeArray[Object] */;
+val* var226 /* : String */;
+val* var227 /* : ModelBuilder */;
+val* var229 /* : ModelBuilder */;
+val* var230 /* : ToolContext */;
+val* var232 /* : ToolContext */;
+val* var233 /* : OptionBool */;
+val* var235 /* : OptionBool */;
+val* var236 /* : nullable Object */;
+val* var238 /* : nullable Object */;
+short int var239 /* : Bool */;
+static val* varonce240;
+val* var241 /* : String */;
+char* var242 /* : NativeString */;
+long var243 /* : Int */;
+val* var244 /* : FlatString */;
+static val* varonce245;
+val* var246 /* : String */;
+char* var247 /* : NativeString */;
+long var248 /* : Int */;
+val* var249 /* : FlatString */;
+static val* varonce250;
+val* var251 /* : String */;
+char* var252 /* : NativeString */;
+long var253 /* : Int */;
+val* var254 /* : FlatString */;
+val* var255 /* : AbstractCompiler */;
+val* var257 /* : AbstractCompiler */;
+val* var258 /* : CodeWriter */;
+val* var260 /* : CodeWriter */;
+static val* varonce261;
+val* var262 /* : String */;
+char* var263 /* : NativeString */;
+long var264 /* : Int */;
+val* var265 /* : FlatString */;
+val* var266 /* : AbstractCompiler */;
+val* var268 /* : AbstractCompiler */;
+val* var269 /* : CodeWriter */;
+val* var271 /* : CodeWriter */;
+static val* varonce272;
+val* var273 /* : String */;
+char* var274 /* : NativeString */;
+long var275 /* : Int */;
+val* var276 /* : FlatString */;
+val* var277 /* : AbstractCompiler */;
+val* var279 /* : AbstractCompiler */;
+val* var280 /* : CodeWriter */;
+val* var282 /* : CodeWriter */;
+static val* varonce283;
+val* var284 /* : String */;
+char* var285 /* : NativeString */;
+long var286 /* : Int */;
+val* var287 /* : FlatString */;
+val* var288 /* : ModelBuilder */;
+val* var290 /* : ModelBuilder */;
+val* var291 /* : ToolContext */;
+val* var293 /* : ToolContext */;
+val* var294 /* : OptionBool */;
+val* var296 /* : OptionBool */;
+val* var297 /* : nullable Object */;
+val* var299 /* : nullable Object */;
+short int var300 /* : Bool */;
+static val* varonce301;
+val* var302 /* : String */;
+char* var303 /* : NativeString */;
+long var304 /* : Int */;
+val* var305 /* : FlatString */;
+static val* varonce306;
+val* var307 /* : String */;
+char* var308 /* : NativeString */;
+long var309 /* : Int */;
+val* var310 /* : FlatString */;
+val* var311 /* : AbstractCompiler */;
+val* var313 /* : AbstractCompiler */;
+val* var314 /* : CodeWriter */;
+val* var316 /* : CodeWriter */;
+static val* varonce317;
+val* var318 /* : String */;
+char* var319 /* : NativeString */;
+long var320 /* : Int */;
+val* var321 /* : FlatString */;
+val* var322 /* : AbstractCompiler */;
+val* var324 /* : AbstractCompiler */;
+val* var325 /* : CodeWriter */;
+val* var327 /* : CodeWriter */;
+static val* varonce328;
+val* var329 /* : String */;
+char* var330 /* : NativeString */;
+long var331 /* : Int */;
+val* var332 /* : FlatString */;
+static val* varonce333;
+val* var334 /* : String */;
+char* var335 /* : NativeString */;
+long var336 /* : Int */;
+val* var337 /* : FlatString */;
+static val* varonce338;
+val* var339 /* : String */;
+char* var340 /* : NativeString */;
+long var341 /* : Int */;
+val* var342 /* : FlatString */;
+static val* varonce343;
+val* var344 /* : String */;
+char* var345 /* : NativeString */;
+long var346 /* : Int */;
+val* var347 /* : FlatString */;
+static val* varonce348;
+val* var349 /* : String */;
+char* var350 /* : NativeString */;
+long var351 /* : Int */;
+val* var352 /* : FlatString */;
+static val* varonce353;
+val* var354 /* : String */;
+char* var355 /* : NativeString */;
+long var356 /* : Int */;
+val* var357 /* : FlatString */;
+short int var358 /* : Bool */;
+static val* varonce359;
+val* var360 /* : String */;
+char* var361 /* : NativeString */;
+long var362 /* : Int */;
+val* var363 /* : FlatString */;
+short int var364 /* : Bool */;
+short int var365 /* : Bool */;
+short int var_366 /* var : Bool */;
+static val* varonce367;
+val* var368 /* : String */;
+char* var369 /* : NativeString */;
+long var370 /* : Int */;
+val* var371 /* : FlatString */;
+short int var372 /* : Bool */;
+short int var373 /* : Bool */;
+static val* varonce374;
+val* var375 /* : String */;
+char* var376 /* : NativeString */;
+long var377 /* : Int */;
+val* var378 /* : FlatString */;
+static val* varonce379;
+val* var380 /* : String */;
+char* var381 /* : NativeString */;
+long var382 /* : Int */;
+val* var383 /* : FlatString */;
+static val* varonce384;
+val* var385 /* : String */;
+char* var386 /* : NativeString */;
+long var387 /* : Int */;
+val* var388 /* : FlatString */;
+static val* varonce389;
+val* var390 /* : String */;
+char* var391 /* : NativeString */;
+long var392 /* : Int */;
+val* var393 /* : FlatString */;
+static val* varonce394;
+val* var395 /* : String */;
+char* var396 /* : NativeString */;
+long var397 /* : Int */;
+val* var398 /* : FlatString */;
+static val* varonce399;
+val* var400 /* : String */;
+char* var401 /* : NativeString */;
+long var402 /* : Int */;
+val* var403 /* : FlatString */;
+static val* varonce404;
+val* var405 /* : String */;
+char* var406 /* : NativeString */;
+long var407 /* : Int */;
+val* var408 /* : FlatString */;
+static val* varonce409;
+val* var410 /* : String */;
+char* var411 /* : NativeString */;
+long var412 /* : Int */;
+val* var413 /* : FlatString */;
+static val* varonce414;
+val* var415 /* : String */;
+char* var416 /* : NativeString */;
+long var417 /* : Int */;
+val* var418 /* : FlatString */;
+static val* varonce419;
+val* var420 /* : String */;
+char* var421 /* : NativeString */;
+long var422 /* : Int */;
+val* var423 /* : FlatString */;
+static val* varonce424;
+val* var425 /* : String */;
+char* var426 /* : NativeString */;
+long var427 /* : Int */;
+val* var428 /* : FlatString */;
+static val* varonce429;
+val* var430 /* : String */;
+char* var431 /* : NativeString */;
+long var432 /* : Int */;
+val* var433 /* : FlatString */;
+static val* varonce434;
+val* var435 /* : String */;
+char* var436 /* : NativeString */;
+long var437 /* : Int */;
+val* var438 /* : FlatString */;
+static val* varonce439;
+val* var440 /* : String */;
+char* var441 /* : NativeString */;
+long var442 /* : Int */;
+val* var443 /* : FlatString */;
+short int var444 /* : Bool */;
+short int var445 /* : Bool */;
+static val* varonce446;
+val* var447 /* : String */;
+char* var448 /* : NativeString */;
+long var449 /* : Int */;
+val* var450 /* : FlatString */;
+static val* varonce451;
+val* var452 /* : String */;
+char* var453 /* : NativeString */;
+long var454 /* : Int */;
+val* var455 /* : FlatString */;
+static val* varonce456;
+val* var457 /* : String */;
+char* var458 /* : NativeString */;
+long var459 /* : Int */;
+val* var460 /* : FlatString */;
+static val* varonce461;
+val* var462 /* : String */;
+char* var463 /* : NativeString */;
+long var464 /* : Int */;
+val* var465 /* : FlatString */;
+static val* varonce466;
+val* var467 /* : String */;
+char* var468 /* : NativeString */;
+long var469 /* : Int */;
+val* var470 /* : FlatString */;
+static val* varonce471;
+val* var472 /* : String */;
+char* var473 /* : NativeString */;
+long var474 /* : Int */;
+val* var475 /* : FlatString */;
+static val* varonce476;
+val* var477 /* : String */;
+char* var478 /* : NativeString */;
+long var479 /* : Int */;
+val* var480 /* : FlatString */;
+static val* varonce481;
+val* var482 /* : String */;
+char* var483 /* : NativeString */;
+long var484 /* : Int */;
+val* var485 /* : FlatString */;
+static val* varonce486;
+val* var487 /* : String */;
+char* var488 /* : NativeString */;
+long var489 /* : Int */;
+val* var490 /* : FlatString */;
+static val* varonce491;
+val* var492 /* : String */;
+char* var493 /* : NativeString */;
+long var494 /* : Int */;
+val* var495 /* : FlatString */;
+static val* varonce496;
+val* var497 /* : String */;
+char* var498 /* : NativeString */;
+long var499 /* : Int */;
+val* var500 /* : FlatString */;
+static val* varonce501;
+val* var502 /* : String */;
+char* var503 /* : NativeString */;
+long var504 /* : Int */;
+val* var505 /* : FlatString */;
+static val* varonce506;
+val* var507 /* : String */;
+char* var508 /* : NativeString */;
+long var509 /* : Int */;
+val* var510 /* : FlatString */;
+static val* varonce511;
+val* var512 /* : String */;
+char* var513 /* : NativeString */;
+long var514 /* : Int */;
+val* var515 /* : FlatString */;
+static val* varonce516;
+val* var517 /* : String */;
+char* var518 /* : NativeString */;
+long var519 /* : Int */;
+val* var520 /* : FlatString */;
+static val* varonce521;
+val* var522 /* : String */;
+char* var523 /* : NativeString */;
+long var524 /* : Int */;
+val* var525 /* : FlatString */;
+static val* varonce526;
+val* var527 /* : String */;
+char* var528 /* : NativeString */;
+long var529 /* : Int */;
+val* var530 /* : FlatString */;
+static val* varonce531;
+val* var532 /* : String */;
+char* var533 /* : NativeString */;
+long var534 /* : Int */;
+val* var535 /* : FlatString */;
+static val* varonce536;
+val* var537 /* : String */;
+char* var538 /* : NativeString */;
+long var539 /* : Int */;
+val* var540 /* : FlatString */;
+static val* varonce541;
+val* var542 /* : String */;
+char* var543 /* : NativeString */;
+long var544 /* : Int */;
+val* var545 /* : FlatString */;
+static val* varonce546;
+val* var547 /* : String */;
+char* var548 /* : NativeString */;
+long var549 /* : Int */;
+val* var550 /* : FlatString */;
+static val* varonce551;
+val* var552 /* : String */;
+char* var553 /* : NativeString */;
+long var554 /* : Int */;
+val* var555 /* : FlatString */;
+static val* varonce556;
+val* var557 /* : String */;
+char* var558 /* : NativeString */;
+long var559 /* : Int */;
+val* var560 /* : FlatString */;
+static val* varonce561;
+val* var562 /* : String */;
+char* var563 /* : NativeString */;
+long var564 /* : Int */;
+val* var565 /* : FlatString */;
+static val* varonce566;
+val* var567 /* : String */;
+char* var568 /* : NativeString */;
+long var569 /* : Int */;
+val* var570 /* : FlatString */;
+val* var571 /* : MModule */;
+val* var573 /* : MModule */;
+val* var574 /* : nullable MClassType */;
+val* var_main_type /* var main_type: nullable MClassType */;
+val* var575 /* : null */;
+short int var576 /* : Bool */;
+short int var577 /* : Bool */;
+val* var_other /* var other: nullable Object */;
+short int var579 /* : Bool */;
+short int var580 /* : Bool */;
+short int var581 /* : Bool */;
+val* var582 /* : AbstractCompiler */;
+val* var584 /* : AbstractCompiler */;
+val* var585 /* : MModule */;
+val* var587 /* : MModule */;
+val* var_mainmodule /* var mainmodule: MModule */;
+val* var588 /* : RuntimeVariable */;
+val* var_glob_sys /* var glob_sys: RuntimeVariable */;
+static val* varonce589;
+val* var590 /* : String */;
+char* var591 /* : NativeString */;
+long var592 /* : Int */;
+val* var593 /* : FlatString */;
+static val* varonce594;
+val* var595 /* : String */;
+char* var596 /* : NativeString */;
+long var597 /* : Int */;
+val* var598 /* : FlatString */;
+val* var599 /* : Array[Object] */;
+long var600 /* : Int */;
+val* var601 /* : NativeArray[Object] */;
+val* var602 /* : String */;
+static val* varonce603;
+val* var604 /* : String */;
+char* var605 /* : NativeString */;
+long var606 /* : Int */;
+val* var607 /* : FlatString */;
+val* var608 /* : MClass */;
+val* var610 /* : MClass */;
+val* var611 /* : nullable MMethod */;
+val* var_main_init /* var main_init: nullable MMethod */;
+val* var612 /* : null */;
+short int var613 /* : Bool */;
+short int var614 /* : Bool */;
+short int var616 /* : Bool */;
+short int var617 /* : Bool */;
+short int var618 /* : Bool */;
+val* var619 /* : Array[RuntimeVariable] */;
+long var620 /* : Int */;
+val* var_621 /* var : Array[RuntimeVariable] */;
+val* var622 /* : nullable RuntimeVariable */;
+static val* varonce623;
+val* var624 /* : String */;
+char* var625 /* : NativeString */;
+long var626 /* : Int */;
+val* var627 /* : FlatString */;
+val* var628 /* : MClass */;
+val* var630 /* : MClass */;
+val* var631 /* : nullable MMethod */;
+val* var_main_method /* var main_method: nullable MMethod */;
+val* var632 /* : null */;
+short int var633 /* : Bool */;
+short int var634 /* : Bool */;
+short int var636 /* : Bool */;
+short int var637 /* : Bool */;
+short int var638 /* : Bool */;
+val* var639 /* : Array[RuntimeVariable] */;
+long var640 /* : Int */;
+val* var_641 /* var : Array[RuntimeVariable] */;
+val* var642 /* : nullable RuntimeVariable */;
+val* var643 /* : ModelBuilder */;
+val* var645 /* : ModelBuilder */;
+val* var646 /* : ToolContext */;
+val* var648 /* : ToolContext */;
+val* var649 /* : OptionBool */;
+val* var651 /* : OptionBool */;
+val* var652 /* : nullable Object */;
+val* var654 /* : nullable Object */;
+short int var655 /* : Bool */;
+static val* varonce656;
+val* var657 /* : String */;
+char* var658 /* : NativeString */;
+long var659 /* : Int */;
+val* var660 /* : FlatString */;
+static val* varonce661;
+val* var662 /* : String */;
+char* var663 /* : NativeString */;
+long var664 /* : Int */;
+val* var665 /* : FlatString */;
+static val* varonce666;
+val* var667 /* : String */;
+char* var668 /* : NativeString */;
+long var669 /* : Int */;
+val* var670 /* : FlatString */;
+static val* varonce671;
+val* var672 /* : String */;
+char* var673 /* : NativeString */;
+long var674 /* : Int */;
+val* var675 /* : FlatString */;
+val* var676 /* : Array[String] */;
+val* var678 /* : Array[String] */;
+val* var679 /* : ArrayIterator[nullable Object] */;
+short int var680 /* : Bool */;
+val* var681 /* : nullable Object */;
+val* var_tag682 /* var tag: String */;
+static val* varonce683;
+val* var684 /* : String */;
+char* var685 /* : NativeString */;
+long var686 /* : Int */;
+val* var687 /* : FlatString */;
+static val* varonce688;
+val* var689 /* : String */;
+char* var690 /* : NativeString */;
+long var691 /* : Int */;
+val* var692 /* : FlatString */;
+val* var693 /* : Array[Object] */;
+long var694 /* : Int */;
+val* var695 /* : NativeArray[Object] */;
+val* var696 /* : String */;
+static val* varonce697;
+val* var698 /* : String */;
+char* var699 /* : NativeString */;
+long var700 /* : Int */;
+val* var701 /* : FlatString */;
+static val* varonce702;
+val* var703 /* : String */;
+char* var704 /* : NativeString */;
+long var705 /* : Int */;
+val* var706 /* : FlatString */;
+static val* varonce707;
+val* var708 /* : String */;
+char* var709 /* : NativeString */;
+long var710 /* : Int */;
+val* var711 /* : FlatString */;
+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 */;
+val* var722 /* : Array[Object] */;
+long var723 /* : Int */;
+val* var724 /* : NativeArray[Object] */;
+val* var725 /* : String */;
+static val* varonce726;
+val* var727 /* : String */;
+char* var728 /* : NativeString */;
+long var729 /* : Int */;
+val* var730 /* : FlatString */;
+static val* varonce731;
+val* var732 /* : String */;
+char* var733 /* : NativeString */;
+long var734 /* : Int */;
+val* var735 /* : FlatString */;
+val* var736 /* : Array[Object] */;
+long var737 /* : Int */;
+val* var738 /* : NativeArray[Object] */;
+val* var739 /* : String */;
+static val* varonce740;
+val* var741 /* : String */;
+char* var742 /* : NativeString */;
+long var743 /* : Int */;
+val* var744 /* : FlatString */;
+static val* varonce745;
+val* var746 /* : String */;
+char* var747 /* : NativeString */;
+long var748 /* : Int */;
+val* var749 /* : FlatString */;
+val* var750 /* : Array[Object] */;
+long var751 /* : Int */;
+val* var752 /* : NativeArray[Object] */;
+val* var753 /* : String */;
+static val* varonce754;
+val* var755 /* : String */;
+char* var756 /* : NativeString */;
+long var757 /* : Int */;
+val* var758 /* : FlatString */;
+static val* varonce759;
+val* var760 /* : String */;
+char* var761 /* : NativeString */;
+long var762 /* : Int */;
+val* var763 /* : FlatString */;
+val* var764 /* : Array[Object] */;
+long var765 /* : Int */;
+val* var766 /* : NativeArray[Object] */;
+val* var767 /* : String */;
+static val* varonce768;
+val* var769 /* : String */;
+char* var770 /* : NativeString */;
+long var771 /* : Int */;
+val* var772 /* : FlatString */;
+static val* varonce773;
+val* var774 /* : String */;
+char* var775 /* : NativeString */;
+long var776 /* : Int */;
+val* var777 /* : FlatString */;
+val* var778 /* : Array[Object] */;
+long var779 /* : Int */;
+val* var780 /* : NativeArray[Object] */;
+val* var781 /* : 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[String] */;
+val* var795 /* : Array[String] */;
+val* var796 /* : Array[nullable Object] */;
+val* var_tags /* var tags: Array[String] */;
+static val* varonce797;
+val* var798 /* : String */;
+char* var799 /* : NativeString */;
+long var800 /* : Int */;
+val* var801 /* : FlatString */;
+val* var802 /* : ArrayIterator[nullable Object] */;
+short int var803 /* : Bool */;
+val* var804 /* : nullable Object */;
+val* var_tag805 /* var tag: String */;
+static val* varonce806;
+val* var807 /* : String */;
+char* var808 /* : NativeString */;
+long var809 /* : Int */;
+val* var810 /* : FlatString */;
+static val* varonce811;
+val* var812 /* : String */;
+char* var813 /* : NativeString */;
+long var814 /* : Int */;
+val* var815 /* : FlatString */;
+val* var816 /* : Array[Object] */;
+long var817 /* : Int */;
+val* var818 /* : NativeArray[Object] */;
+val* var819 /* : String */;
+static val* varonce820;
+val* var821 /* : String */;
+char* var822 /* : NativeString */;
+long var823 /* : Int */;
+val* var824 /* : FlatString */;
+static val* varonce825;
+val* var826 /* : String */;
+char* var827 /* : NativeString */;
+long var828 /* : Int */;
+val* var829 /* : FlatString */;
+static val* varonce830;
+val* var831 /* : String */;
+char* var832 /* : NativeString */;
+long var833 /* : Int */;
+val* var834 /* : FlatString */;
+val* var835 /* : Array[Object] */;
+long var836 /* : Int */;
+val* var837 /* : NativeArray[Object] */;
+val* var838 /* : String */;
+static val* varonce839;
+val* var840 /* : String */;
+char* var841 /* : NativeString */;
+long var842 /* : Int */;
+val* var843 /* : FlatString */;
+static val* varonce844;
+val* var845 /* : String */;
+char* var846 /* : NativeString */;
+long var847 /* : Int */;
+val* var848 /* : FlatString */;
+static val* varonce849;
+val* var850 /* : String */;
+char* var851 /* : NativeString */;
+long var852 /* : Int */;
+val* var853 /* : FlatString */;
+val* var854 /* : Array[Object] */;
+long var855 /* : Int */;
+val* var856 /* : NativeArray[Object] */;
+val* var857 /* : String */;
+static val* varonce858;
+val* var859 /* : String */;
+char* var860 /* : NativeString */;
+long var861 /* : Int */;
+val* var862 /* : FlatString */;
+static val* varonce863;
+val* var864 /* : String */;
+char* var865 /* : NativeString */;
+long var866 /* : Int */;
+val* var867 /* : FlatString */;
+static val* varonce868;
+val* var869 /* : String */;
+char* var870 /* : NativeString */;
+long var871 /* : Int */;
+val* var872 /* : FlatString */;
+val* var873 /* : Array[Object] */;
+long var874 /* : Int */;
+val* var875 /* : NativeArray[Object] */;
+val* var876 /* : String */;
+static val* varonce877;
+val* var878 /* : String */;
+char* var879 /* : NativeString */;
+long var880 /* : Int */;
+val* var881 /* : FlatString */;
+static val* varonce882;
+val* var883 /* : String */;
+char* var884 /* : NativeString */;
+long var885 /* : Int */;
+val* var886 /* : FlatString */;
+static val* varonce887;
+val* var888 /* : String */;
+char* var889 /* : NativeString */;
+long var890 /* : Int */;
+val* var891 /* : FlatString */;
+val* var892 /* : Array[Object] */;
+long var893 /* : Int */;
+val* var894 /* : NativeArray[Object] */;
+val* var895 /* : String */;
+val* var897 /* : ModelBuilder */;
+val* var899 /* : ModelBuilder */;
+val* var900 /* : ToolContext */;
+val* var902 /* : ToolContext */;
+val* var903 /* : OptionBool */;
+val* var905 /* : OptionBool */;
+val* var906 /* : nullable Object */;
+val* var908 /* : nullable Object */;
+short int var909 /* : Bool */;
+static val* varonce910;
+val* var911 /* : String */;
+char* var912 /* : NativeString */;
+long var913 /* : Int */;
+val* var914 /* : FlatString */;
+static val* varonce915;
+val* var916 /* : String */;
+char* var917 /* : NativeString */;
+long var918 /* : Int */;
+val* var919 /* : FlatString */;
+static val* varonce920;
+val* var921 /* : String */;
+char* var922 /* : NativeString */;
+long var923 /* : Int */;
+val* var924 /* : FlatString */;
+static val* varonce925;
+val* var926 /* : String */;
+char* var927 /* : NativeString */;
+long var928 /* : Int */;
+val* var929 /* : FlatString */;
+static val* varonce930;
+val* var931 /* : String */;
+char* var932 /* : NativeString */;
+long var933 /* : Int */;
+val* var934 /* : FlatString */;
+static val* varonce935;
+val* var936 /* : String */;
+char* var937 /* : NativeString */;
+long var938 /* : Int */;
+val* var939 /* : FlatString */;
+val* var940 /* : ModelBuilder */;
+val* var942 /* : ModelBuilder */;
+val* var943 /* : ToolContext */;
+val* var945 /* : ToolContext */;
+val* var946 /* : OptionBool */;
+val* var948 /* : OptionBool */;
+val* var949 /* : nullable Object */;
+val* var951 /* : nullable Object */;
+short int var952 /* : Bool */;
+static val* varonce953;
+val* var954 /* : String */;
+char* var955 /* : NativeString */;
+long var956 /* : Int */;
+val* var957 /* : FlatString */;
+static val* varonce958;
+val* var959 /* : String */;
+char* var960 /* : NativeString */;
+long var961 /* : Int */;
+val* var962 /* : FlatString */;
+static val* varonce963;
+val* var964 /* : String */;
+char* var965 /* : NativeString */;
+long var966 /* : Int */;
+val* var967 /* : FlatString */;
+static val* varonce968;
+val* var969 /* : String */;
+char* var970 /* : NativeString */;
+long var971 /* : Int */;
+val* var972 /* : FlatString */;
+{
+var = ((val* (*)(val*))(self->class->vft[COLOR_abstract_compiler__AbstractCompiler__new_visitor]))(self) /* new_visitor on <self:AbstractCompiler>*/;
 }
-if (var2){
+var_v = var;
 if (varonce) {
-var3 = varonce;
-} else {
-var4 = "?: ";
-var5 = 3;
-var6 = string__NativeString__to_s_with_length(var4, var5);
-var3 = var6;
-varonce = var3;
-}
-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);
-}
-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>*/;
-} else {
-((void (*)(val*, val*))(var_node->class->vft[COLOR_parser_nodes__ANode__debug]))(var_node, var_message) /* debug on <var_node:nullable ANode(ANode)>*/;
-}
-if (varonce11) {
-var12 = varonce11;
-} else {
-var13 = "/* DEBUG: ";
-var14 = 10;
-var15 = string__NativeString__to_s_with_length(var13, var14);
-var12 = var15;
-varonce11 = var12;
-}
-if (varonce16) {
-var17 = varonce16;
-} else {
-var18 = " */";
-var19 = 3;
-var20 = string__NativeString__to_s_with_length(var18, var19);
-var17 = var20;
-varonce16 = var17;
-}
-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);
-}
-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:;
+var1 = varonce;
+} else {
+var2 = "#include <signal.h>";
+var3 = 19;
+var4 = string__NativeString__to_s_with_length(var2, var3);
+var1 = var4;
+varonce = var1;
 }
-/* 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_decl(var_v, var1); /* Direct call abstract_compiler#AbstractCompilerVisitor#add_decl 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);
+{
+{ /* 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", "src/abstract_compiler.nit", 443);
+show_backtrace(1);
 }
-var = var1;
-RET_LABEL:;
-return var;
+var5 = var7;
+RET_LABEL6:(void)0;
 }
-/* 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;
 }
-/* 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:;
+{
+{ /* 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", "src/modelbuilder.nit", 101);
+show_backtrace(1);
 }
-/* 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:;
+var8 = var10;
+RET_LABEL9:(void)0;
 }
-/* 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 */
-} else {
-var3 = 1; /* arg is null and recv is not */
 }
-if (var3){
-var = var_res;
-goto RET_LABEL;
-} else {
+{
+{ /* 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", "src/abstract_compiler.nit", 62);
+show_backtrace(1);
 }
-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;
+var11 = var13;
+RET_LABEL12:(void)0;
 }
-/* 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;
 }
-/* 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;
+{
+{ /* 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;
 }
-/* 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;
 }
-/* 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;
+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", "src/abstract_compiler.nit", 436);
+show_backtrace(1);
 }
-/* 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;
+var17 = var19;
+RET_LABEL18:(void)0;
 }
-/* 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:;
 }
-/* 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:;
+{
+var20 = platform__MModule__target_platform(var17);
 }
-/* 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;
+var_platform = var20;
+var22 = NULL;
+if (var_platform == NULL) {
+var23 = 0; /* is null */
 } else {
-var1 = p0->type->type_table[cltype] == idtype;
+var23 = 1; /* arg is null and recv is not */
 }
-if (!var1) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "src/abstract_compiler.nit", 988);
-exit(1);
+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;
 }
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Deferred method called", "src/abstract_compiler.nit", 988);
-exit(1);
-RET_LABEL:;
-return var;
+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)>*/;
 }
-/* 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;
+var26 = !var25;
+var21 = var26;
+} else {
+var21 = var_;
 }
-/* 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 (var21){
+if (varonce27) {
+var28 = varonce27;
 } else {
-var = p0->type->type_table[cltype] == idtype;
+var29 = "none";
+var30 = 4;
+var31 = string__NativeString__to_s_with_length(var29, var30);
+var28 = var31;
+varonce27 = var28;
 }
-if (!var) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "src/abstract_compiler.nit", 992);
-exit(1);
+var_ost = var28;
+} else {
 }
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Deferred method called", "src/abstract_compiler.nit", 992);
-exit(1);
-RET_LABEL:;
+var34 = NULL;
+if (var_platform == NULL) {
+var35 = 0; /* is null */
+} else {
+var35 = 1; /* arg is null and recv is not */
 }
-/* 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:;
+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;
 }
-/* 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:;
+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)>*/;
 }
-/* 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:;
+var33 = var38;
+} else {
+var33 = var_37;
 }
-/* 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);
+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", "src/abstract_compiler.nit", 443);
+show_backtrace(1);
 }
-var = var1;
-RET_LABEL:;
-return var;
+var40 = var42;
+RET_LABEL41:(void)0;
 }
-/* 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;
 }
-/* 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:;
+{
+{ /* 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", "src/modelbuilder.nit", 101);
+show_backtrace(1);
 }
-/* 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:;
+var43 = var45;
+RET_LABEL44:(void)0;
 }
-/* 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);
 }
-var = var1;
-RET_LABEL:;
-return var;
+{
+{ /* 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", "src/abstract_compiler.nit", 34);
+show_backtrace(1);
 }
-/* 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;
+var46 = var48;
+RET_LABEL47:(void)0;
 }
-/* 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:;
 }
-/* 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:;
+{
+{ /* 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;
 }
-/* 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;
+var52 = ((struct instance_kernel__Bool*)var49)->value; /* autounbox from nullable Object to Bool */;
+var32 = var52;
 }
-/* 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;
+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;
 }
-/* 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:;
+if (var_ost == NULL) {
+var59 = 0; /* <var55:String> cannot be null */
+} else {
+var60 = string__FlatString___61d_61d(var_ost, var55);
+var59 = var60;
 }
-/* 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:;
+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;
 }
-/* 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;
+if (var_ost == NULL) {
+var67 = 0; /* <var63:String> cannot be null */
+} else {
+var68 = string__FlatString___61d_61d(var_ost, var63);
+var67 = var68;
 }
-/* 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;
+var53 = var67;
 }
-/* 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:;
+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;
 }
-/* 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:;
+{
+abstract_compiler__AbstractCompilerVisitor__add_decl(var_v, var70); /* Direct call abstract_compiler#AbstractCompilerVisitor#add_decl on <var_v:AbstractCompilerVisitor>*/
 }
-/* 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);
+if (varonce74) {
+var75 = varonce74;
+} else {
+var76 = "#include <libunwind.h>";
+var77 = 22;
+var78 = string__NativeString__to_s_with_length(var76, var77);
+var75 = var78;
+varonce74 = var75;
 }
-RET_LABEL:;
+{
+abstract_compiler__AbstractCompilerVisitor__add_decl(var_v, var75); /* Direct call abstract_compiler#AbstractCompilerVisitor#add_decl on <var_v:AbstractCompilerVisitor>*/
 }
-/* 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:;
+if (varonce79) {
+var80 = varonce79;
+} else {
+var81 = "nitstack";
+var82 = 8;
+var83 = string__NativeString__to_s_with_length(var81, var82);
+var80 = var83;
+varonce79 = var80;
 }
-/* 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 (var_ost == NULL) {
+var84 = 0; /* <var80:String> cannot be null */
+} else {
+var85 = string__FlatString___61d_61d(var_ost, var80);
+var84 = var85;
 }
-/* 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;
+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>*/
 }
-/* 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;
 } else {
-var3 = " exact";
-var4 = 6;
-var5 = string__NativeString__to_s_with_length(var3, var4);
-var2 = var5;
-varonce = var2;
 }
-var_exact_str = var2;
 } else {
-if (varonce6) {
-var7 = varonce6;
+}
+if (varonce91) {
+var92 = varonce91;
 } else {
-var8 = "";
-var9 = 0;
-var10 = string__NativeString__to_s_with_length(var8, var9);
-var7 = var10;
-varonce6 = var7;
+var93 = "int glob_argc;";
+var94 = 14;
+var95 = string__NativeString__to_s_with_length(var93, var94);
+var92 = var95;
+varonce91 = var92;
 }
-var_exact_str = var7;
+{
+abstract_compiler__AbstractCompilerVisitor__add_decl(var_v, var92); /* Direct call abstract_compiler#AbstractCompilerVisitor#add_decl on <var_v:AbstractCompilerVisitor>*/
 }
-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);
-}
-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;
+if (varonce96) {
+var97 = varonce96;
 } else {
-var28 = ")";
-var29 = 1;
-var30 = string__NativeString__to_s_with_length(var28, var29);
-var27 = var30;
-varonce26 = var27;
-}
-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);
+var98 = "char **glob_argv;";
+var99 = 17;
+var100 = string__NativeString__to_s_with_length(var98, var99);
+var97 = var100;
+varonce96 = var97;
 }
-var34 = ((val* (*)(val*))(var31->class->vft[COLOR_string__Object__to_s]))(var31) /* to_s on <var31:Array[Object]>*/;
-var_type_str = var34;
+{
+abstract_compiler__AbstractCompilerVisitor__add_decl(var_v, var97); /* Direct call abstract_compiler#AbstractCompilerVisitor#add_decl on <var_v:AbstractCompilerVisitor>*/
 }
-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;
+if (varonce101) {
+var102 = varonce101;
 } else {
-var39 = "<";
-var40 = 1;
-var41 = string__NativeString__to_s_with_length(var39, var40);
-var38 = var41;
-varonce37 = var38;
+var103 = "val *glob_sys;";
+var104 = 14;
+var105 = string__NativeString__to_s_with_length(var103, var104);
+var102 = var105;
+varonce101 = var102;
 }
-((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;
+{
+abstract_compiler__AbstractCompilerVisitor__add_decl(var_v, var102); /* Direct call abstract_compiler#AbstractCompilerVisitor#add_decl on <var_v:AbstractCompilerVisitor>*/
 }
-/* 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#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", "src/abstract_compiler.nit", 443);
+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);
+var106 = var108;
+RET_LABEL107:(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 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", "src/modelbuilder.nit", 101);
+show_backtrace(1);
 }
-/* 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;
+var109 = var111;
+RET_LABEL110:(void)0;
 }
-if (!var) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "src/abstract_compiler.nit", 1049);
-exit(1);
 }
-self->attrs[COLOR_abstract_compiler__Frame___64dvisitor].val = p0; /* @visitor on <self:Frame> */
-RET_LABEL:;
+{
+{ /* 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", "src/abstract_compiler.nit", 56);
+show_backtrace(1);
 }
-/* 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:;
+var112 = var114;
+RET_LABEL113:(void)0;
 }
-/* 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);
 }
-var = var1;
-RET_LABEL:;
-return var;
+{
+{ /* 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;
 }
-/* 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;
 }
-/* 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:;
+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", "src/abstract_compiler.nit", 888);
+show_backtrace(1);
 }
-/* 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:;
+var119 = var121;
+RET_LABEL120:(void)0;
 }
-/* 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);
 }
-var = var1;
-RET_LABEL:;
-return var;
+{
+var122 = array__AbstractArrayRead__iterator(var119);
 }
-/* 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;
-RET_LABEL:;
-return var;
+for(;;) {
+{
+var123 = array__ArrayIterator__is_ok(var122);
+}
+if(!var123) break;
+{
+var124 = array__ArrayIterator__item(var122);
+}
+var_tag = var124;
+if (varonce125) {
+var126 = varonce125;
+} else {
+var127 = "long count_type_test_resolved_";
+var128 = 30;
+var129 = string__NativeString__to_s_with_length(var127, var128);
+var126 = var129;
+varonce125 = var126;
+}
+if (varonce130) {
+var131 = varonce130;
+} else {
+var132 = ";";
+var133 = 1;
+var134 = string__NativeString__to_s_with_length(var132, var133);
+var131 = var134;
+varonce130 = var131;
+}
+var135 = NEW_array__Array(&type_array__Arraykernel__Object);
+{ /* var135 = array_instance Array[Object] */
+var136 = 3;
+var137 = NEW_array__NativeArray(var136, &type_array__NativeArraykernel__Object);
+((struct instance_array__NativeArray*)var137)->values[0] = (val*) var126;
+((struct instance_array__NativeArray*)var137)->values[1] = (val*) var_tag;
+((struct instance_array__NativeArray*)var137)->values[2] = (val*) var131;
+{
+((void (*)(val*, val*, long))(var135->class->vft[COLOR_array__Array__with_native]))(var135, var137, var136) /* with_native on <var135:Array[Object]>*/;
+}
+}
+{
+var138 = ((val* (*)(val*))(var135->class->vft[COLOR_string__Object__to_s]))(var135) /* to_s on <var135:Array[Object]>*/;
+}
+{
+abstract_compiler__AbstractCompilerVisitor__add_decl(var_v, var138); /* Direct call abstract_compiler#AbstractCompilerVisitor#add_decl on <var_v:AbstractCompilerVisitor>*/
+}
+if (varonce139) {
+var140 = varonce139;
+} else {
+var141 = "long count_type_test_unresolved_";
+var142 = 32;
+var143 = string__NativeString__to_s_with_length(var141, var142);
+var140 = var143;
+varonce139 = var140;
+}
+if (varonce144) {
+var145 = varonce144;
+} else {
+var146 = ";";
+var147 = 1;
+var148 = string__NativeString__to_s_with_length(var146, var147);
+var145 = var148;
+varonce144 = var145;
+}
+var149 = NEW_array__Array(&type_array__Arraykernel__Object);
+{ /* var149 = array_instance Array[Object] */
+var150 = 3;
+var151 = NEW_array__NativeArray(var150, &type_array__NativeArraykernel__Object);
+((struct instance_array__NativeArray*)var151)->values[0] = (val*) var140;
+((struct instance_array__NativeArray*)var151)->values[1] = (val*) var_tag;
+((struct instance_array__NativeArray*)var151)->values[2] = (val*) var145;
+{
+((void (*)(val*, val*, long))(var149->class->vft[COLOR_array__Array__with_native]))(var149, var151, var150) /* with_native on <var149:Array[Object]>*/;
+}
+}
+{
+var152 = ((val* (*)(val*))(var149->class->vft[COLOR_string__Object__to_s]))(var149) /* to_s on <var149:Array[Object]>*/;
+}
+{
+abstract_compiler__AbstractCompilerVisitor__add_decl(var_v, var152); /* Direct call abstract_compiler#AbstractCompilerVisitor#add_decl on <var_v:AbstractCompilerVisitor>*/
+}
+if (varonce153) {
+var154 = varonce153;
+} else {
+var155 = "long count_type_test_skipped_";
+var156 = 29;
+var157 = string__NativeString__to_s_with_length(var155, var156);
+var154 = var157;
+varonce153 = var154;
+}
+if (varonce158) {
+var159 = varonce158;
+} else {
+var160 = ";";
+var161 = 1;
+var162 = string__NativeString__to_s_with_length(var160, var161);
+var159 = var162;
+varonce158 = var159;
+}
+var163 = NEW_array__Array(&type_array__Arraykernel__Object);
+{ /* var163 = array_instance Array[Object] */
+var164 = 3;
+var165 = NEW_array__NativeArray(var164, &type_array__NativeArraykernel__Object);
+((struct instance_array__NativeArray*)var165)->values[0] = (val*) var154;
+((struct instance_array__NativeArray*)var165)->values[1] = (val*) var_tag;
+((struct instance_array__NativeArray*)var165)->values[2] = (val*) var159;
+{
+((void (*)(val*, val*, long))(var163->class->vft[COLOR_array__Array__with_native]))(var163, var165, var164) /* with_native on <var163:Array[Object]>*/;
+}
+}
+{
+var166 = ((val* (*)(val*))(var163->class->vft[COLOR_string__Object__to_s]))(var163) /* to_s on <var163:Array[Object]>*/;
+}
+{
+abstract_compiler__AbstractCompilerVisitor__add_decl(var_v, var166); /* Direct call abstract_compiler#AbstractCompilerVisitor#add_decl on <var_v:AbstractCompilerVisitor>*/
+}
+{
+{ /* Inline abstract_compiler#AbstractCompilerVisitor#compiler (var_v) on <var_v:AbstractCompilerVisitor> */
+var169 = var_v->attrs[COLOR_abstract_compiler__AbstractCompilerVisitor___compiler].val; /* _compiler on <var_v:AbstractCompilerVisitor> */
+if (unlikely(var169 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _compiler");
+PRINT_ERROR(" (%s:%d)\n", "src/abstract_compiler.nit", 984);
+show_backtrace(1);
+}
+var167 = var169;
+RET_LABEL168:(void)0;
+}
+}
+{
+{ /* Inline abstract_compiler#AbstractCompiler#header (var167) on <var167:AbstractCompiler> */
+var172 = var167->attrs[COLOR_abstract_compiler__AbstractCompiler___header].val; /* _header on <var167:AbstractCompiler> */
+if (unlikely(var172 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _header");
+PRINT_ERROR(" (%s:%d)\n", "src/abstract_compiler.nit", 472);
+show_backtrace(1);
+}
+var170 = var172;
+RET_LABEL171:(void)0;
+}
+}
+if (varonce173) {
+var174 = varonce173;
+} else {
+var175 = "extern long count_type_test_resolved_";
+var176 = 37;
+var177 = string__NativeString__to_s_with_length(var175, var176);
+var174 = var177;
+varonce173 = var174;
+}
+if (varonce178) {
+var179 = varonce178;
+} else {
+var180 = ";";
+var181 = 1;
+var182 = string__NativeString__to_s_with_length(var180, var181);
+var179 = var182;
+varonce178 = var179;
+}
+var183 = NEW_array__Array(&type_array__Arraykernel__Object);
+{ /* var183 = array_instance Array[Object] */
+var184 = 3;
+var185 = NEW_array__NativeArray(var184, &type_array__NativeArraykernel__Object);
+((struct instance_array__NativeArray*)var185)->values[0] = (val*) var174;
+((struct instance_array__NativeArray*)var185)->values[1] = (val*) var_tag;
+((struct instance_array__NativeArray*)var185)->values[2] = (val*) var179;
+{
+((void (*)(val*, val*, long))(var183->class->vft[COLOR_array__Array__with_native]))(var183, var185, var184) /* with_native on <var183:Array[Object]>*/;
+}
+}
+{
+var186 = ((val* (*)(val*))(var183->class->vft[COLOR_string__Object__to_s]))(var183) /* to_s on <var183:Array[Object]>*/;
+}
+{
+abstract_compiler__CodeWriter__add_decl(var170, var186); /* Direct call abstract_compiler#CodeWriter#add_decl on <var170:CodeWriter>*/
+}
+{
+{ /* Inline abstract_compiler#AbstractCompilerVisitor#compiler (var_v) on <var_v:AbstractCompilerVisitor> */
+var189 = var_v->attrs[COLOR_abstract_compiler__AbstractCompilerVisitor___compiler].val; /* _compiler on <var_v:AbstractCompilerVisitor> */
+if (unlikely(var189 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _compiler");
+PRINT_ERROR(" (%s:%d)\n", "src/abstract_compiler.nit", 984);
+show_backtrace(1);
+}
+var187 = var189;
+RET_LABEL188:(void)0;
+}
+}
+{
+{ /* Inline abstract_compiler#AbstractCompiler#header (var187) on <var187:AbstractCompiler> */
+var192 = var187->attrs[COLOR_abstract_compiler__AbstractCompiler___header].val; /* _header on <var187:AbstractCompiler> */
+if (unlikely(var192 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _header");
+PRINT_ERROR(" (%s:%d)\n", "src/abstract_compiler.nit", 472);
+show_backtrace(1);
+}
+var190 = var192;
+RET_LABEL191:(void)0;
+}
+}
+if (varonce193) {
+var194 = varonce193;
+} else {
+var195 = "extern long count_type_test_unresolved_";
+var196 = 39;
+var197 = string__NativeString__to_s_with_length(var195, var196);
+var194 = var197;
+varonce193 = var194;
 }
-/* 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> */
-RET_LABEL:;
+if (varonce198) {
+var199 = varonce198;
+} else {
+var200 = ";";
+var201 = 1;
+var202 = string__NativeString__to_s_with_length(var200, var201);
+var199 = var202;
+varonce198 = var199;
+}
+var203 = NEW_array__Array(&type_array__Arraykernel__Object);
+{ /* var203 = array_instance Array[Object] */
+var204 = 3;
+var205 = NEW_array__NativeArray(var204, &type_array__NativeArraykernel__Object);
+((struct instance_array__NativeArray*)var205)->values[0] = (val*) var194;
+((struct instance_array__NativeArray*)var205)->values[1] = (val*) var_tag;
+((struct instance_array__NativeArray*)var205)->values[2] = (val*) var199;
+{
+((void (*)(val*, val*, long))(var203->class->vft[COLOR_array__Array__with_native]))(var203, var205, var204) /* with_native on <var203:Array[Object]>*/;
 }
-/* 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);
-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);
+{
+var206 = ((val* (*)(val*))(var203->class->vft[COLOR_string__Object__to_s]))(var203) /* to_s on <var203:Array[Object]>*/;
+}
+{
+abstract_compiler__CodeWriter__add_decl(var190, var206); /* Direct call abstract_compiler#CodeWriter#add_decl on <var190:CodeWriter>*/
+}
+{
+{ /* Inline abstract_compiler#AbstractCompilerVisitor#compiler (var_v) on <var_v:AbstractCompilerVisitor> */
+var209 = var_v->attrs[COLOR_abstract_compiler__AbstractCompilerVisitor___compiler].val; /* _compiler on <var_v:AbstractCompilerVisitor> */
+if (unlikely(var209 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _compiler");
+PRINT_ERROR(" (%s:%d)\n", "src/abstract_compiler.nit", 984);
+show_backtrace(1);
+}
+var207 = var209;
+RET_LABEL208:(void)0;
+}
+}
+{
+{ /* Inline abstract_compiler#AbstractCompiler#header (var207) on <var207:AbstractCompiler> */
+var212 = var207->attrs[COLOR_abstract_compiler__AbstractCompiler___header].val; /* _header on <var207:AbstractCompiler> */
+if (unlikely(var212 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _header");
+PRINT_ERROR(" (%s:%d)\n", "src/abstract_compiler.nit", 472);
+show_backtrace(1);
+}
+var210 = var212;
+RET_LABEL211:(void)0;
+}
+}
+if (varonce213) {
+var214 = varonce213;
+} else {
+var215 = "extern long count_type_test_skipped_";
+var216 = 36;
+var217 = string__NativeString__to_s_with_length(var215, var216);
+var214 = var217;
+varonce213 = var214;
+}
+if (varonce218) {
+var219 = varonce218;
+} else {
+var220 = ";";
+var221 = 1;
+var222 = string__NativeString__to_s_with_length(var220, var221);
+var219 = var222;
+varonce218 = var219;
+}
+var223 = NEW_array__Array(&type_array__Arraykernel__Object);
+{ /* var223 = array_instance Array[Object] */
+var224 = 3;
+var225 = NEW_array__NativeArray(var224, &type_array__NativeArraykernel__Object);
+((struct instance_array__NativeArray*)var225)->values[0] = (val*) var214;
+((struct instance_array__NativeArray*)var225)->values[1] = (val*) var_tag;
+((struct instance_array__NativeArray*)var225)->values[2] = (val*) var219;
+{
+((void (*)(val*, val*, long))(var223->class->vft[COLOR_array__Array__with_native]))(var223, var225, var224) /* with_native on <var223:Array[Object]>*/;
 }
-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);
-var = var1;
-RET_LABEL:;
-return var;
+{
+var226 = ((val* (*)(val*))(var223->class->vft[COLOR_string__Object__to_s]))(var223) /* to_s on <var223:Array[Object]>*/;
+}
+{
+abstract_compiler__CodeWriter__add_decl(var210, var226); /* Direct call abstract_compiler#CodeWriter#add_decl on <var210:CodeWriter>*/
 }
-/* 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:;
+CONTINUE_label: (void)0;
+{
+array__ArrayIterator__next(var122); /* Direct call array#ArrayIterator#next on <var122:ArrayIterator[nullable Object]>*/
 }
-/* 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#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;
+BREAK_label: (void)0;
+} else {
 }
-/* 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);
-var = var1;
-RET_LABEL:;
-return var;
+{
+{ /* Inline abstract_compiler#AbstractCompiler#modelbuilder (self) on <self:AbstractCompiler> */
+var229 = self->attrs[COLOR_abstract_compiler__AbstractCompiler___modelbuilder].val; /* _modelbuilder on <self:AbstractCompiler> */
+if (unlikely(var229 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _modelbuilder");
+PRINT_ERROR(" (%s:%d)\n", "src/abstract_compiler.nit", 443);
+show_backtrace(1);
 }
-/* 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:;
+var227 = var229;
+RET_LABEL228:(void)0;
 }
-/* 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#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;
+{
+{ /* Inline modelbuilder#ModelBuilder#toolcontext (var227) on <var227:ModelBuilder> */
+var232 = var227->attrs[COLOR_modelbuilder__ModelBuilder___toolcontext].val; /* _toolcontext on <var227:ModelBuilder> */
+if (unlikely(var232 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _toolcontext");
+PRINT_ERROR(" (%s:%d)\n", "src/modelbuilder.nit", 101);
+show_backtrace(1);
 }
-/* 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);
-var = var1;
-RET_LABEL:;
-return var;
+var230 = var232;
+RET_LABEL231:(void)0;
 }
-/* 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:;
+{
+{ /* Inline abstract_compiler#ToolContext#opt_invocation_metrics (var230) on <var230:ToolContext> */
+var235 = var230->attrs[COLOR_abstract_compiler__ToolContext___opt_invocation_metrics].val; /* _opt_invocation_metrics on <var230:ToolContext> */
+if (unlikely(var235 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _opt_invocation_metrics");
+PRINT_ERROR(" (%s:%d)\n", "src/abstract_compiler.nit", 58);
+show_backtrace(1);
 }
-/* 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) {
-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;
+var233 = var235;
+RET_LABEL234:(void)0;
+}
+}
+{
+{ /* Inline opts#Option#value (var233) on <var233:OptionBool> */
+var238 = var233->attrs[COLOR_opts__Option___value].val; /* _value on <var233:OptionBool> */
+var236 = var238;
+RET_LABEL237:(void)0;
+}
+}
+var239 = ((struct instance_kernel__Bool*)var236)->value; /* autounbox from nullable Object to Bool */;
+if (var239){
+if (varonce240) {
+var241 = varonce240;
 } else {
-var = p0->type->type_table[cltype] == idtype;
+var242 = "long count_invoke_by_tables;";
+var243 = 28;
+var244 = string__NativeString__to_s_with_length(var242, var243);
+var241 = var244;
+varonce240 = var241;
 }
-if (!var) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "src/abstract_compiler.nit", 1044);
-exit(1);
+{
+abstract_compiler__AbstractCompilerVisitor__add_decl(var_v, var241); /* Direct call abstract_compiler#AbstractCompilerVisitor#add_decl on <var_v:AbstractCompilerVisitor>*/
 }
-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:;
+if (varonce245) {
+var246 = varonce245;
+} else {
+var247 = "long count_invoke_by_direct;";
+var248 = 28;
+var249 = string__NativeString__to_s_with_length(var247, var248);
+var246 = var249;
+varonce245 = var246;
 }
-/* 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);
-RET_LABEL:;
+{
+abstract_compiler__AbstractCompilerVisitor__add_decl(var_v, var246); /* Direct call abstract_compiler#AbstractCompilerVisitor#add_decl on <var_v:AbstractCompilerVisitor>*/
 }
-/* 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);
+if (varonce250) {
+var251 = varonce250;
+} else {
+var252 = "long count_invoke_by_inline;";
+var253 = 28;
+var254 = string__NativeString__to_s_with_length(var252, var253);
+var251 = var254;
+varonce250 = var251;
 }
-var = var1;
-RET_LABEL:;
-return var;
+{
+abstract_compiler__AbstractCompilerVisitor__add_decl(var_v, var251); /* Direct call abstract_compiler#AbstractCompilerVisitor#add_decl on <var_v:AbstractCompilerVisitor>*/
 }
-/* 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);
-var = var1;
-RET_LABEL:;
-return var;
+{
+{ /* Inline abstract_compiler#AbstractCompilerVisitor#compiler (var_v) on <var_v:AbstractCompilerVisitor> */
+var257 = var_v->attrs[COLOR_abstract_compiler__AbstractCompilerVisitor___compiler].val; /* _compiler on <var_v:AbstractCompilerVisitor> */
+if (unlikely(var257 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _compiler");
+PRINT_ERROR(" (%s:%d)\n", "src/abstract_compiler.nit", 984);
+show_backtrace(1);
 }
-/* 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:;
+var255 = var257;
+RET_LABEL256:(void)0;
 }
-/* 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);
-RET_LABEL:;
 }
-/* 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);
+{
+{ /* Inline abstract_compiler#AbstractCompiler#header (var255) on <var255:AbstractCompiler> */
+var260 = var255->attrs[COLOR_abstract_compiler__AbstractCompiler___header].val; /* _header on <var255:AbstractCompiler> */
+if (unlikely(var260 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _header");
+PRINT_ERROR(" (%s:%d)\n", "src/abstract_compiler.nit", 472);
+show_backtrace(1);
 }
-var = var1;
-RET_LABEL:;
-return var;
+var258 = var260;
+RET_LABEL259:(void)0;
 }
-/* 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);
-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:;
+if (varonce261) {
+var262 = varonce261;
+} else {
+var263 = "extern long count_invoke_by_tables;";
+var264 = 35;
+var265 = string__NativeString__to_s_with_length(var263, var264);
+var262 = var265;
+varonce261 = var262;
 }
-/* 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);
-RET_LABEL:;
+{
+abstract_compiler__CodeWriter__add_decl(var258, var262); /* Direct call abstract_compiler#CodeWriter#add_decl on <var258:CodeWriter>*/
 }
-/* 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> */
-RET_LABEL:;
+{
+{ /* Inline abstract_compiler#AbstractCompilerVisitor#compiler (var_v) on <var_v:AbstractCompilerVisitor> */
+var268 = var_v->attrs[COLOR_abstract_compiler__AbstractCompilerVisitor___compiler].val; /* _compiler on <var_v:AbstractCompilerVisitor> */
+if (unlikely(var268 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _compiler");
+PRINT_ERROR(" (%s:%d)\n", "src/abstract_compiler.nit", 984);
+show_backtrace(1);
 }
-/* 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);
-RET_LABEL:;
+var266 = var268;
+RET_LABEL267:(void)0;
 }
-/* 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;
 }
-var = var1;
-goto RET_LABEL;
-RET_LABEL:;
-return var;
+{
+{ /* Inline abstract_compiler#AbstractCompiler#header (var266) on <var266:AbstractCompiler> */
+var271 = var266->attrs[COLOR_abstract_compiler__AbstractCompiler___header].val; /* _header on <var266:AbstractCompiler> */
+if (unlikely(var271 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _header");
+PRINT_ERROR(" (%s:%d)\n", "src/abstract_compiler.nit", 472);
+show_backtrace(1);
 }
-/* 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);
-var = var1;
-RET_LABEL:;
-return var;
+var269 = var271;
+RET_LABEL270:(void)0;
 }
-/* method abstract_compiler#MType#ctypename for (self: MType): String */
-val* abstract_compiler__MType__ctypename(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 = 3;
-var4 = string__NativeString__to_s_with_length(var2, var3);
-var1 = var4;
-varonce = var1;
 }
-var = var1;
-goto RET_LABEL;
-RET_LABEL:;
-return var;
+if (varonce272) {
+var273 = varonce272;
+} else {
+var274 = "extern long count_invoke_by_direct;";
+var275 = 35;
+var276 = string__NativeString__to_s_with_length(var274, var275);
+var273 = var276;
+varonce272 = var273;
 }
-/* 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;
+{
+abstract_compiler__CodeWriter__add_decl(var269, var273); /* Direct call abstract_compiler#CodeWriter#add_decl on <var269:CodeWriter>*/
 }
-/* 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;
+{
+{ /* Inline abstract_compiler#AbstractCompilerVisitor#compiler (var_v) on <var_v:AbstractCompilerVisitor> */
+var279 = var_v->attrs[COLOR_abstract_compiler__AbstractCompilerVisitor___compiler].val; /* _compiler on <var_v:AbstractCompilerVisitor> */
+if (unlikely(var279 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _compiler");
+PRINT_ERROR(" (%s:%d)\n", "src/abstract_compiler.nit", 984);
+show_backtrace(1);
 }
-/* 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;
+var277 = var279;
+RET_LABEL278:(void)0;
 }
-/* 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;
 }
-/* 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#header (var277) on <var277:AbstractCompiler> */
+var282 = var277->attrs[COLOR_abstract_compiler__AbstractCompiler___header].val; /* _header on <var277:AbstractCompiler> */
+if (unlikely(var282 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _header");
+PRINT_ERROR(" (%s:%d)\n", "src/abstract_compiler.nit", 472);
+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:;
+var280 = var282;
+RET_LABEL281:(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 (varonce283) {
+var284 = varonce283;
 } else {
-var3 = 1; /* arg is null and recv is not */
+var285 = "extern long count_invoke_by_inline;";
+var286 = 35;
+var287 = string__NativeString__to_s_with_length(var285, var286);
+var284 = var287;
+varonce283 = var284;
 }
-if (var3){
-var = var_res;
-goto RET_LABEL;
-} else {
+{
+abstract_compiler__CodeWriter__add_decl(var280, var284); /* Direct call abstract_compiler#CodeWriter#add_decl on <var280:CodeWriter>*/
 }
-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;
 }
-((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;
+{
+{ /* Inline abstract_compiler#AbstractCompiler#modelbuilder (self) on <self:AbstractCompiler> */
+var290 = self->attrs[COLOR_abstract_compiler__AbstractCompiler___modelbuilder].val; /* _modelbuilder on <self:AbstractCompiler> */
+if (unlikely(var290 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _modelbuilder");
+PRINT_ERROR(" (%s:%d)\n", "src/abstract_compiler.nit", 443);
+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__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;
+var288 = var290;
+RET_LABEL289:(void)0;
 }
-/* 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;
 }
-/* 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;
+{
+{ /* Inline modelbuilder#ModelBuilder#toolcontext (var288) on <var288:ModelBuilder> */
+var293 = var288->attrs[COLOR_modelbuilder__ModelBuilder___toolcontext].val; /* _toolcontext on <var288:ModelBuilder> */
+if (unlikely(var293 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _toolcontext");
+PRINT_ERROR(" (%s:%d)\n", "src/modelbuilder.nit", 101);
+show_backtrace(1);
 }
-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;
+var291 = var293;
+RET_LABEL292:(void)0;
 }
-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;
+}
+{
+{ /* Inline abstract_compiler#ToolContext#opt_isset_checks_metrics (var291) on <var291:ToolContext> */
+var296 = var291->attrs[COLOR_abstract_compiler__ToolContext___opt_isset_checks_metrics].val; /* _opt_isset_checks_metrics on <var291:ToolContext> */
+if (unlikely(var296 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _opt_isset_checks_metrics");
+PRINT_ERROR(" (%s:%d)\n", "src/abstract_compiler.nit", 60);
+show_backtrace(1);
+}
+var294 = var296;
+RET_LABEL295:(void)0;
+}
+}
+{
+{ /* Inline opts#Option#value (var294) on <var294:OptionBool> */
+var299 = var294->attrs[COLOR_opts__Option___value].val; /* _value on <var294:OptionBool> */
+var297 = var299;
+RET_LABEL298:(void)0;
+}
+}
+var300 = ((struct instance_kernel__Bool*)var297)->value; /* autounbox from nullable Object to Bool */;
+if (var300){
+if (varonce301) {
+var302 = varonce301;
 } else {
-var17 = "Bool";
-var18 = 4;
-var19 = string__NativeString__to_s_with_length(var17, var18);
-var16 = var19;
-varonce15 = var16;
+var303 = "long count_attr_reads = 0;";
+var304 = 26;
+var305 = string__NativeString__to_s_with_length(var303, var304);
+var302 = var305;
+varonce301 = var302;
 }
-var20 = ((short int (*)(val*, val*))(var14->class->vft[COLOR_kernel__Object___61d_61d]))(var14, var16) /* == on <var14:String>*/;
-if (var20){
-if (varonce21) {
-var22 = varonce21;
+{
+abstract_compiler__AbstractCompilerVisitor__add_decl(var_v, var302); /* Direct call abstract_compiler#AbstractCompilerVisitor#add_decl on <var_v:AbstractCompilerVisitor>*/
+}
+if (varonce306) {
+var307 = varonce306;
 } else {
-var23 = "short int";
-var24 = 9;
-var25 = string__NativeString__to_s_with_length(var23, var24);
-var22 = var25;
-varonce21 = var22;
+var308 = "long count_isset_checks = 0;";
+var309 = 28;
+var310 = string__NativeString__to_s_with_length(var308, var309);
+var307 = var310;
+varonce306 = var307;
 }
-var = var22;
-goto RET_LABEL;
+{
+abstract_compiler__AbstractCompilerVisitor__add_decl(var_v, var307); /* Direct call abstract_compiler#AbstractCompilerVisitor#add_decl on <var_v:AbstractCompilerVisitor>*/
+}
+{
+{ /* Inline abstract_compiler#AbstractCompilerVisitor#compiler (var_v) on <var_v:AbstractCompilerVisitor> */
+var313 = var_v->attrs[COLOR_abstract_compiler__AbstractCompilerVisitor___compiler].val; /* _compiler on <var_v:AbstractCompilerVisitor> */
+if (unlikely(var313 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _compiler");
+PRINT_ERROR(" (%s:%d)\n", "src/abstract_compiler.nit", 984);
+show_backtrace(1);
+}
+var311 = var313;
+RET_LABEL312:(void)0;
+}
+}
+{
+{ /* Inline abstract_compiler#AbstractCompiler#header (var311) on <var311:AbstractCompiler> */
+var316 = var311->attrs[COLOR_abstract_compiler__AbstractCompiler___header].val; /* _header on <var311:AbstractCompiler> */
+if (unlikely(var316 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _header");
+PRINT_ERROR(" (%s:%d)\n", "src/abstract_compiler.nit", 472);
+show_backtrace(1);
+}
+var314 = var316;
+RET_LABEL315:(void)0;
+}
+}
+if (varonce317) {
+var318 = varonce317;
 } 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;
+var319 = "extern long count_attr_reads;";
+var320 = 29;
+var321 = string__NativeString__to_s_with_length(var319, var320);
+var318 = var321;
+varonce317 = var318;
+}
+{
+abstract_compiler__CodeWriter__add_decl(var314, var318); /* Direct call abstract_compiler#CodeWriter#add_decl on <var314:CodeWriter>*/
+}
+{
+{ /* Inline abstract_compiler#AbstractCompilerVisitor#compiler (var_v) on <var_v:AbstractCompilerVisitor> */
+var324 = var_v->attrs[COLOR_abstract_compiler__AbstractCompilerVisitor___compiler].val; /* _compiler on <var_v:AbstractCompilerVisitor> */
+if (unlikely(var324 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _compiler");
+PRINT_ERROR(" (%s:%d)\n", "src/abstract_compiler.nit", 984);
+show_backtrace(1);
+}
+var322 = var324;
+RET_LABEL323:(void)0;
+}
+}
+{
+{ /* Inline abstract_compiler#AbstractCompiler#header (var322) on <var322:AbstractCompiler> */
+var327 = var322->attrs[COLOR_abstract_compiler__AbstractCompiler___header].val; /* _header on <var322:AbstractCompiler> */
+if (unlikely(var327 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _header");
+PRINT_ERROR(" (%s:%d)\n", "src/abstract_compiler.nit", 472);
+show_backtrace(1);
+}
+var325 = var327;
+RET_LABEL326:(void)0;
+}
+}
+if (varonce328) {
+var329 = varonce328;
 } else {
-var30 = "Char";
-var31 = 4;
-var32 = string__NativeString__to_s_with_length(var30, var31);
-var29 = var32;
-varonce28 = var29;
+var330 = "extern long count_isset_checks;";
+var331 = 31;
+var332 = string__NativeString__to_s_with_length(var330, var331);
+var329 = var332;
+varonce328 = var329;
+}
+{
+abstract_compiler__CodeWriter__add_decl(var325, var329); /* Direct call abstract_compiler#CodeWriter#add_decl on <var325:CodeWriter>*/
 }
-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;
 }
-var = var35;
-goto RET_LABEL;
+if (varonce333) {
+var334 = varonce333;
 } 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;
+var335 = "void sig_handler(int signo){";
+var336 = 28;
+var337 = string__NativeString__to_s_with_length(var335, var336);
+var334 = var337;
+varonce333 = var334;
+}
+{
+abstract_compiler__AbstractCompilerVisitor__add_decl(var_v, var334); /* Direct call abstract_compiler#AbstractCompilerVisitor#add_decl on <var_v:AbstractCompilerVisitor>*/
+}
+if (varonce338) {
+var339 = varonce338;
 } else {
-var43 = "Float";
-var44 = 5;
-var45 = string__NativeString__to_s_with_length(var43, var44);
-var42 = var45;
-varonce41 = var42;
+var340 = "PRINT_ERROR(\"Caught signal : %s\\n\", strsignal(signo));";
+var341 = 54;
+var342 = string__NativeString__to_s_with_length(var340, var341);
+var339 = var342;
+varonce338 = var339;
 }
-var46 = ((short int (*)(val*, val*))(var40->class->vft[COLOR_kernel__Object___61d_61d]))(var40, var42) /* == on <var40:String>*/;
-if (var46){
-if (varonce47) {
-var48 = varonce47;
+{
+abstract_compiler__AbstractCompilerVisitor__add_decl(var_v, var339); /* Direct call abstract_compiler#AbstractCompilerVisitor#add_decl on <var_v:AbstractCompilerVisitor>*/
+}
+if (varonce343) {
+var344 = varonce343;
 } else {
-var49 = "double";
-var50 = 6;
-var51 = string__NativeString__to_s_with_length(var49, var50);
-var48 = var51;
-varonce47 = var48;
+var345 = "show_backtrace(signo);";
+var346 = 22;
+var347 = string__NativeString__to_s_with_length(var345, var346);
+var344 = var347;
+varonce343 = var344;
 }
-var = var48;
-goto RET_LABEL;
+{
+abstract_compiler__AbstractCompilerVisitor__add_decl(var_v, var344); /* Direct call abstract_compiler#AbstractCompilerVisitor#add_decl on <var_v:AbstractCompilerVisitor>*/
+}
+if (varonce348) {
+var349 = varonce348;
 } 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;
+var350 = "}";
+var351 = 1;
+var352 = string__NativeString__to_s_with_length(var350, var351);
+var349 = var352;
+varonce348 = var349;
+}
+{
+abstract_compiler__AbstractCompilerVisitor__add_decl(var_v, var349); /* Direct call abstract_compiler#AbstractCompilerVisitor#add_decl on <var_v:AbstractCompilerVisitor>*/
+}
+if (varonce353) {
+var354 = varonce353;
 } else {
-var56 = "NativeString";
-var57 = 12;
-var58 = string__NativeString__to_s_with_length(var56, var57);
-var55 = var58;
-varonce54 = var55;
+var355 = "void show_backtrace (int signo) {";
+var356 = 33;
+var357 = string__NativeString__to_s_with_length(var355, var356);
+var354 = var357;
+varonce353 = var354;
 }
-var59 = ((short int (*)(val*, val*))(var53->class->vft[COLOR_kernel__Object___61d_61d]))(var53, var55) /* == on <var53:String>*/;
-if (var59){
-if (varonce60) {
-var61 = varonce60;
+{
+abstract_compiler__AbstractCompilerVisitor__add_decl(var_v, var354); /* Direct call abstract_compiler#AbstractCompilerVisitor#add_decl on <var_v:AbstractCompilerVisitor>*/
+}
+if (varonce359) {
+var360 = varonce359;
 } else {
-var62 = "char*";
-var63 = 5;
-var64 = string__NativeString__to_s_with_length(var62, var63);
-var61 = var64;
-varonce60 = var61;
+var361 = "nitstack";
+var362 = 8;
+var363 = string__NativeString__to_s_with_length(var361, var362);
+var360 = var363;
+varonce359 = var360;
 }
-var = var61;
-goto RET_LABEL;
+if (var_ost == NULL) {
+var364 = 0; /* <var360:String> cannot be null */
 } 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;
-} else {
-var75 = "val*";
-var76 = 4;
-var77 = string__NativeString__to_s_with_length(var75, var76);
-var74 = var77;
-varonce73 = var74;
-}
-var = var74;
-goto RET_LABEL;
+var365 = string__FlatString___61d_61d(var_ost, var360);
+var364 = var365;
+}
+var_366 = var364;
+if (var364){
+var358 = var_366;
 } 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;
+if (varonce367) {
+var368 = varonce367;
 } else {
-if (varonce87) {
-var88 = varonce87;
+var369 = "libunwind";
+var370 = 9;
+var371 = string__NativeString__to_s_with_length(var369, var370);
+var368 = var371;
+varonce367 = var368;
+}
+if (var_ost == NULL) {
+var372 = 0; /* <var368:String> cannot be null */
 } else {
-var89 = "val*";
-var90 = 4;
-var91 = string__NativeString__to_s_with_length(var89, var90);
-var88 = var91;
-varonce87 = var88;
+var373 = string__FlatString___61d_61d(var_ost, var368);
+var372 = var373;
 }
-var = var88;
-goto RET_LABEL;
+var358 = var372;
 }
+if (var358){
+if (varonce374) {
+var375 = varonce374;
+} else {
+var376 = "char* opt = getenv(\"NIT_NO_STACK\");";
+var377 = 35;
+var378 = string__NativeString__to_s_with_length(var376, var377);
+var375 = var378;
+varonce374 = var375;
 }
+{
+abstract_compiler__AbstractCompilerVisitor__add_decl(var_v, var375); /* Direct call abstract_compiler#AbstractCompilerVisitor#add_decl on <var_v:AbstractCompilerVisitor>*/
 }
+if (varonce379) {
+var380 = varonce379;
+} else {
+var381 = "unw_cursor_t cursor;";
+var382 = 20;
+var383 = string__NativeString__to_s_with_length(var381, var382);
+var380 = var383;
+varonce379 = var380;
 }
+{
+abstract_compiler__AbstractCompilerVisitor__add_decl(var_v, var380); /* Direct call abstract_compiler#AbstractCompilerVisitor#add_decl on <var_v:AbstractCompilerVisitor>*/
 }
+if (varonce384) {
+var385 = varonce384;
+} else {
+var386 = "if(opt==NULL){";
+var387 = 14;
+var388 = string__NativeString__to_s_with_length(var386, var387);
+var385 = var388;
+varonce384 = var385;
 }
+{
+abstract_compiler__AbstractCompilerVisitor__add_decl(var_v, var385); /* Direct call abstract_compiler#AbstractCompilerVisitor#add_decl on <var_v:AbstractCompilerVisitor>*/
 }
-RET_LABEL:;
-return var;
+if (varonce389) {
+var390 = varonce389;
+} else {
+var391 = "unw_context_t uc;";
+var392 = 17;
+var393 = string__NativeString__to_s_with_length(var391, var392);
+var390 = var393;
+varonce389 = var390;
 }
-/* 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;
+{
+abstract_compiler__AbstractCompilerVisitor__add_decl(var_v, var390); /* Direct call abstract_compiler#AbstractCompilerVisitor#add_decl on <var_v:AbstractCompilerVisitor>*/
 }
-/* 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;
+if (varonce394) {
+var395 = varonce394;
 } else {
-var4 = "Int";
-var5 = 3;
-var6 = string__NativeString__to_s_with_length(var4, var5);
-var3 = var6;
-varonce = var3;
+var396 = "unw_word_t ip;";
+var397 = 14;
+var398 = string__NativeString__to_s_with_length(var396, var397);
+var395 = var398;
+varonce394 = var395;
 }
-var7 = ((short int (*)(val*, val*))(var2->class->vft[COLOR_kernel__Object___61d_61d]))(var2, var3) /* == on <var2:String>*/;
-if (var7){
-if (varonce8) {
-var9 = varonce8;
+{
+abstract_compiler__AbstractCompilerVisitor__add_decl(var_v, var395); /* Direct call abstract_compiler#AbstractCompilerVisitor#add_decl on <var_v:AbstractCompilerVisitor>*/
+}
+if (varonce399) {
+var400 = varonce399;
 } else {
-var10 = "l";
-var11 = 1;
-var12 = string__NativeString__to_s_with_length(var10, var11);
-var9 = var12;
-varonce8 = var9;
+var401 = "char* procname = malloc(sizeof(char) * 100);";
+var402 = 44;
+var403 = string__NativeString__to_s_with_length(var401, var402);
+var400 = var403;
+varonce399 = var400;
 }
-var = var9;
-goto RET_LABEL;
+{
+abstract_compiler__AbstractCompilerVisitor__add_decl(var_v, var400); /* Direct call abstract_compiler#AbstractCompilerVisitor#add_decl on <var_v:AbstractCompilerVisitor>*/
+}
+if (varonce404) {
+var405 = varonce404;
 } 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;
+var406 = "unw_getcontext(&uc);";
+var407 = 20;
+var408 = string__NativeString__to_s_with_length(var406, var407);
+var405 = var408;
+varonce404 = var405;
+}
+{
+abstract_compiler__AbstractCompilerVisitor__add_decl(var_v, var405); /* Direct call abstract_compiler#AbstractCompilerVisitor#add_decl on <var_v:AbstractCompilerVisitor>*/
+}
+if (varonce409) {
+var410 = varonce409;
 } else {
-var17 = "Bool";
-var18 = 4;
-var19 = string__NativeString__to_s_with_length(var17, var18);
-var16 = var19;
-varonce15 = var16;
+var411 = "unw_init_local(&cursor, &uc);";
+var412 = 29;
+var413 = string__NativeString__to_s_with_length(var411, var412);
+var410 = var413;
+varonce409 = var410;
 }
-var20 = ((short int (*)(val*, val*))(var14->class->vft[COLOR_kernel__Object___61d_61d]))(var14, var16) /* == on <var14:String>*/;
-if (var20){
-if (varonce21) {
-var22 = varonce21;
+{
+abstract_compiler__AbstractCompilerVisitor__add_decl(var_v, var410); /* Direct call abstract_compiler#AbstractCompilerVisitor#add_decl on <var_v:AbstractCompilerVisitor>*/
+}
+if (varonce414) {
+var415 = varonce414;
 } else {
-var23 = "s";
-var24 = 1;
-var25 = string__NativeString__to_s_with_length(var23, var24);
-var22 = var25;
-varonce21 = var22;
+var416 = "PRINT_ERROR(\"-------------------------------------------------\\n\");";
+var417 = 67;
+var418 = string__NativeString__to_s_with_length(var416, var417);
+var415 = var418;
+varonce414 = var415;
 }
-var = var22;
-goto RET_LABEL;
+{
+abstract_compiler__AbstractCompilerVisitor__add_decl(var_v, var415); /* Direct call abstract_compiler#AbstractCompilerVisitor#add_decl on <var_v:AbstractCompilerVisitor>*/
+}
+if (varonce419) {
+var420 = varonce419;
 } 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;
+var421 = "PRINT_ERROR(\"--   Stack Trace   ------------------------------\\n\");";
+var422 = 67;
+var423 = string__NativeString__to_s_with_length(var421, var422);
+var420 = var423;
+varonce419 = var420;
+}
+{
+abstract_compiler__AbstractCompilerVisitor__add_decl(var_v, var420); /* Direct call abstract_compiler#AbstractCompilerVisitor#add_decl on <var_v:AbstractCompilerVisitor>*/
+}
+if (varonce424) {
+var425 = varonce424;
 } else {
-var30 = "Char";
-var31 = 4;
-var32 = string__NativeString__to_s_with_length(var30, var31);
-var29 = var32;
-varonce28 = var29;
+var426 = "PRINT_ERROR(\"-------------------------------------------------\\n\");";
+var427 = 67;
+var428 = string__NativeString__to_s_with_length(var426, var427);
+var425 = var428;
+varonce424 = var425;
 }
-var33 = ((short int (*)(val*, val*))(var27->class->vft[COLOR_kernel__Object___61d_61d]))(var27, var29) /* == on <var27:String>*/;
-if (var33){
-if (varonce34) {
-var35 = varonce34;
+{
+abstract_compiler__AbstractCompilerVisitor__add_decl(var_v, var425); /* Direct call abstract_compiler#AbstractCompilerVisitor#add_decl on <var_v:AbstractCompilerVisitor>*/
+}
+if (varonce429) {
+var430 = varonce429;
 } else {
-var36 = "c";
-var37 = 1;
-var38 = string__NativeString__to_s_with_length(var36, var37);
-var35 = var38;
-varonce34 = var35;
+var431 = "while (unw_step(&cursor) > 0) {";
+var432 = 31;
+var433 = string__NativeString__to_s_with_length(var431, var432);
+var430 = var433;
+varonce429 = var430;
 }
-var = var35;
-goto RET_LABEL;
+{
+abstract_compiler__AbstractCompilerVisitor__add_decl(var_v, var430); /* Direct call abstract_compiler#AbstractCompilerVisitor#add_decl on <var_v:AbstractCompilerVisitor>*/
+}
+if (varonce434) {
+var435 = varonce434;
 } 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;
+var436 = "\11unw_get_proc_name(&cursor, procname, 100, &ip);";
+var437 = 48;
+var438 = string__NativeString__to_s_with_length(var436, var437);
+var435 = var438;
+varonce434 = var435;
+}
+{
+abstract_compiler__AbstractCompilerVisitor__add_decl(var_v, var435); /* Direct call abstract_compiler#AbstractCompilerVisitor#add_decl on <var_v:AbstractCompilerVisitor>*/
+}
+if (varonce439) {
+var440 = varonce439;
 } else {
-var43 = "Float";
-var44 = 5;
-var45 = string__NativeString__to_s_with_length(var43, var44);
-var42 = var45;
-varonce41 = var42;
+var441 = "nitstack";
+var442 = 8;
+var443 = string__NativeString__to_s_with_length(var441, var442);
+var440 = var443;
+varonce439 = var440;
 }
-var46 = ((short int (*)(val*, val*))(var40->class->vft[COLOR_kernel__Object___61d_61d]))(var40, var42) /* == on <var40:String>*/;
-if (var46){
-if (varonce47) {
-var48 = varonce47;
+if (var_ost == NULL) {
+var444 = 0; /* <var440:String> cannot be null */
 } else {
-var49 = "d";
-var50 = 1;
-var51 = string__NativeString__to_s_with_length(var49, var50);
-var48 = var51;
-varonce47 = var48;
+var445 = string__FlatString___61d_61d(var_ost, var440);
+var444 = var445;
 }
-var = var48;
-goto RET_LABEL;
+if (var444){
+if (varonce446) {
+var447 = varonce446;
 } 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;
+var448 = "\11const char* recv = get_nit_name(procname, strlen(procname));";
+var449 = 61;
+var450 = string__NativeString__to_s_with_length(var448, var449);
+var447 = var450;
+varonce446 = var447;
+}
+{
+abstract_compiler__AbstractCompilerVisitor__add_decl(var_v, var447); /* Direct call abstract_compiler#AbstractCompilerVisitor#add_decl on <var_v:AbstractCompilerVisitor>*/
+}
+if (varonce451) {
+var452 = varonce451;
 } else {
-var56 = "NativeString";
-var57 = 12;
-var58 = string__NativeString__to_s_with_length(var56, var57);
-var55 = var58;
-varonce54 = var55;
+var453 = "\11if (recv != NULL){";
+var454 = 19;
+var455 = string__NativeString__to_s_with_length(var453, var454);
+var452 = var455;
+varonce451 = var452;
 }
-var59 = ((short int (*)(val*, val*))(var53->class->vft[COLOR_kernel__Object___61d_61d]))(var53, var55) /* == on <var53:String>*/;
-if (var59){
-if (varonce60) {
-var61 = varonce60;
+{
+abstract_compiler__AbstractCompilerVisitor__add_decl(var_v, var452); /* Direct call abstract_compiler#AbstractCompilerVisitor#add_decl on <var_v:AbstractCompilerVisitor>*/
+}
+if (varonce456) {
+var457 = varonce456;
 } else {
-var62 = "str";
-var63 = 3;
-var64 = string__NativeString__to_s_with_length(var62, var63);
-var61 = var64;
-varonce60 = var61;
+var458 = "\11\11PRINT_ERROR(\"` %s\\n\", recv);";
+var459 = 30;
+var460 = string__NativeString__to_s_with_length(var458, var459);
+var457 = var460;
+varonce456 = var457;
 }
-var = var61;
-goto RET_LABEL;
+{
+abstract_compiler__AbstractCompilerVisitor__add_decl(var_v, var457); /* Direct call abstract_compiler#AbstractCompilerVisitor#add_decl on <var_v:AbstractCompilerVisitor>*/
+}
+if (varonce461) {
+var462 = varonce461;
 } 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;
-} else {
-var75 = "val";
-var76 = 3;
-var77 = string__NativeString__to_s_with_length(var75, var76);
-var74 = var77;
-varonce73 = var74;
-}
-var = var74;
-goto RET_LABEL;
+var463 = "\11}else{";
+var464 = 7;
+var465 = string__NativeString__to_s_with_length(var463, var464);
+var462 = var465;
+varonce461 = var462;
+}
+{
+abstract_compiler__AbstractCompilerVisitor__add_decl(var_v, var462); /* Direct call abstract_compiler#AbstractCompilerVisitor#add_decl on <var_v:AbstractCompilerVisitor>*/
+}
+if (varonce466) {
+var467 = varonce466;
 } 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;
+var468 = "\11\11PRINT_ERROR(\"` %s\\n\", procname);";
+var469 = 34;
+var470 = string__NativeString__to_s_with_length(var468, var469);
+var467 = var470;
+varonce466 = var467;
+}
+{
+abstract_compiler__AbstractCompilerVisitor__add_decl(var_v, var467); /* Direct call abstract_compiler#AbstractCompilerVisitor#add_decl on <var_v:AbstractCompilerVisitor>*/
+}
+if (varonce471) {
+var472 = varonce471;
 } else {
-if (varonce87) {
-var88 = varonce87;
+var473 = "\11}";
+var474 = 2;
+var475 = string__NativeString__to_s_with_length(var473, var474);
+var472 = var475;
+varonce471 = var472;
+}
+{
+abstract_compiler__AbstractCompilerVisitor__add_decl(var_v, var472); /* Direct call abstract_compiler#AbstractCompilerVisitor#add_decl on <var_v:AbstractCompilerVisitor>*/
+}
 } else {
-var89 = "val";
-var90 = 3;
-var91 = string__NativeString__to_s_with_length(var89, var90);
-var88 = var91;
-varonce87 = var88;
+if (varonce476) {
+var477 = varonce476;
+} else {
+var478 = "\11PRINT_ERROR(\"` %s \\n\",procname);";
+var479 = 33;
+var480 = string__NativeString__to_s_with_length(var478, var479);
+var477 = var480;
+varonce476 = var477;
 }
-var = var88;
-goto RET_LABEL;
+{
+abstract_compiler__AbstractCompilerVisitor__add_decl(var_v, var477); /* Direct call abstract_compiler#AbstractCompilerVisitor#add_decl on <var_v:AbstractCompilerVisitor>*/
 }
 }
+if (varonce481) {
+var482 = varonce481;
+} else {
+var483 = "}";
+var484 = 1;
+var485 = string__NativeString__to_s_with_length(var483, var484);
+var482 = var485;
+varonce481 = var482;
 }
+{
+abstract_compiler__AbstractCompilerVisitor__add_decl(var_v, var482); /* Direct call abstract_compiler#AbstractCompilerVisitor#add_decl on <var_v:AbstractCompilerVisitor>*/
 }
+if (varonce486) {
+var487 = varonce486;
+} else {
+var488 = "PRINT_ERROR(\"-------------------------------------------------\\n\");";
+var489 = 67;
+var490 = string__NativeString__to_s_with_length(var488, var489);
+var487 = var490;
+varonce486 = var487;
 }
+{
+abstract_compiler__AbstractCompilerVisitor__add_decl(var_v, var487); /* Direct call abstract_compiler#AbstractCompilerVisitor#add_decl on <var_v:AbstractCompilerVisitor>*/
 }
+if (varonce491) {
+var492 = varonce491;
+} else {
+var493 = "free(procname);";
+var494 = 15;
+var495 = string__NativeString__to_s_with_length(var493, var494);
+var492 = var495;
+varonce491 = var492;
 }
-RET_LABEL:;
-return var;
+{
+abstract_compiler__AbstractCompilerVisitor__add_decl(var_v, var492); /* Direct call abstract_compiler#AbstractCompilerVisitor#add_decl on <var_v:AbstractCompilerVisitor>*/
 }
-/* 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;
+if (varonce496) {
+var497 = varonce496;
+} else {
+var498 = "}";
+var499 = 1;
+var500 = string__NativeString__to_s_with_length(var498, var499);
+var497 = var500;
+varonce496 = var497;
+}
+{
+abstract_compiler__AbstractCompilerVisitor__add_decl(var_v, var497); /* Direct call abstract_compiler#AbstractCompilerVisitor#add_decl on <var_v:AbstractCompilerVisitor>*/
 }
-/* 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 */
 }
-if (var3){
-var = var_res;
-goto RET_LABEL;
+if (varonce501) {
+var502 = varonce501;
 } else {
+var503 = "exit(signo);";
+var504 = 12;
+var505 = string__NativeString__to_s_with_length(var503, var504);
+var502 = var505;
+varonce501 = var502;
 }
-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]>*/;
+{
+abstract_compiler__AbstractCompilerVisitor__add_decl(var_v, var502); /* Direct call abstract_compiler#AbstractCompilerVisitor#add_decl on <var_v:AbstractCompilerVisitor>*/
 }
-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;
-RET_LABEL:;
-return var;
+if (varonce506) {
+var507 = varonce506;
+} else {
+var508 = "}";
+var509 = 1;
+var510 = string__NativeString__to_s_with_length(var508, var509);
+var507 = var510;
+varonce506 = var507;
 }
-/* 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;
-RET_LABEL:;
-return var;
+{
+abstract_compiler__AbstractCompilerVisitor__add_decl(var_v, var507); /* Direct call abstract_compiler#AbstractCompilerVisitor#add_decl on <var_v:AbstractCompilerVisitor>*/
 }
-/* method abstract_compiler#MParameterType#c_name for (self: MParameterType): String */
-val* abstract_compiler__MParameterType__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 /* : String */;
-static val* varonce12;
-val* var13 /* : String */;
-char* var14 /* : NativeString */;
-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 */
+if (var_no_main){
+if (varonce511) {
+var512 = varonce511;
 } else {
-var3 = 1; /* arg is null and recv is not */
+var513 = "int nit_main(int argc, char** argv) {";
+var514 = 37;
+var515 = string__NativeString__to_s_with_length(var513, var514);
+var512 = var515;
+varonce511 = var512;
 }
-if (var3){
-var = var_res;
-goto RET_LABEL;
-} else {
+{
+abstract_compiler__AbstractCompilerVisitor__add_decl(var_v, var512); /* Direct call abstract_compiler#AbstractCompilerVisitor#add_decl on <var_v:AbstractCompilerVisitor>*/
 }
-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;
-}
-((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;
+if (varonce516) {
+var517 = varonce516;
 } else {
-var14 = "_FT";
-var15 = 3;
-var16 = string__NativeString__to_s_with_length(var14, var15);
-var13 = var16;
-varonce12 = var13;
+var518 = "int main(int argc, char** argv) {";
+var519 = 33;
+var520 = string__NativeString__to_s_with_length(var518, var519);
+var517 = var520;
+varonce516 = var517;
 }
-((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;
+{
+abstract_compiler__AbstractCompilerVisitor__add_decl(var_v, var517); /* Direct call abstract_compiler#AbstractCompilerVisitor#add_decl on <var_v:AbstractCompilerVisitor>*/
+}
+}
+if (varonce521) {
+var522 = varonce521;
 } else {
-var21 = "";
-var22 = 0;
-var23 = string__NativeString__to_s_with_length(var21, var22);
-var20 = var23;
-varonce19 = var20;
+var523 = "signal(SIGABRT, sig_handler);";
+var524 = 29;
+var525 = string__NativeString__to_s_with_length(var523, var524);
+var522 = var525;
+varonce521 = var522;
 }
-((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;
-goto RET_LABEL;
-RET_LABEL:;
-return var;
+{
+abstract_compiler__AbstractCompilerVisitor__add(var_v, var522); /* Direct call abstract_compiler#AbstractCompilerVisitor#add on <var_v:AbstractCompilerVisitor>*/
 }
-/* method abstract_compiler#MParameterType#c_name for (self: Object): String */
-val* VIRTUAL_abstract_compiler__MParameterType__c_name(val* self) {
-val* var /* : String */;
-val* var1 /* : String */;
-var1 = abstract_compiler__MParameterType__c_name(self);
-var = var1;
-RET_LABEL:;
-return var;
+if (varonce526) {
+var527 = varonce526;
+} else {
+var528 = "signal(SIGFPE, sig_handler);";
+var529 = 28;
+var530 = string__NativeString__to_s_with_length(var528, var529);
+var527 = var530;
+varonce526 = var527;
 }
-/* method abstract_compiler#MVirtualType#c_name for (self: MVirtualType): String */
-val* abstract_compiler__MVirtualType__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 /* : 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 */
+{
+abstract_compiler__AbstractCompilerVisitor__add(var_v, var527); /* Direct call abstract_compiler#AbstractCompilerVisitor#add on <var_v:AbstractCompilerVisitor>*/
+}
+if (varonce531) {
+var532 = varonce531;
 } else {
-var3 = 1; /* arg is null and recv is not */
+var533 = "signal(SIGILL, sig_handler);";
+var534 = 28;
+var535 = string__NativeString__to_s_with_length(var533, var534);
+var532 = var535;
+varonce531 = var532;
 }
-if (var3){
-var = var_res;
-goto RET_LABEL;
+{
+abstract_compiler__AbstractCompilerVisitor__add(var_v, var532); /* Direct call abstract_compiler#AbstractCompilerVisitor#add on <var_v:AbstractCompilerVisitor>*/
+}
+if (varonce536) {
+var537 = varonce536;
 } else {
+var538 = "signal(SIGINT, sig_handler);";
+var539 = 28;
+var540 = string__NativeString__to_s_with_length(var538, var539);
+var537 = var540;
+varonce536 = var537;
 }
-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;
+{
+abstract_compiler__AbstractCompilerVisitor__add(var_v, var537); /* Direct call abstract_compiler#AbstractCompilerVisitor#add on <var_v:AbstractCompilerVisitor>*/
+}
+if (varonce541) {
+var542 = varonce541;
 } else {
-var7 = "";
-var8 = 0;
-var9 = string__NativeString__to_s_with_length(var7, var8);
-var6 = var9;
-varonce = var6;
+var543 = "signal(SIGTERM, sig_handler);";
+var544 = 29;
+var545 = string__NativeString__to_s_with_length(var543, var544);
+var542 = var545;
+varonce541 = var542;
 }
-((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;
+{
+abstract_compiler__AbstractCompilerVisitor__add(var_v, var542); /* Direct call abstract_compiler#AbstractCompilerVisitor#add on <var_v:AbstractCompilerVisitor>*/
+}
+if (varonce546) {
+var547 = varonce546;
 } else {
-var17 = "_VT";
-var18 = 3;
-var19 = string__NativeString__to_s_with_length(var17, var18);
-var16 = var19;
-varonce15 = var16;
+var548 = "signal(SIGSEGV, sig_handler);";
+var549 = 29;
+var550 = string__NativeString__to_s_with_length(var548, var549);
+var547 = var550;
+varonce546 = var547;
+}
+{
+abstract_compiler__AbstractCompilerVisitor__add(var_v, var547); /* Direct call abstract_compiler#AbstractCompilerVisitor#add on <var_v:AbstractCompilerVisitor>*/
 }
-((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;
+if (varonce551) {
+var552 = varonce551;
 } 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;
-RET_LABEL:;
-return var;
+var553 = "signal(SIGPIPE, sig_handler);";
+var554 = 29;
+var555 = string__NativeString__to_s_with_length(var553, var554);
+var552 = var555;
+varonce551 = var552;
 }
-/* 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);
-var = var1;
-RET_LABEL:;
-return var;
+{
+abstract_compiler__AbstractCompilerVisitor__add(var_v, var552); /* Direct call abstract_compiler#AbstractCompilerVisitor#add on <var_v:AbstractCompilerVisitor>*/
 }
-/* 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 */
+if (varonce556) {
+var557 = varonce556;
 } else {
-var3 = 1; /* arg is null and recv is not */
+var558 = "glob_argc = argc; glob_argv = argv;";
+var559 = 35;
+var560 = string__NativeString__to_s_with_length(var558, var559);
+var557 = var560;
+varonce556 = var557;
 }
-if (var3){
-var = var_res;
-goto RET_LABEL;
-} else {
+{
+abstract_compiler__AbstractCompilerVisitor__add(var_v, var557); /* Direct call abstract_compiler#AbstractCompilerVisitor#add on <var_v:AbstractCompilerVisitor>*/
 }
-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;
+if (varonce561) {
+var562 = varonce561;
 } else {
-var7 = "nullable_";
-var8 = 9;
-var9 = string__NativeString__to_s_with_length(var7, var8);
-var6 = var9;
-varonce = var6;
+var563 = "initialize_gc_option();";
+var564 = 23;
+var565 = string__NativeString__to_s_with_length(var563, var564);
+var562 = var565;
+varonce561 = var562;
+}
+{
+abstract_compiler__AbstractCompilerVisitor__add(var_v, var562); /* Direct call abstract_compiler#AbstractCompilerVisitor#add on <var_v:AbstractCompilerVisitor>*/
+}
+if (varonce566) {
+var567 = varonce566;
+} else {
+var568 = "initialize_nitni_global_refs();";
+var569 = 31;
+var570 = string__NativeString__to_s_with_length(var568, var569);
+var567 = var570;
+varonce566 = var567;
+}
+{
+abstract_compiler__AbstractCompilerVisitor__add(var_v, var567); /* Direct call abstract_compiler#AbstractCompilerVisitor#add on <var_v:AbstractCompilerVisitor>*/
+}
+{
+{ /* Inline abstract_compiler#AbstractCompiler#mainmodule (self) on <self:AbstractCompiler> */
+var573 = self->attrs[COLOR_abstract_compiler__AbstractCompiler___mainmodule].val; /* _mainmodule on <self:AbstractCompiler> */
+if (unlikely(var573 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _mainmodule");
+PRINT_ERROR(" (%s:%d)\n", "src/abstract_compiler.nit", 436);
+show_backtrace(1);
+}
+var571 = var573;
+RET_LABEL572:(void)0;
+}
+}
+{
+var574 = model__MModule__sys_type(var571);
+}
+var_main_type = var574;
+var575 = NULL;
+if (var_main_type == NULL) {
+var576 = 0; /* is null */
+} else {
+var576 = 1; /* arg is null and recv is not */
+}
+if (0) {
+{ /* Inline kernel#Object#!= (var_main_type,var575) on <var_main_type:nullable MClassType> */
+var_other = var575;
+{
+var580 = ((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)>*/;
+var579 = var580;
+}
+var581 = !var579;
+var577 = var581;
+goto RET_LABEL578;
+RET_LABEL578:(void)0;
+}
+var576 = var577;
+}
+if (var576){
+{
+{ /* Inline abstract_compiler#AbstractCompilerVisitor#compiler (var_v) on <var_v:AbstractCompilerVisitor> */
+var584 = var_v->attrs[COLOR_abstract_compiler__AbstractCompilerVisitor___compiler].val; /* _compiler on <var_v:AbstractCompilerVisitor> */
+if (unlikely(var584 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _compiler");
+PRINT_ERROR(" (%s:%d)\n", "src/abstract_compiler.nit", 984);
+show_backtrace(1);
+}
+var582 = var584;
+RET_LABEL583:(void)0;
+}
+}
+{
+{ /* Inline abstract_compiler#AbstractCompiler#mainmodule (var582) on <var582:AbstractCompiler> */
+var587 = var582->attrs[COLOR_abstract_compiler__AbstractCompiler___mainmodule].val; /* _mainmodule on <var582:AbstractCompiler> */
+if (unlikely(var587 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _mainmodule");
+PRINT_ERROR(" (%s:%d)\n", "src/abstract_compiler.nit", 436);
+show_backtrace(1);
+}
+var585 = var587;
+RET_LABEL586:(void)0;
+}
+}
+var_mainmodule = var585;
+{
+var588 = ((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 = var588;
+if (varonce589) {
+var590 = varonce589;
+} else {
+var591 = "glob_sys = ";
+var592 = 11;
+var593 = string__NativeString__to_s_with_length(var591, var592);
+var590 = var593;
+varonce589 = var590;
+}
+if (varonce594) {
+var595 = varonce594;
+} else {
+var596 = ";";
+var597 = 1;
+var598 = string__NativeString__to_s_with_length(var596, var597);
+var595 = var598;
+varonce594 = var595;
+}
+var599 = NEW_array__Array(&type_array__Arraykernel__Object);
+{ /* var599 = array_instance Array[Object] */
+var600 = 3;
+var601 = NEW_array__NativeArray(var600, &type_array__NativeArraykernel__Object);
+((struct instance_array__NativeArray*)var601)->values[0] = (val*) var590;
+((struct instance_array__NativeArray*)var601)->values[1] = (val*) var_glob_sys;
+((struct instance_array__NativeArray*)var601)->values[2] = (val*) var595;
+{
+((void (*)(val*, val*, long))(var599->class->vft[COLOR_array__Array__with_native]))(var599, var601, var600) /* with_native on <var599:Array[Object]>*/;
+}
+}
+{
+var602 = ((val* (*)(val*))(var599->class->vft[COLOR_string__Object__to_s]))(var599) /* to_s on <var599:Array[Object]>*/;
+}
+{
+abstract_compiler__AbstractCompilerVisitor__add(var_v, var602); /* Direct call abstract_compiler#AbstractCompilerVisitor#add on <var_v:AbstractCompilerVisitor>*/
+}
+if (varonce603) {
+var604 = varonce603;
+} else {
+var605 = "init";
+var606 = 4;
+var607 = string__NativeString__to_s_with_length(var605, var606);
+var604 = var607;
+varonce603 = var604;
 }
-((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;
+{
+{ /* Inline model#MClassType#mclass (var_main_type) on <var_main_type:nullable MClassType(MClassType)> */
+var610 = var_main_type->attrs[COLOR_model__MClassType___mclass].val; /* _mclass on <var_main_type:nullable MClassType(MClassType)> */
+if (unlikely(var610 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _mclass");
+PRINT_ERROR(" (%s:%d)\n", "src/model/model.nit", 969);
+show_backtrace(1);
+}
+var608 = var610;
+RET_LABEL609:(void)0;
+}
+}
+{
+var611 = model__MModule__try_get_primitive_method(var_mainmodule, var604, var608);
+}
+var_main_init = var611;
+var612 = NULL;
+if (var_main_init == NULL) {
+var613 = 0; /* is null */
+} else {
+var613 = 1; /* arg is null and recv is not */
+}
+if (0) {
+{ /* Inline kernel#Object#!= (var_main_init,var612) on <var_main_init:nullable MMethod> */
+var_other = var612;
+{
+var617 = ((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)>*/;
+var616 = var617;
+}
+var618 = !var616;
+var614 = var618;
+goto RET_LABEL615;
+RET_LABEL615:(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__MType__c_name_cache_61d]))(self, var_res) /* c_name_cache= on <self:MNullableType>*/;
-var = var_res;
-goto RET_LABEL;
-RET_LABEL:;
-return var;
+var613 = var614;
 }
-/* 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);
-var = var1;
-RET_LABEL:;
-return var;
+if (var613){
+var619 = NEW_array__Array(&type_array__Arrayabstract_compiler__RuntimeVariable);
+var620 = 1;
+{
+array__Array__with_capacity(var619, var620); /* Direct call array#Array#with_capacity on <var619:Array[RuntimeVariable]>*/
 }
-/* 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 */
+var_621 = var619;
+{
+array__AbstractArray__push(var_621, var_glob_sys); /* Direct call array#AbstractArray#push on <var_621:Array[RuntimeVariable]>*/
 }
-if (var3){
-var = var_res;
-goto RET_LABEL;
-} else {
+{
+var622 = separate_compiler__SeparateCompilerVisitor__send(var_v, var_main_init, var_621);
 }
-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;
+var622;
 } else {
-var7 = "";
-var8 = 0;
-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__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;
+if (varonce623) {
+var624 = varonce623;
 } else {
-var15 = "__";
-var16 = 2;
-var17 = string__NativeString__to_s_with_length(var15, var16);
-var14 = var17;
-varonce13 = var14;
+var625 = "main";
+var626 = 4;
+var627 = string__NativeString__to_s_with_length(var625, var626);
+var624 = var627;
+varonce623 = var624;
 }
-((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:;
-return var;
+{
+{ /* Inline model#MClassType#mclass (var_main_type) on <var_main_type:nullable MClassType(MClassType)> */
+var630 = var_main_type->attrs[COLOR_model__MClassType___mclass].val; /* _mclass on <var_main_type:nullable MClassType(MClassType)> */
+if (unlikely(var630 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _mclass");
+PRINT_ERROR(" (%s:%d)\n", "src/model/model.nit", 969);
+show_backtrace(1);
 }
-/* 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);
-var = var1;
-RET_LABEL:;
-return var;
+var628 = var630;
+RET_LABEL629:(void)0;
 }
-/* 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> */
-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);
-var = var1;
-RET_LABEL:;
-return var;
+{
+var631 = model__MModule__try_get_primitive_method(var_mainmodule, var624, var628);
 }
-/* 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> */
-RET_LABEL:;
+var_main_method = var631;
+var632 = NULL;
+if (var_main_method == NULL) {
+var633 = 0; /* is null */
+} else {
+var633 = 1; /* arg is null and recv is not */
 }
-/* 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);
-RET_LABEL:;
+if (0) {
+{ /* Inline kernel#Object#!= (var_main_method,var632) on <var_main_method:nullable MMethod> */
+var_other = var632;
+{
+var637 = ((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)>*/;
+var636 = var637;
 }
-/* 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 */
+var638 = !var636;
+var634 = var638;
+goto RET_LABEL635;
+RET_LABEL635:(void)0;
 }
-if (var3){
-var = var_res;
-goto RET_LABEL;
-} else {
+var633 = var634;
 }
-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;
+if (var633){
+var639 = NEW_array__Array(&type_array__Arrayabstract_compiler__RuntimeVariable);
+var640 = 1;
+{
+array__Array__with_capacity(var639, var640); /* Direct call array#Array#with_capacity on <var639:Array[RuntimeVariable]>*/
+}
+var_641 = var639;
+{
+array__AbstractArray__push(var_641, var_glob_sys); /* Direct call array#AbstractArray#push on <var_641:Array[RuntimeVariable]>*/
+}
+{
+var642 = separate_compiler__SeparateCompilerVisitor__send(var_v, var_main_method, var_641);
+}
+var642;
 } else {
-var7 = "";
-var8 = 0;
-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__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;
 }
-((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;
-RET_LABEL:;
-return var;
+{
+{ /* Inline abstract_compiler#AbstractCompiler#modelbuilder (self) on <self:AbstractCompiler> */
+var645 = self->attrs[COLOR_abstract_compiler__AbstractCompiler___modelbuilder].val; /* _modelbuilder on <self:AbstractCompiler> */
+if (unlikely(var645 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _modelbuilder");
+PRINT_ERROR(" (%s:%d)\n", "src/abstract_compiler.nit", 443);
+show_backtrace(1);
 }
-/* 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);
-var = var1;
-RET_LABEL:;
-return var;
+var643 = var645;
+RET_LABEL644:(void)0;
 }
-/* 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> */
-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);
-var = var1;
-RET_LABEL:;
-return var;
+{
+{ /* Inline modelbuilder#ModelBuilder#toolcontext (var643) on <var643:ModelBuilder> */
+var648 = var643->attrs[COLOR_modelbuilder__ModelBuilder___toolcontext].val; /* _toolcontext on <var643:ModelBuilder> */
+if (unlikely(var648 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _toolcontext");
+PRINT_ERROR(" (%s:%d)\n", "src/modelbuilder.nit", 101);
+show_backtrace(1);
 }
-/* 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> */
-RET_LABEL:;
+var646 = var648;
+RET_LABEL647:(void)0;
 }
-/* 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);
-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> */
-var = var1;
-RET_LABEL:;
-return var;
+{
+{ /* Inline abstract_compiler#ToolContext#opt_typing_test_metrics (var646) on <var646:ToolContext> */
+var651 = var646->attrs[COLOR_abstract_compiler__ToolContext___opt_typing_test_metrics].val; /* _opt_typing_test_metrics on <var646:ToolContext> */
+if (unlikely(var651 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _opt_typing_test_metrics");
+PRINT_ERROR(" (%s:%d)\n", "src/abstract_compiler.nit", 56);
+show_backtrace(1);
 }
-/* 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);
-var = var1;
-RET_LABEL:;
-return var;
+var649 = var651;
+RET_LABEL650:(void)0;
 }
-/* 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> */
-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);
-RET_LABEL:;
+{
+{ /* Inline opts#Option#value (var649) on <var649:OptionBool> */
+var654 = var649->attrs[COLOR_opts__Option___value].val; /* _value on <var649:OptionBool> */
+var652 = var654;
+RET_LABEL653:(void)0;
 }
-/* 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 */
 }
-if (var3){
-var = var_res;
-goto RET_LABEL;
+var655 = ((struct instance_kernel__Bool*)var652)->value; /* autounbox from nullable Object to Bool */;
+if (var655){
+if (varonce656) {
+var657 = varonce656;
 } else {
+var658 = "long count_type_test_resolved_total = 0;";
+var659 = 40;
+var660 = string__NativeString__to_s_with_length(var658, var659);
+var657 = var660;
+varonce656 = var657;
 }
-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;
+{
+abstract_compiler__AbstractCompilerVisitor__add_decl(var_v, var657); /* Direct call abstract_compiler#AbstractCompilerVisitor#add_decl on <var_v:AbstractCompilerVisitor>*/
 }
-((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;
+if (varonce661) {
+var662 = varonce661;
 } else {
-var16 = "__";
-var17 = 2;
-var18 = string__NativeString__to_s_with_length(var16, var17);
-var15 = var18;
-varonce14 = var15;
+var663 = "long count_type_test_unresolved_total = 0;";
+var664 = 42;
+var665 = string__NativeString__to_s_with_length(var663, var664);
+var662 = var665;
+varonce661 = var662;
 }
-((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;
+{
+abstract_compiler__AbstractCompilerVisitor__add_decl(var_v, var662); /* Direct call abstract_compiler#AbstractCompilerVisitor#add_decl on <var_v:AbstractCompilerVisitor>*/
 }
-((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;
-goto RET_LABEL;
-RET_LABEL:;
-return var;
+if (varonce666) {
+var667 = varonce666;
+} else {
+var668 = "long count_type_test_skipped_total = 0;";
+var669 = 39;
+var670 = string__NativeString__to_s_with_length(var668, var669);
+var667 = var670;
+varonce666 = var667;
 }
-/* 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);
-var = var1;
-RET_LABEL:;
-return var;
+{
+abstract_compiler__AbstractCompilerVisitor__add_decl(var_v, var667); /* Direct call abstract_compiler#AbstractCompilerVisitor#add_decl on <var_v:AbstractCompilerVisitor>*/
 }
-/* method abstract_compiler#MMethodDef#can_inline for (self: MMethodDef, AbstractCompilerVisitor): Bool */
-short int abstract_compiler__MMethodDef__can_inline(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];
-cltype = type_struct->color;
-idtype = type_struct->id;
-if(cltype >= p0->type->table_size) {
-var1 = 0;
+if (varonce671) {
+var672 = varonce671;
 } else {
-var1 = p0->type->type_table[cltype] == idtype;
+var673 = "long count_type_test_total_total = 0;";
+var674 = 37;
+var675 = string__NativeString__to_s_with_length(var673, var674);
+var672 = var675;
+varonce671 = var672;
 }
-if (!var1) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "src/abstract_compiler.nit", 1229);
-exit(1);
+{
+abstract_compiler__AbstractCompilerVisitor__add_decl(var_v, var672); /* Direct call abstract_compiler#AbstractCompilerVisitor#add_decl on <var_v:AbstractCompilerVisitor>*/
 }
-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;
-} else {
-var12 = "init";
-var13 = 4;
-var14 = string__NativeString__to_s_with_length(var12, var13);
-var11 = var14;
-varonce = var11;
+{
+{ /* Inline abstract_compiler#AbstractCompiler#count_type_test_tags (self) on <self:AbstractCompiler> */
+var678 = self->attrs[COLOR_abstract_compiler__AbstractCompiler___count_type_test_tags].val; /* _count_type_test_tags on <self:AbstractCompiler> */
+if (unlikely(var678 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _count_type_test_tags");
+PRINT_ERROR(" (%s:%d)\n", "src/abstract_compiler.nit", 888);
+show_backtrace(1);
 }
-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);
+var676 = var678;
+RET_LABEL677:(void)0;
 }
 }
-RET_LABEL:;
-return var;
+{
+var679 = array__AbstractArrayRead__iterator(var676);
 }
-/* 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);
-var = var1;
-RET_LABEL:;
-return var;
+for(;;) {
+{
+var680 = array__ArrayIterator__is_ok(var679);
+}
+if(!var680) break;
+{
+var681 = array__ArrayIterator__item(var679);
+}
+var_tag682 = var681;
+if (varonce683) {
+var684 = varonce683;
+} else {
+var685 = "long count_type_test_total_";
+var686 = 27;
+var687 = string__NativeString__to_s_with_length(var685, var686);
+var684 = var687;
+varonce683 = var684;
+}
+if (varonce688) {
+var689 = varonce688;
+} else {
+var690 = ";";
+var691 = 1;
+var692 = string__NativeString__to_s_with_length(var690, var691);
+var689 = var692;
+varonce688 = var689;
+}
+var693 = NEW_array__Array(&type_array__Arraykernel__Object);
+{ /* var693 = array_instance Array[Object] */
+var694 = 3;
+var695 = NEW_array__NativeArray(var694, &type_array__NativeArraykernel__Object);
+((struct instance_array__NativeArray*)var695)->values[0] = (val*) var684;
+((struct instance_array__NativeArray*)var695)->values[1] = (val*) var_tag682;
+((struct instance_array__NativeArray*)var695)->values[2] = (val*) var689;
+{
+((void (*)(val*, val*, long))(var693->class->vft[COLOR_array__Array__with_native]))(var693, var695, var694) /* with_native on <var693:Array[Object]>*/;
+}
+}
+{
+var696 = ((val* (*)(val*))(var693->class->vft[COLOR_string__Object__to_s]))(var693) /* to_s on <var693:Array[Object]>*/;
+}
+{
+abstract_compiler__AbstractCompilerVisitor__add_decl(var_v, var696); /* Direct call abstract_compiler#AbstractCompilerVisitor#add_decl on <var_v:AbstractCompilerVisitor>*/
+}
+if (varonce697) {
+var698 = varonce697;
+} else {
+var699 = "count_type_test_total_";
+var700 = 22;
+var701 = string__NativeString__to_s_with_length(var699, var700);
+var698 = var701;
+varonce697 = var698;
+}
+if (varonce702) {
+var703 = varonce702;
+} else {
+var704 = " = count_type_test_resolved_";
+var705 = 28;
+var706 = string__NativeString__to_s_with_length(var704, var705);
+var703 = var706;
+varonce702 = var703;
 }
-/* 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 */;
-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* 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) {
-var1 = 0;
+if (varonce707) {
+var708 = varonce707;
 } else {
-var1 = p0->type->type_table[cltype] == idtype;
+var709 = " + count_type_test_unresolved_";
+var710 = 30;
+var711 = string__NativeString__to_s_with_length(var709, var710);
+var708 = var711;
+varonce707 = var708;
 }
-if (!var1) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "src/abstract_compiler.nit", 1244);
-exit(1);
+if (varonce712) {
+var713 = varonce712;
+} else {
+var714 = " + count_type_test_skipped_";
+var715 = 27;
+var716 = string__NativeString__to_s_with_length(var714, var715);
+var713 = var716;
+varonce712 = var713;
+}
+if (varonce717) {
+var718 = varonce717;
+} else {
+var719 = ";";
+var720 = 1;
+var721 = string__NativeString__to_s_with_length(var719, var720);
+var718 = var721;
+varonce717 = var718;
+}
+var722 = NEW_array__Array(&type_array__Arraykernel__Object);
+{ /* var722 = array_instance Array[Object] */
+var723 = 9;
+var724 = NEW_array__NativeArray(var723, &type_array__NativeArraykernel__Object);
+((struct instance_array__NativeArray*)var724)->values[0] = (val*) var698;
+((struct instance_array__NativeArray*)var724)->values[1] = (val*) var_tag682;
+((struct instance_array__NativeArray*)var724)->values[2] = (val*) var703;
+((struct instance_array__NativeArray*)var724)->values[3] = (val*) var_tag682;
+((struct instance_array__NativeArray*)var724)->values[4] = (val*) var708;
+((struct instance_array__NativeArray*)var724)->values[5] = (val*) var_tag682;
+((struct instance_array__NativeArray*)var724)->values[6] = (val*) var713;
+((struct instance_array__NativeArray*)var724)->values[7] = (val*) var_tag682;
+((struct instance_array__NativeArray*)var724)->values[8] = (val*) var718;
+{
+((void (*)(val*, val*, long))(var722->class->vft[COLOR_array__Array__with_native]))(var722, var724, var723) /* with_native on <var722:Array[Object]>*/;
+}
+}
+{
+var725 = ((val* (*)(val*))(var722->class->vft[COLOR_string__Object__to_s]))(var722) /* to_s on <var722:Array[Object]>*/;
+}
+{
+abstract_compiler__AbstractCompilerVisitor__add(var_v, var725); /* Direct call abstract_compiler#AbstractCompilerVisitor#add on <var_v:AbstractCompilerVisitor>*/
+}
+if (varonce726) {
+var727 = varonce726;
+} else {
+var728 = "count_type_test_resolved_total += count_type_test_resolved_";
+var729 = 59;
+var730 = string__NativeString__to_s_with_length(var728, var729);
+var727 = var730;
+varonce726 = var727;
+}
+if (varonce731) {
+var732 = varonce731;
+} else {
+var733 = ";";
+var734 = 1;
+var735 = string__NativeString__to_s_with_length(var733, var734);
+var732 = var735;
+varonce731 = var732;
+}
+var736 = NEW_array__Array(&type_array__Arraykernel__Object);
+{ /* var736 = array_instance Array[Object] */
+var737 = 3;
+var738 = NEW_array__NativeArray(var737, &type_array__NativeArraykernel__Object);
+((struct instance_array__NativeArray*)var738)->values[0] = (val*) var727;
+((struct instance_array__NativeArray*)var738)->values[1] = (val*) var_tag682;
+((struct instance_array__NativeArray*)var738)->values[2] = (val*) var732;
+{
+((void (*)(val*, val*, long))(var736->class->vft[COLOR_array__Array__with_native]))(var736, var738, var737) /* with_native on <var736:Array[Object]>*/;
+}
+}
+{
+var739 = ((val* (*)(val*))(var736->class->vft[COLOR_string__Object__to_s]))(var736) /* to_s on <var736:Array[Object]>*/;
+}
+{
+abstract_compiler__AbstractCompilerVisitor__add(var_v, var739); /* Direct call abstract_compiler#AbstractCompilerVisitor#add on <var_v:AbstractCompilerVisitor>*/
 }
-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;
+if (varonce740) {
+var741 = varonce740;
 } else {
-var12 = "init";
-var13 = 4;
-var14 = string__NativeString__to_s_with_length(var12, var13);
-var11 = var14;
-varonce = var11;
+var742 = "count_type_test_unresolved_total += count_type_test_unresolved_";
+var743 = 63;
+var744 = string__NativeString__to_s_with_length(var742, var743);
+var741 = var744;
+varonce740 = var741;
 }
-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;
-goto RET_LABEL;
-RET_LABEL:;
-return var;
+if (varonce745) {
+var746 = varonce745;
+} else {
+var747 = ";";
+var748 = 1;
+var749 = string__NativeString__to_s_with_length(var747, var748);
+var746 = var749;
+varonce745 = var746;
 }
-/* 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);
-var = var1;
-RET_LABEL:;
-return var;
+var750 = NEW_array__Array(&type_array__Arraykernel__Object);
+{ /* var750 = array_instance Array[Object] */
+var751 = 3;
+var752 = NEW_array__NativeArray(var751, &type_array__NativeArraykernel__Object);
+((struct instance_array__NativeArray*)var752)->values[0] = (val*) var741;
+((struct instance_array__NativeArray*)var752)->values[1] = (val*) var_tag682;
+((struct instance_array__NativeArray*)var752)->values[2] = (val*) var746;
+{
+((void (*)(val*, val*, long))(var750->class->vft[COLOR_array__Array__with_native]))(var750, var752, var751) /* with_native on <var750:Array[Object]>*/;
 }
-/* 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 */;
-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 */;
-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* 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* 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;
 }
-if (!var) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "src/abstract_compiler.nit", 1268);
-exit(1);
+{
+var753 = ((val* (*)(val*))(var750->class->vft[COLOR_string__Object__to_s]))(var750) /* to_s on <var750:Array[Object]>*/;
 }
-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;
+{
+abstract_compiler__AbstractCompilerVisitor__add(var_v, var753); /* Direct call abstract_compiler#AbstractCompilerVisitor#add on <var_v:AbstractCompilerVisitor>*/
+}
+if (varonce754) {
+var755 = varonce754;
 } else {
+var756 = "count_type_test_skipped_total += count_type_test_skipped_";
+var757 = 57;
+var758 = string__NativeString__to_s_with_length(var756, var757);
+var755 = var758;
+varonce754 = var755;
 }
-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);
+if (varonce759) {
+var760 = varonce759;
 } else {
-var10 = ((long (*)(val*))(var9->class->vft[COLOR_model__MSignature__arity]))(var9) /* arity on <var9:nullable MSignature>*/;
+var761 = ";";
+var762 = 1;
+var763 = string__NativeString__to_s_with_length(var761, var762);
+var760 = var763;
+varonce759 = var760;
 }
-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]>*/;
-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;
-var19 = var21;
-goto RET_LABEL20;
-RET_LABEL20:(void)0;
+var764 = NEW_array__Array(&type_array__Arraykernel__Object);
+{ /* var764 = array_instance Array[Object] */
+var765 = 3;
+var766 = NEW_array__NativeArray(var765, &type_array__NativeArraykernel__Object);
+((struct instance_array__NativeArray*)var766)->values[0] = (val*) var755;
+((struct instance_array__NativeArray*)var766)->values[1] = (val*) var_tag682;
+((struct instance_array__NativeArray*)var766)->values[2] = (val*) var760;
+{
+((void (*)(val*, val*, long))(var764->class->vft[COLOR_array__Array__with_native]))(var764, var766, var765) /* with_native on <var764:Array[Object]>*/;
 }
-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>*/;
+{
+var767 = ((val* (*)(val*))(var764->class->vft[COLOR_string__Object__to_s]))(var764) /* to_s on <var764:Array[Object]>*/;
+}
+{
+abstract_compiler__AbstractCompilerVisitor__add(var_v, var767); /* Direct call abstract_compiler#AbstractCompilerVisitor#add on <var_v:AbstractCompilerVisitor>*/
 }
-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;
+if (varonce768) {
+var769 = varonce768;
 } else {
+var770 = "count_type_test_total_total += count_type_test_total_";
+var771 = 53;
+var772 = string__NativeString__to_s_with_length(var770, var771);
+var769 = var772;
+varonce768 = var769;
 }
-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 (varonce773) {
+var774 = varonce773;
 } else {
-var31 = ((val* (*)(val*))(var30->class->vft[COLOR_model__MSignature__mparameters]))(var30) /* mparameters on <var30:nullable MSignature>*/;
+var775 = ";";
+var776 = 1;
+var777 = string__NativeString__to_s_with_length(var775, var776);
+var774 = var777;
+varonce773 = var774;
 }
-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;
+var778 = NEW_array__Array(&type_array__Arraykernel__Object);
+{ /* var778 = array_instance Array[Object] */
+var779 = 3;
+var780 = NEW_array__NativeArray(var779, &type_array__NativeArraykernel__Object);
+((struct instance_array__NativeArray*)var780)->values[0] = (val*) var769;
+((struct instance_array__NativeArray*)var780)->values[1] = (val*) var_tag682;
+((struct instance_array__NativeArray*)var780)->values[2] = (val*) var774;
+{
+((void (*)(val*, val*, long))(var778->class->vft[COLOR_array__Array__with_native]))(var778, var780, var779) /* with_native on <var778:Array[Object]>*/;
 }
-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;
 }
-((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;
+{
+var781 = ((val* (*)(val*))(var778->class->vft[COLOR_string__Object__to_s]))(var778) /* to_s on <var778:Array[Object]>*/;
 }
-((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]>*/;
+{
+abstract_compiler__AbstractCompilerVisitor__add(var_v, var781); /* Direct call abstract_compiler#AbstractCompilerVisitor#add on <var_v:AbstractCompilerVisitor>*/
 }
-BREAK_label: (void)0;
-RET_LABEL:;
+CONTINUE_label782: (void)0;
+{
+array__ArrayIterator__next(var679); /* Direct call array#ArrayIterator#next on <var679:ArrayIterator[nullable Object]>*/
 }
-/* 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:;
 }
-/* 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;
+BREAK_label782: (void)0;
+if (varonce783) {
+var784 = varonce783;
 } else {
-var1 = "printf(\"NOT YET IMPLEMENTED ";
-var2 = 28;
-var3 = string__NativeString__to_s_with_length(var1, var2);
-var = var3;
-varonce = var;
+var785 = "printf(\"# dynamic count_type_test: total %l\\n\");";
+var786 = 48;
+var787 = string__NativeString__to_s_with_length(var785, var786);
+var784 = var787;
+varonce783 = var784;
 }
-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;
+{
+abstract_compiler__AbstractCompilerVisitor__add(var_v, var784); /* Direct call abstract_compiler#AbstractCompilerVisitor#add on <var_v:AbstractCompilerVisitor>*/
 }
-if (varonce10) {
-var11 = varonce10;
+if (varonce788) {
+var789 = varonce788;
 } else {
-var12 = " at ";
-var13 = 4;
-var14 = string__NativeString__to_s_with_length(var12, var13);
-var11 = var14;
-varonce10 = var11;
+var790 = "printf(\"\\tresolved\\tunresolved\\tskipped\\ttotal\\n\");";
+var791 = 51;
+var792 = string__NativeString__to_s_with_length(var790, var791);
+var789 = var792;
+varonce788 = var789;
 }
-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;
+{
+abstract_compiler__AbstractCompilerVisitor__add(var_v, var789); /* Direct call abstract_compiler#AbstractCompilerVisitor#add on <var_v:AbstractCompilerVisitor>*/
 }
-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;
+{
+{ /* Inline abstract_compiler#AbstractCompiler#count_type_test_tags (self) on <self:AbstractCompiler> */
+var795 = self->attrs[COLOR_abstract_compiler__AbstractCompiler___count_type_test_tags].val; /* _count_type_test_tags on <self:AbstractCompiler> */
+if (unlikely(var795 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _count_type_test_tags");
+PRINT_ERROR(" (%s:%d)\n", "src/abstract_compiler.nit", 888);
+show_backtrace(1);
 }
-((void (*)(val*, val*))(self->class->vft[COLOR_parser_nodes__ANode__debug]))(self, var27) /* debug on <self:APropdef>*/;
-RET_LABEL:;
+var793 = var795;
+RET_LABEL794:(void)0;
 }
-/* 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:;
 }
-/* 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;
+{
+var796 = array__Collection__to_a(var793);
 }
-/* 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;
+var_tags = var796;
+if (varonce797) {
+var798 = varonce797;
+} else {
+var799 = "total";
+var800 = 5;
+var801 = string__NativeString__to_s_with_length(var799, var800);
+var798 = var801;
+varonce797 = var798;
+}
+{
+array__Array__add(var_tags, var798); /* Direct call array#Array#add on <var_tags:Array[String]>*/
+}
+{
+var802 = array__AbstractArrayRead__iterator(var_tags);
 }
-/* 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;
+{
+var803 = array__ArrayIterator__is_ok(var802);
+}
+if(!var803) break;
+{
+var804 = array__ArrayIterator__item(var802);
+}
+var_tag805 = var804;
+if (varonce806) {
+var807 = varonce806;
+} else {
+var808 = "printf(\"";
+var809 = 8;
+var810 = string__NativeString__to_s_with_length(var808, var809);
+var807 = var810;
+varonce806 = var807;
+}
+if (varonce811) {
+var812 = varonce811;
+} else {
+var813 = "\");";
+var814 = 3;
+var815 = string__NativeString__to_s_with_length(var813, var814);
+var812 = var815;
+varonce811 = var812;
+}
+var816 = NEW_array__Array(&type_array__Arraykernel__Object);
+{ /* var816 = array_instance Array[Object] */
+var817 = 3;
+var818 = NEW_array__NativeArray(var817, &type_array__NativeArraykernel__Object);
+((struct instance_array__NativeArray*)var818)->values[0] = (val*) var807;
+((struct instance_array__NativeArray*)var818)->values[1] = (val*) var_tag805;
+((struct instance_array__NativeArray*)var818)->values[2] = (val*) var812;
+{
+((void (*)(val*, val*, long))(var816->class->vft[COLOR_array__Array__with_native]))(var816, var818, var817) /* with_native on <var816:Array[Object]>*/;
+}
+}
+{
+var819 = ((val* (*)(val*))(var816->class->vft[COLOR_string__Object__to_s]))(var816) /* to_s on <var816:Array[Object]>*/;
+}
+{
+abstract_compiler__AbstractCompilerVisitor__add(var_v, var819); /* Direct call abstract_compiler#AbstractCompilerVisitor#add on <var_v:AbstractCompilerVisitor>*/
+}
+if (varonce820) {
+var821 = varonce820;
+} else {
+var822 = "printf(\"\\t%ld (%.2f%%)\", count_type_test_resolved_";
+var823 = 50;
+var824 = string__NativeString__to_s_with_length(var822, var823);
+var821 = var824;
+varonce820 = var821;
+}
+if (varonce825) {
+var826 = varonce825;
+} else {
+var827 = ", 100.0*count_type_test_resolved_";
+var828 = 33;
+var829 = string__NativeString__to_s_with_length(var827, var828);
+var826 = var829;
+varonce825 = var826;
 }
-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]>*/;
+if (varonce830) {
+var831 = varonce830;
+} else {
+var832 = "/count_type_test_total_total);";
+var833 = 30;
+var834 = string__NativeString__to_s_with_length(var832, var833);
+var831 = var834;
+varonce830 = var831;
 }
-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 */
+var835 = NEW_array__Array(&type_array__Arraykernel__Object);
+{ /* var835 = array_instance Array[Object] */
+var836 = 5;
+var837 = NEW_array__NativeArray(var836, &type_array__NativeArraykernel__Object);
+((struct instance_array__NativeArray*)var837)->values[0] = (val*) var821;
+((struct instance_array__NativeArray*)var837)->values[1] = (val*) var_tag805;
+((struct instance_array__NativeArray*)var837)->values[2] = (val*) var826;
+((struct instance_array__NativeArray*)var837)->values[3] = (val*) var_tag805;
+((struct instance_array__NativeArray*)var837)->values[4] = (val*) var831;
+{
+((void (*)(val*, val*, long))(var835->class->vft[COLOR_array__Array__with_native]))(var835, var837, var836) /* with_native on <var835:Array[Object]>*/;
+}
+}
+{
+var838 = ((val* (*)(val*))(var835->class->vft[COLOR_string__Object__to_s]))(var835) /* to_s on <var835:Array[Object]>*/;
+}
+{
+abstract_compiler__AbstractCompilerVisitor__add(var_v, var838); /* Direct call abstract_compiler#AbstractCompilerVisitor#add on <var_v:AbstractCompilerVisitor>*/
+}
+if (varonce839) {
+var840 = varonce839;
+} else {
+var841 = "printf(\"\\t%ld (%.2f%%)\", count_type_test_unresolved_";
+var842 = 52;
+var843 = string__NativeString__to_s_with_length(var841, var842);
+var840 = var843;
+varonce839 = var840;
+}
+if (varonce844) {
+var845 = varonce844;
+} else {
+var846 = ", 100.0*count_type_test_unresolved_";
+var847 = 35;
+var848 = string__NativeString__to_s_with_length(var846, var847);
+var845 = var848;
+varonce844 = var845;
+}
+if (varonce849) {
+var850 = varonce849;
+} else {
+var851 = "/count_type_test_total_total);";
+var852 = 30;
+var853 = string__NativeString__to_s_with_length(var851, var852);
+var850 = var853;
+varonce849 = var850;
+}
+var854 = NEW_array__Array(&type_array__Arraykernel__Object);
+{ /* var854 = array_instance Array[Object] */
+var855 = 5;
+var856 = NEW_array__NativeArray(var855, &type_array__NativeArraykernel__Object);
+((struct instance_array__NativeArray*)var856)->values[0] = (val*) var840;
+((struct instance_array__NativeArray*)var856)->values[1] = (val*) var_tag805;
+((struct instance_array__NativeArray*)var856)->values[2] = (val*) var845;
+((struct instance_array__NativeArray*)var856)->values[3] = (val*) var_tag805;
+((struct instance_array__NativeArray*)var856)->values[4] = (val*) var850;
+{
+((void (*)(val*, val*, long))(var854->class->vft[COLOR_array__Array__with_native]))(var854, var856, var855) /* with_native on <var854:Array[Object]>*/;
+}
+}
+{
+var857 = ((val* (*)(val*))(var854->class->vft[COLOR_string__Object__to_s]))(var854) /* to_s on <var854:Array[Object]>*/;
+}
+{
+abstract_compiler__AbstractCompilerVisitor__add(var_v, var857); /* Direct call abstract_compiler#AbstractCompilerVisitor#add on <var_v:AbstractCompilerVisitor>*/
+}
+if (varonce858) {
+var859 = varonce858;
+} else {
+var860 = "printf(\"\\t%ld (%.2f%%)\", count_type_test_skipped_";
+var861 = 49;
+var862 = string__NativeString__to_s_with_length(var860, var861);
+var859 = var862;
+varonce858 = var859;
+}
+if (varonce863) {
+var864 = varonce863;
+} else {
+var865 = ", 100.0*count_type_test_skipped_";
+var866 = 32;
+var867 = string__NativeString__to_s_with_length(var865, var866);
+var864 = var867;
+varonce863 = var864;
+}
+if (varonce868) {
+var869 = varonce868;
 } else {
-var22 = 1; /* arg is null and recv is not */
+var870 = "/count_type_test_total_total);";
+var871 = 30;
+var872 = string__NativeString__to_s_with_length(var870, var871);
+var869 = var872;
+varonce868 = var869;
 }
-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;
+var873 = NEW_array__Array(&type_array__Arraykernel__Object);
+{ /* var873 = array_instance Array[Object] */
+var874 = 5;
+var875 = NEW_array__NativeArray(var874, &type_array__NativeArraykernel__Object);
+((struct instance_array__NativeArray*)var875)->values[0] = (val*) var859;
+((struct instance_array__NativeArray*)var875)->values[1] = (val*) var_tag805;
+((struct instance_array__NativeArray*)var875)->values[2] = (val*) var864;
+((struct instance_array__NativeArray*)var875)->values[3] = (val*) var_tag805;
+((struct instance_array__NativeArray*)var875)->values[4] = (val*) var869;
+{
+((void (*)(val*, val*, long))(var873->class->vft[COLOR_array__Array__with_native]))(var873, var875, var874) /* with_native on <var873:Array[Object]>*/;
 }
-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;
+}
+{
+var876 = ((val* (*)(val*))(var873->class->vft[COLOR_string__Object__to_s]))(var873) /* to_s on <var873:Array[Object]>*/;
+}
+{
+abstract_compiler__AbstractCompilerVisitor__add(var_v, var876); /* Direct call abstract_compiler#AbstractCompilerVisitor#add on <var_v:AbstractCompilerVisitor>*/
+}
+if (varonce877) {
+var878 = varonce877;
 } 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;
+var879 = "printf(\"\\t%ld (%.2f%%)\\n\", count_type_test_total_";
+var880 = 49;
+var881 = string__NativeString__to_s_with_length(var879, var880);
+var878 = var881;
+varonce877 = var878;
 }
-CONTINUE_label38: (void)0;
-((void (*)(val*))(var26->class->vft[COLOR_abstract_collection__Iterator__next]))(var26) /* next on <var26:Iterator[nullable Object]>*/;
+if (varonce882) {
+var883 = varonce882;
+} else {
+var884 = ", 100.0*count_type_test_total_";
+var885 = 30;
+var886 = string__NativeString__to_s_with_length(var884, var885);
+var883 = var886;
+varonce882 = var883;
 }
-BREAK_label38: (void)0;
+if (varonce887) {
+var888 = varonce887;
 } else {
+var889 = "/count_type_test_total_total);";
+var890 = 30;
+var891 = string__NativeString__to_s_with_length(var889, var890);
+var888 = var891;
+varonce887 = var888;
 }
-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:;
+var892 = NEW_array__Array(&type_array__Arraykernel__Object);
+{ /* var892 = array_instance Array[Object] */
+var893 = 5;
+var894 = NEW_array__NativeArray(var893, &type_array__NativeArraykernel__Object);
+((struct instance_array__NativeArray*)var894)->values[0] = (val*) var878;
+((struct instance_array__NativeArray*)var894)->values[1] = (val*) var_tag805;
+((struct instance_array__NativeArray*)var894)->values[2] = (val*) var883;
+((struct instance_array__NativeArray*)var894)->values[3] = (val*) var_tag805;
+((struct instance_array__NativeArray*)var894)->values[4] = (val*) var888;
+{
+((void (*)(val*, val*, long))(var892->class->vft[COLOR_array__Array__with_native]))(var892, var894, var893) /* with_native on <var892:Array[Object]>*/;
 }
-/* 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:;
 }
-/* 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 */
+{
+var895 = ((val* (*)(val*))(var892->class->vft[COLOR_string__Object__to_s]))(var892) /* to_s on <var892:Array[Object]>*/;
+}
+{
+abstract_compiler__AbstractCompilerVisitor__add(var_v, var895); /* Direct call abstract_compiler#AbstractCompilerVisitor#add on <var_v:AbstractCompilerVisitor>*/
+}
+CONTINUE_label896: (void)0;
+{
+array__ArrayIterator__next(var802); /* Direct call array#ArrayIterator#next on <var802:ArrayIterator[nullable Object]>*/
+}
+}
+BREAK_label896: (void)0;
 } else {
-var3 = 1; /* arg is null and recv is not */
 }
-if (var3){
-var4 = 0;
-var = var4;
-goto RET_LABEL;
+{
+{ /* Inline abstract_compiler#AbstractCompiler#modelbuilder (self) on <self:AbstractCompiler> */
+var899 = self->attrs[COLOR_abstract_compiler__AbstractCompiler___modelbuilder].val; /* _modelbuilder on <self:AbstractCompiler> */
+if (unlikely(var899 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _modelbuilder");
+PRINT_ERROR(" (%s:%d)\n", "src/abstract_compiler.nit", 443);
+show_backtrace(1);
+}
+var897 = var899;
+RET_LABEL898:(void)0;
+}
+}
+{
+{ /* Inline modelbuilder#ModelBuilder#toolcontext (var897) on <var897:ModelBuilder> */
+var902 = var897->attrs[COLOR_modelbuilder__ModelBuilder___toolcontext].val; /* _toolcontext on <var897:ModelBuilder> */
+if (unlikely(var902 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _toolcontext");
+PRINT_ERROR(" (%s:%d)\n", "src/modelbuilder.nit", 101);
+show_backtrace(1);
+}
+var900 = var902;
+RET_LABEL901:(void)0;
+}
+}
+{
+{ /* Inline abstract_compiler#ToolContext#opt_invocation_metrics (var900) on <var900:ToolContext> */
+var905 = var900->attrs[COLOR_abstract_compiler__ToolContext___opt_invocation_metrics].val; /* _opt_invocation_metrics on <var900:ToolContext> */
+if (unlikely(var905 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _opt_invocation_metrics");
+PRINT_ERROR(" (%s:%d)\n", "src/abstract_compiler.nit", 58);
+show_backtrace(1);
+}
+var903 = var905;
+RET_LABEL904:(void)0;
+}
+}
+{
+{ /* Inline opts#Option#value (var903) on <var903:OptionBool> */
+var908 = var903->attrs[COLOR_opts__Option___value].val; /* _value on <var903:OptionBool> */
+var906 = var908;
+RET_LABEL907:(void)0;
+}
+}
+var909 = ((struct instance_kernel__Bool*)var906)->value; /* autounbox from nullable Object to Bool */;
+if (var909){
+if (varonce910) {
+var911 = varonce910;
 } else {
+var912 = "long count_invoke_total;";
+var913 = 24;
+var914 = string__NativeString__to_s_with_length(var912, var913);
+var911 = var914;
+varonce910 = var911;
+}
+{
+abstract_compiler__AbstractCompilerVisitor__add_decl(var_v, var911); /* Direct call abstract_compiler#AbstractCompilerVisitor#add_decl on <var_v:AbstractCompilerVisitor>*/
 }
-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 */
+if (varonce915) {
+var916 = varonce915;
 } else {
-var7 = 0; /* arg is null but recv is not */
+var917 = "count_invoke_total = count_invoke_by_tables + count_invoke_by_direct + count_invoke_by_inline;";
+var918 = 94;
+var919 = string__NativeString__to_s_with_length(var917, var918);
+var916 = var919;
+varonce915 = var916;
 }
-if (var7){
-var8 = 1;
-var = var8;
-goto RET_LABEL;
+{
+abstract_compiler__AbstractCompilerVisitor__add(var_v, var916); /* Direct call abstract_compiler#AbstractCompilerVisitor#add on <var_v:AbstractCompilerVisitor>*/
+}
+if (varonce920) {
+var921 = varonce920;
 } else {
+var922 = "printf(\"# dynamic count_invocation: total %ld\\n\", count_invoke_total);";
+var923 = 70;
+var924 = string__NativeString__to_s_with_length(var922, var923);
+var921 = var924;
+varonce920 = var921;
+}
+{
+abstract_compiler__AbstractCompilerVisitor__add(var_v, var921); /* Direct call abstract_compiler#AbstractCompilerVisitor#add on <var_v:AbstractCompilerVisitor>*/
 }
-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);
+if (varonce925) {
+var926 = varonce925;
 } else {
-var12 = ((val* (*)(val*))(var11->class->vft[COLOR_model__MPropDef__mproperty]))(var11) /* mproperty on <var11:nullable MPropDef(nullable MMethodDef)>*/;
+var927 = "printf(\"by table: %ld (%.2f%%)\\n\", count_invoke_by_tables, 100.0*count_invoke_by_tables/count_invoke_total);";
+var928 = 108;
+var929 = string__NativeString__to_s_with_length(var927, var928);
+var926 = var929;
+varonce925 = var926;
 }
-var13 = ((val* (*)(val*))(var12->class->vft[COLOR_model__MProperty__name]))(var12) /* name on <var12:MProperty(MMethod)>*/;
-if (varonce) {
-var14 = varonce;
+{
+abstract_compiler__AbstractCompilerVisitor__add(var_v, var926); /* Direct call abstract_compiler#AbstractCompilerVisitor#add on <var_v:AbstractCompilerVisitor>*/
+}
+if (varonce930) {
+var931 = varonce930;
 } else {
-var15 = "==";
-var16 = 2;
-var17 = string__NativeString__to_s_with_length(var15, var16);
-var14 = var17;
-varonce = var14;
+var932 = "printf(\"direct:   %ld (%.2f%%)\\n\", count_invoke_by_direct, 100.0*count_invoke_by_direct/count_invoke_total);";
+var933 = 108;
+var934 = string__NativeString__to_s_with_length(var932, var933);
+var931 = var934;
+varonce930 = var931;
 }
-var18 = ((short int (*)(val*, val*))(var13->class->vft[COLOR_kernel__Object___61d_61d]))(var13, var14) /* == on <var13:String>*/;
-var_ = var18;
-if (var18){
-var10 = var_;
+{
+abstract_compiler__AbstractCompilerVisitor__add(var_v, var931); /* Direct call abstract_compiler#AbstractCompilerVisitor#add on <var_v:AbstractCompilerVisitor>*/
+}
+if (varonce935) {
+var936 = varonce935;
 } 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);
+var937 = "printf(\"inlined:  %ld (%.2f%%)\\n\", count_invoke_by_inline, 100.0*count_invoke_by_inline/count_invoke_total);";
+var938 = 108;
+var939 = string__NativeString__to_s_with_length(var937, var938);
+var936 = var939;
+varonce935 = var936;
+}
+{
+abstract_compiler__AbstractCompilerVisitor__add(var_v, var936); /* Direct call abstract_compiler#AbstractCompilerVisitor#add on <var_v:AbstractCompilerVisitor>*/
+}
 } else {
-var20 = ((val* (*)(val*))(var19->class->vft[COLOR_model__MPropDef__mproperty]))(var19) /* mproperty on <var19:nullable MPropDef(nullable MMethodDef)>*/;
 }
-var21 = ((val* (*)(val*))(var20->class->vft[COLOR_model__MProperty__name]))(var20) /* name on <var20:MProperty(MMethod)>*/;
-if (varonce22) {
-var23 = varonce22;
+{
+{ /* Inline abstract_compiler#AbstractCompiler#modelbuilder (self) on <self:AbstractCompiler> */
+var942 = self->attrs[COLOR_abstract_compiler__AbstractCompiler___modelbuilder].val; /* _modelbuilder on <self:AbstractCompiler> */
+if (unlikely(var942 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _modelbuilder");
+PRINT_ERROR(" (%s:%d)\n", "src/abstract_compiler.nit", 443);
+show_backtrace(1);
+}
+var940 = var942;
+RET_LABEL941:(void)0;
+}
+}
+{
+{ /* Inline modelbuilder#ModelBuilder#toolcontext (var940) on <var940:ModelBuilder> */
+var945 = var940->attrs[COLOR_modelbuilder__ModelBuilder___toolcontext].val; /* _toolcontext on <var940:ModelBuilder> */
+if (unlikely(var945 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _toolcontext");
+PRINT_ERROR(" (%s:%d)\n", "src/modelbuilder.nit", 101);
+show_backtrace(1);
+}
+var943 = var945;
+RET_LABEL944:(void)0;
+}
+}
+{
+{ /* Inline abstract_compiler#ToolContext#opt_isset_checks_metrics (var943) on <var943:ToolContext> */
+var948 = var943->attrs[COLOR_abstract_compiler__ToolContext___opt_isset_checks_metrics].val; /* _opt_isset_checks_metrics on <var943:ToolContext> */
+if (unlikely(var948 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _opt_isset_checks_metrics");
+PRINT_ERROR(" (%s:%d)\n", "src/abstract_compiler.nit", 60);
+show_backtrace(1);
+}
+var946 = var948;
+RET_LABEL947:(void)0;
+}
+}
+{
+{ /* Inline opts#Option#value (var946) on <var946:OptionBool> */
+var951 = var946->attrs[COLOR_opts__Option___value].val; /* _value on <var946:OptionBool> */
+var949 = var951;
+RET_LABEL950:(void)0;
+}
+}
+var952 = ((struct instance_kernel__Bool*)var949)->value; /* autounbox from nullable Object to Bool */;
+if (var952){
+if (varonce953) {
+var954 = varonce953;
 } else {
-var24 = "!=";
-var25 = 2;
-var26 = string__NativeString__to_s_with_length(var24, var25);
-var23 = var26;
-varonce22 = var23;
+var955 = "printf(\"# dynamic attribute reads: %ld\\n\", count_attr_reads);";
+var956 = 61;
+var957 = string__NativeString__to_s_with_length(var955, var956);
+var954 = var957;
+varonce953 = var954;
 }
-var27 = ((short int (*)(val*, val*))(var21->class->vft[COLOR_kernel__Object___61d_61d]))(var21, var23) /* == on <var21:String>*/;
-var10 = var27;
+{
+abstract_compiler__AbstractCompilerVisitor__add(var_v, var954); /* Direct call abstract_compiler#AbstractCompilerVisitor#add on <var_v:AbstractCompilerVisitor>*/
 }
-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);
+if (varonce958) {
+var959 = varonce958;
 } else {
-var30 = ((val* (*)(val*))(var29->class->vft[COLOR_model__MPropDef__mclassdef]))(var29) /* mclassdef on <var29:nullable MPropDef(nullable MMethodDef)>*/;
+var960 = "printf(\"# dynamic isset checks: %ld\\n\", count_isset_checks);";
+var961 = 60;
+var962 = string__NativeString__to_s_with_length(var960, var961);
+var959 = var962;
+varonce958 = var959;
+}
+{
+abstract_compiler__AbstractCompilerVisitor__add(var_v, var959); /* Direct call abstract_compiler#AbstractCompilerVisitor#add on <var_v:AbstractCompilerVisitor>*/
 }
-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;
 }
-var38 = ((short int (*)(val*, val*))(var32->class->vft[COLOR_kernel__Object___61d_61d]))(var32, var34) /* == on <var32:String>*/;
-var9 = var38;
+if (varonce963) {
+var964 = varonce963;
 } else {
-var9 = var_28;
+var965 = "return 0;";
+var966 = 9;
+var967 = string__NativeString__to_s_with_length(var965, var966);
+var964 = var967;
+varonce963 = var964;
 }
-if (var9){
-var39 = 1;
-var = var39;
-goto RET_LABEL;
+{
+abstract_compiler__AbstractCompilerVisitor__add(var_v, var964); /* Direct call abstract_compiler#AbstractCompilerVisitor#add on <var_v:AbstractCompilerVisitor>*/
+}
+if (varonce968) {
+var969 = varonce968;
 } else {
+var970 = "}";
+var971 = 1;
+var972 = string__NativeString__to_s_with_length(var970, var971);
+var969 = var972;
+varonce968 = var969;
 }
-/* <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;
+{
+abstract_compiler__AbstractCompilerVisitor__add(var_v, var969); /* Direct call abstract_compiler#AbstractCompilerVisitor#add on <var_v:AbstractCompilerVisitor>*/
+}
+RET_LABEL:;
+}
+/* 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:;
+}
+/* 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 {
-var41 = var_nblock->type->type_table[cltype] == idtype;
+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;
 }
-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;
+{
+abstract_compiler__AbstractCompilerVisitor__add(var_v, var1); /* Direct call abstract_compiler#AbstractCompilerVisitor#add on <var_v:AbstractCompilerVisitor>*/
+}
+RET_LABEL:;
+}
+/* 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#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", "src/abstract_compiler.nit", 847);
+show_backtrace(1);
+}
+var = var1;
+RET_LABEL:;
+return var;
+}
+/* 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", "src/abstract_compiler.nit", 847);
+show_backtrace(1);
+}
+var1 = var3;
+RET_LABEL2:(void)0;
+}
+var = var1;
+RET_LABEL:;
+return var;
+}
+/* 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", "src/abstract_compiler.nit", 850);
+show_backtrace(1);
+}
+var = var1;
+RET_LABEL:;
+return var;
+}
+/* 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", "src/abstract_compiler.nit", 850);
+show_backtrace(1);
+}
+var1 = var3;
+RET_LABEL2:(void)0;
+}
+var = var1;
+RET_LABEL:;
+return var;
+}
+/* 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", "src/abstract_compiler.nit", 853);
+show_backtrace(1);
+}
+var = var1;
+RET_LABEL:;
+return var;
+}
+/* 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", "src/abstract_compiler.nit", 853);
+show_backtrace(1);
+}
+var1 = var3;
+RET_LABEL2:(void)0;
+}
+var = var1;
+RET_LABEL:;
+return var;
 }
-var40 = var46;
+/* 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;
+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* var9 /* : ArrayIterator[nullable Object] */;
+short int var10 /* : Bool */;
+val* var11 /* : nullable Object */;
+val* var_cd /* var cd: MClassDef */;
+val* var12 /* : ModelBuilder */;
+val* var14 /* : ModelBuilder */;
+val* var15 /* : HashMap[MClassDef, AClassdef] */;
+val* var17 /* : HashMap[MClassDef, AClassdef] */;
+val* var18 /* : nullable Object */;
+val* var_n /* var n: AClassdef */;
+val* var19 /* : ANodes[APropdef] */;
+val* var21 /* : ANodes[APropdef] */;
+val* var22 /* : Iterator[ANode] */;
+short int var23 /* : Bool */;
+val* var24 /* : nullable Object */;
+val* var_npropdef /* var npropdef: APropdef */;
+short int var25 /* : Bool */;
+int cltype26;
+int idtype27;
+/* Covariant cast for argument 0 (v) <p0:AbstractCompilerVisitor> isa VISITOR */
+/* <p0:AbstractCompilerVisitor> isa VISITOR */
+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) {
+var = 0;
 } else {
-var40 = var_42;
+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`", "VISITOR", var_class_name);
+PRINT_ERROR(" (%s:%d)\n", "src/abstract_compiler.nit", 856);
+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", "src/abstract_compiler.nit", 436);
+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", "src/abstract_compiler.nit", 436);
+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>*/
+}
+{
+var9 = array__AbstractArrayRead__iterator(var_cds);
+}
+for(;;) {
+{
+var10 = array__ArrayIterator__is_ok(var9);
+}
+if(!var10) break;
+{
+var11 = array__ArrayIterator__item(var9);
+}
+var_cd = var11;
+{
+{ /* Inline abstract_compiler#AbstractCompiler#modelbuilder (self) on <self:AbstractCompiler> */
+var14 = self->attrs[COLOR_abstract_compiler__AbstractCompiler___modelbuilder].val; /* _modelbuilder on <self:AbstractCompiler> */
+if (unlikely(var14 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _modelbuilder");
+PRINT_ERROR(" (%s:%d)\n", "src/abstract_compiler.nit", 443);
+show_backtrace(1);
+}
+var12 = var14;
+RET_LABEL13:(void)0;
+}
+}
+{
+{ /* Inline modelize_class#ModelBuilder#mclassdef2nclassdef (var12) on <var12:ModelBuilder> */
+var17 = var12->attrs[COLOR_modelize_class__ModelBuilder___mclassdef2nclassdef].val; /* _mclassdef2nclassdef on <var12:ModelBuilder> */
+if (unlikely(var17 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _mclassdef2nclassdef");
+PRINT_ERROR(" (%s:%d)\n", "src/modelize_class.nit", 399);
+show_backtrace(1);
+}
+var15 = var17;
+RET_LABEL16:(void)0;
+}
+}
+{
+var18 = hash_collection__HashMap___91d_93d(var15, var_cd);
+}
+var_n = var18;
+{
+{ /* Inline parser_nodes#AClassdef#n_propdefs (var_n) on <var_n:AClassdef> */
+var21 = var_n->attrs[COLOR_parser_nodes__AClassdef___n_propdefs].val; /* _n_propdefs on <var_n:AClassdef> */
+if (unlikely(var21 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _n_propdefs");
+PRINT_ERROR(" (%s:%d)\n", "src/parser/parser_nodes.nit", 802);
+show_backtrace(1);
+}
+var19 = var21;
+RET_LABEL20:(void)0;
+}
+}
+{
+var22 = parser_nodes__ANodes__iterator(var19);
+}
+for(;;) {
+{
+var23 = ((short int (*)(val*))(var22->class->vft[COLOR_abstract_collection__Iterator__is_ok]))(var22) /* is_ok on <var22:Iterator[ANode]>*/;
+}
+if(!var23) break;
+{
+var24 = ((val* (*)(val*))(var22->class->vft[COLOR_abstract_collection__Iterator__item]))(var22) /* item on <var22:Iterator[ANode]>*/;
+}
+var_npropdef = var24;
+/* <var_npropdef:APropdef> isa AAttrPropdef */
+cltype26 = type_parser_nodes__AAttrPropdef.color;
+idtype27 = type_parser_nodes__AAttrPropdef.id;
+if(cltype26 >= var_npropdef->type->table_size) {
+var25 = 0;
+} else {
+var25 = var_npropdef->type->type_table[cltype26] == idtype27;
+}
+if (var25){
+{
+abstract_compiler__AAttrPropdef__init_expr(var_npropdef, var_v, var_recv); /* Direct call abstract_compiler#AAttrPropdef#init_expr on <var_npropdef:APropdef(AAttrPropdef)>*/
 }
-if (var40){
-var49 = 1;
-var = var49;
-goto RET_LABEL;
 } else {
 }
-var50 = 0;
-var = var50;
+CONTINUE_label: (void)0;
+{
+((void (*)(val*))(var22->class->vft[COLOR_abstract_collection__Iterator__next]))(var22) /* next on <var22:Iterator[ANode]>*/;
+}
+}
+BREAK_label: (void)0;
+CONTINUE_label28: (void)0;
+{
+array__ArrayIterator__next(var9); /* Direct call array#ArrayIterator#next on <var9:ArrayIterator[nullable Object]>*/
+}
+}
+BREAK_label28: (void)0;
+RET_LABEL:;
+}
+/* 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#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", "src/abstract_compiler.nit", 888);
+show_backtrace(1);
+}
+var = var1;
+RET_LABEL:;
+return var;
+}
+/* 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", "src/abstract_compiler.nit", 888);
+show_backtrace(1);
+}
+var1 = var3;
+RET_LABEL2:(void)0;
+}
+var = var1;
+RET_LABEL:;
+return var;
+}
+/* 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", "src/abstract_compiler.nit", 889);
+show_backtrace(1);
+}
+var = var1;
+RET_LABEL:;
+return var;
+}
+/* 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", "src/abstract_compiler.nit", 889);
+show_backtrace(1);
+}
+var1 = var3;
+RET_LABEL2:(void)0;
+}
+var = var1;
+RET_LABEL:;
+return var;
+}
+/* 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", "src/abstract_compiler.nit", 890);
+show_backtrace(1);
+}
+var = var1;
+RET_LABEL:;
+return var;
+}
+/* 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", "src/abstract_compiler.nit", 890);
+show_backtrace(1);
+}
+var1 = var3;
+RET_LABEL2:(void)0;
+}
+var = var1;
+RET_LABEL:;
+return var;
+}
+/* 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", "src/abstract_compiler.nit", 891);
+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", "src/abstract_compiler.nit", 891);
+show_backtrace(1);
+}
+var1 = var3;
+RET_LABEL2:(void)0;
+}
+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* var5 /* : ArrayIterator[nullable Object] */;
+short int var6 /* : Bool */;
+val* var7 /* : nullable Object */;
+val* var_tag /* var tag: String */;
+long var8 /* : Int */;
+val* var9 /* : nullable Object */;
+var1 = NEW_hash_collection__HashMap(&type_hash_collection__HashMapstring__Stringkernel__Int);
+{
+hash_collection__HashMap__init(var1); /* Direct call hash_collection#HashMap#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", "src/abstract_compiler.nit", 888);
+show_backtrace(1);
+}
+var2 = var4;
+RET_LABEL3:(void)0;
+}
+}
+{
+var5 = array__AbstractArrayRead__iterator(var2);
+}
+for(;;) {
+{
+var6 = array__ArrayIterator__is_ok(var5);
+}
+if(!var6) break;
+{
+var7 = array__ArrayIterator__item(var5);
+}
+var_tag = var7;
+var8 = 0;
+{
+var9 = BOX_kernel__Int(var8); /* autobox from Int to nullable Object */
+hash_collection__HashMap___91d_93d_61d(var_res, var_tag, var9); /* Direct call hash_collection#HashMap#[]= on <var_res:HashMap[String, Int]>*/
+}
+CONTINUE_label: (void)0;
+{
+array__ArrayIterator__next(var5); /* Direct call array#ArrayIterator#next on <var5:ArrayIterator[nullable Object]>*/
+}
+}
+BREAK_label: (void)0;
+var = var_res;
 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#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#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 */;
-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* var5 /* : nullable MSignature */;
-val* var6 /* : nullable MType */;
-val* var_ret /* var ret: nullable MType */;
-val* var7 /* : null */;
-short int var8 /* : Bool */;
+/* 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* var10 /* : MType */;
-short int var11 /* : Bool */;
+val* var11 /* : nullable Object */;
+short int var12 /* : Bool */;
 static val* varonce;
-val* var12 /* : String */;
-char* var13 /* : NativeString */;
-long var14 /* : Int */;
-val* var15 /* : String */;
-short int var16 /* : Bool */;
-short int var_ /* var : Bool */;
+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 /* : String */;
-short int var22 /* : Bool */;
-static val* varonce23;
-val* var24 /* : String */;
-char* var25 /* : NativeString */;
-long var26 /* : 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 */;
-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 */;
+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 */;
-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 */;
+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* var63 /* : ArrayIterator[nullable Object] */;
+short int var64 /* : Bool */;
+val* var65 /* : nullable Object */;
+val* var_tag /* var tag: String */;
+val* var66 /* : HashMap[String, Int] */;
+val* var68 /* : HashMap[String, Int] */;
+val* var69 /* : nullable Object */;
+val* var70 /* : HashMap[String, Int] */;
+val* var72 /* : HashMap[String, Int] */;
+val* var73 /* : nullable Object */;
+long var74 /* : Int */;
+short int var76 /* : Bool */;
+int cltype;
+int idtype;
+const char* var_class_name;
+long var77 /* : Int */;
+long var78 /* : Int */;
+long var79 /* : Int */;
+val* var80 /* : HashMap[String, Int] */;
+val* var82 /* : HashMap[String, Int] */;
+val* var83 /* : nullable Object */;
+long var84 /* : Int */;
+short int var86 /* : Bool */;
+int cltype87;
+int idtype88;
+const char* var_class_name89;
 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 var91 /* : Int */;
+val* var92 /* : nullable Object */;
+val* var93 /* : HashMap[String, Int] */;
+val* var95 /* : HashMap[String, Int] */;
+val* var_ /* var : HashMap[String, Int] */;
+static val* varonce96;
+val* var97 /* : String */;
+char* var98 /* : NativeString */;
+long var99 /* : Int */;
+val* var100 /* : FlatString */;
+val* var_101 /* var : String */;
+val* var102 /* : nullable Object */;
+val* var103 /* : HashMap[String, Int] */;
+val* var105 /* : HashMap[String, Int] */;
+val* var106 /* : nullable Object */;
+long var107 /* : Int */;
+short int var109 /* : Bool */;
+int cltype110;
+int idtype111;
+const char* var_class_name112;
+long var113 /* : Int */;
+long var114 /* : Int */;
+long var115 /* : Int */;
+val* var116 /* : nullable Object */;
+val* var117 /* : HashMap[String, Int] */;
+val* var119 /* : HashMap[String, Int] */;
+val* var_120 /* var : HashMap[String, Int] */;
+static val* varonce121;
+val* var122 /* : String */;
+char* var123 /* : NativeString */;
+long var124 /* : Int */;
+val* var125 /* : FlatString */;
+val* var_126 /* var : String */;
+val* var127 /* : nullable Object */;
+val* var128 /* : HashMap[String, Int] */;
+val* var130 /* : HashMap[String, Int] */;
+val* var131 /* : nullable Object */;
+long var132 /* : Int */;
+short int var134 /* : Bool */;
+int cltype135;
+int idtype136;
+const char* var_class_name137;
+long var138 /* : Int */;
 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 var140 /* : Int */;
+val* var141 /* : nullable Object */;
+val* var142 /* : HashMap[String, Int] */;
+val* var144 /* : HashMap[String, Int] */;
+val* var_145 /* var : HashMap[String, Int] */;
+static val* varonce146;
+val* var147 /* : String */;
+char* var148 /* : NativeString */;
+long var149 /* : Int */;
+val* var150 /* : FlatString */;
+val* var_151 /* var : String */;
+val* var152 /* : nullable Object */;
+val* var153 /* : HashMap[String, Int] */;
+val* var155 /* : HashMap[String, Int] */;
+val* var156 /* : nullable Object */;
 long var157 /* : Int */;
-val* var158 /* : nullable Object */;
-static val* varonce159;
-val* var160 /* : String */;
-char* var161 /* : NativeString */;
-long var162 /* : Int */;
-val* var163 /* : String */;
+short int var159 /* : Bool */;
+int cltype160;
+int idtype161;
+const char* var_class_name162;
+long var163 /* : Int */;
 long var164 /* : Int */;
-val* var165 /* : nullable Object */;
-val* var166 /* : Array[Object] */;
-long var167 /* : Int */;
-val* var168 /* : NativeArray[Object] */;
+long var165 /* : Int */;
+val* var166 /* : nullable Object */;
+val* var_167 /* var : HashMap[String, Int] */;
+static val* varonce168;
 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 */;
+char* var170 /* : NativeString */;
+long var171 /* : Int */;
+val* var172 /* : FlatString */;
+val* var_173 /* var : String */;
+val* var174 /* : nullable Object */;
+val* var175 /* : nullable Object */;
+long var176 /* : Int */;
+short int var178 /* : Bool */;
+int cltype179;
+int idtype180;
+const char* var_class_name181;
 long var182 /* : Int */;
-val* var183 /* : String */;
+long var183 /* : Int */;
 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 */;
+static val* varonce186;
+val* var187 /* : String */;
+char* var188 /* : NativeString */;
+long var189 /* : Int */;
+val* var190 /* : FlatString */;
+val* var191 /* : nullable Object */;
+long var192 /* : Int */;
+long var_count_type_test /* var count_type_test: Int */;
+val* var193 /* : Array[String] */;
+val* var195 /* : Array[String] */;
+val* var196 /* : Array[nullable Object] */;
+val* var_tags /* var tags: Array[String] */;
+static val* varonce197;
+val* var198 /* : String */;
+char* var199 /* : NativeString */;
+long var200 /* : Int */;
+val* var201 /* : FlatString */;
+val* var202 /* : ArrayIterator[nullable Object] */;
+short int var203 /* : Bool */;
+val* var204 /* : nullable Object */;
+val* var_tag205 /* var tag: String */;
 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 */;
+static val* varonce209;
+val* var210 /* : String */;
+char* var211 /* : NativeString */;
+long var212 /* : Int */;
+val* var213 /* : FlatString */;
+val* var214 /* : HashMap[String, Int] */;
+val* var216 /* : HashMap[String, Int] */;
+val* var217 /* : nullable Object */;
+static val* varonce218;
+val* var219 /* : String */;
+char* var220 /* : NativeString */;
+long var221 /* : Int */;
+val* var222 /* : FlatString */;
+val* var223 /* : HashMap[String, Int] */;
+val* var225 /* : HashMap[String, Int] */;
+val* var226 /* : nullable Object */;
+val* var227 /* : String */;
+long var228 /* : Int */;
+static val* varonce229;
+val* var230 /* : String */;
+char* var231 /* : NativeString */;
+long var232 /* : Int */;
+val* var233 /* : FlatString */;
+val* var234 /* : Array[Object] */;
+long var235 /* : Int */;
+val* var236 /* : NativeArray[Object] */;
+val* var237 /* : String */;
+val* var238 /* : Array[Object] */;
+long var239 /* : Int */;
+val* var240 /* : NativeArray[Object] */;
+static val* varonce241;
+val* var242 /* : String */;
+char* var243 /* : NativeString */;
 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* var245 /* : FlatString */;
+val* var246 /* : HashMap[String, Int] */;
+val* var248 /* : HashMap[String, Int] */;
+val* var249 /* : nullable Object */;
+static val* varonce250;
+val* var251 /* : String */;
+char* var252 /* : NativeString */;
+long var253 /* : Int */;
+val* var254 /* : FlatString */;
+val* var255 /* : HashMap[String, Int] */;
+val* var257 /* : HashMap[String, 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 */;
+val* var259 /* : String */;
+long var260 /* : Int */;
+static val* varonce261;
+val* var262 /* : String */;
+char* var263 /* : NativeString */;
+long var264 /* : Int */;
+val* var265 /* : FlatString */;
+val* var266 /* : Array[Object] */;
+long var267 /* : Int */;
+val* var268 /* : NativeArray[Object] */;
+val* var269 /* : String */;
+val* var270 /* : Array[Object] */;
+long var271 /* : Int */;
+val* var272 /* : NativeArray[Object] */;
 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* var277 /* : FlatString */;
+val* var278 /* : HashMap[String, Int] */;
+val* var280 /* : HashMap[String, Int] */;
+val* var281 /* : nullable Object */;
+static val* varonce282;
+val* var283 /* : String */;
+char* var284 /* : NativeString */;
+long var285 /* : Int */;
+val* var286 /* : FlatString */;
+val* var287 /* : HashMap[String, Int] */;
+val* var289 /* : HashMap[String, Int] */;
 val* var290 /* : nullable Object */;
-static val* varonce291;
-val* var292 /* : String */;
-char* var293 /* : NativeString */;
-long var294 /* : Int */;
-val* var295 /* : String */;
+val* var291 /* : String */;
+long var292 /* : Int */;
+static val* varonce293;
+val* var294 /* : String */;
+char* var295 /* : NativeString */;
 long var296 /* : Int */;
-val* var297 /* : nullable Object */;
+val* var297 /* : FlatString */;
 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* var302 /* : Array[Object] */;
+long var303 /* : Int */;
+val* var304 /* : NativeArray[Object] */;
+static val* varonce305;
+val* var306 /* : String */;
+char* var307 /* : NativeString */;
+long var308 /* : Int */;
+val* var309 /* : FlatString */;
 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* var315 /* : FlatString */;
+val* var316 /* : nullable Object */;
+val* var317 /* : String */;
+long var318 /* : Int */;
+static val* varonce319;
+val* var320 /* : String */;
+char* var321 /* : NativeString */;
+long var322 /* : Int */;
+val* var323 /* : FlatString */;
+val* var324 /* : Array[Object] */;
+long var325 /* : Int */;
+val* var326 /* : NativeArray[Object] */;
 val* var327 /* : String */;
-short int var328 /* : Bool */;
+val* var328 /* : Array[Object] */;
 long var329 /* : Int */;
-val* var330 /* : nullable Object */;
+val* var330 /* : NativeArray[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 */
-}
-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;
+val* var335 /* : 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", "src/abstract_compiler.nit", 443);
+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", "src/modelbuilder.nit", 101);
+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", "src/abstract_compiler.nit", 56);
+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) {
+var13 = varonce;
+} else {
+var14 = "# static count_type_test";
+var15 = 24;
+var16 = string__NativeString__to_s_with_length(var14, var15);
+var13 = var16;
+varonce = var13;
+}
+{
+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", "src/abstract_compiler.nit", 889);
+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", "src/abstract_compiler.nit", 890);
+show_backtrace(1);
+}
+var33 = var35;
+RET_LABEL34:(void)0;
+}
+}
+if (varonce36) {
+var37 = varonce36;
+} else {
+var38 = "total";
+var39 = 5;
+var40 = string__NativeString__to_s_with_length(var38, var39);
+var37 = var40;
+varonce36 = var37;
+}
+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]>*/
+}
+{
+{ /* 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", "src/abstract_compiler.nit", 891);
+show_backtrace(1);
+}
+var43 = var45;
+RET_LABEL44:(void)0;
+}
+}
+if (varonce46) {
+var47 = varonce46;
+} else {
+var48 = "total";
+var49 = 5;
+var50 = string__NativeString__to_s_with_length(var48, var49);
+var47 = var50;
+varonce46 = var47;
+}
+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]>*/
+}
+if (varonce53) {
+var54 = varonce53;
+} else {
+var55 = "total";
+var56 = 5;
+var57 = string__NativeString__to_s_with_length(var55, var56);
+var54 = var57;
+varonce53 = var54;
+}
+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]>*/
+}
+{
+{ /* 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", "src/abstract_compiler.nit", 888);
+show_backtrace(1);
+}
+var60 = var62;
+RET_LABEL61:(void)0;
+}
+}
+{
+var63 = array__AbstractArrayRead__iterator(var60);
+}
+for(;;) {
+{
+var64 = array__ArrayIterator__is_ok(var63);
+}
+if(!var64) break;
+{
+var65 = array__ArrayIterator__item(var63);
+}
+var_tag = var65;
+{
+{ /* Inline abstract_compiler#AbstractCompiler#count_type_test_resolved (self) on <self:AbstractCompiler> */
+var68 = self->attrs[COLOR_abstract_compiler__AbstractCompiler___count_type_test_resolved].val; /* _count_type_test_resolved on <self:AbstractCompiler> */
+if (unlikely(var68 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _count_type_test_resolved");
+PRINT_ERROR(" (%s:%d)\n", "src/abstract_compiler.nit", 889);
+show_backtrace(1);
+}
+var66 = var68;
+RET_LABEL67:(void)0;
+}
+}
+{
+var69 = hash_collection__HashMap___91d_93d(var66, var_tag);
+}
+{
+{ /* Inline abstract_compiler#AbstractCompiler#count_type_test_unresolved (self) on <self:AbstractCompiler> */
+var72 = self->attrs[COLOR_abstract_compiler__AbstractCompiler___count_type_test_unresolved].val; /* _count_type_test_unresolved on <self:AbstractCompiler> */
+if (unlikely(var72 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _count_type_test_unresolved");
+PRINT_ERROR(" (%s:%d)\n", "src/abstract_compiler.nit", 890);
+show_backtrace(1);
+}
+var70 = var72;
+RET_LABEL71:(void)0;
+}
+}
+{
+var73 = hash_collection__HashMap___91d_93d(var70, var_tag);
+}
+{
+{ /* Inline kernel#Int#+ (var69,var73) on <var69:nullable Object(Int)> */
+/* Covariant cast for argument 0 (i) <var73:nullable Object(Int)> isa OTHER */
+/* <var73:nullable Object(Int)> isa OTHER */
+var76 = 1; /* easy <var73:nullable Object(Int)> isa OTHER*/
+if (unlikely(!var76)) {
+var_class_name = var73 == NULL ? "null" : var73->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", 328);
+show_backtrace(1);
+}
+var77 = ((struct instance_kernel__Int*)var69)->value; /* autounbox from nullable Object to Int */;
+var78 = ((struct instance_kernel__Int*)var73)->value; /* autounbox from nullable Object to Int */;
+var79 = var77 + var78;
+var74 = var79;
+goto RET_LABEL75;
+RET_LABEL75:(void)0;
+}
+}
+{
+{ /* Inline abstract_compiler#AbstractCompiler#count_type_test_skipped (self) on <self:AbstractCompiler> */
+var82 = self->attrs[COLOR_abstract_compiler__AbstractCompiler___count_type_test_skipped].val; /* _count_type_test_skipped on <self:AbstractCompiler> */
+if (unlikely(var82 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _count_type_test_skipped");
+PRINT_ERROR(" (%s:%d)\n", "src/abstract_compiler.nit", 891);
+show_backtrace(1);
+}
+var80 = var82;
+RET_LABEL81:(void)0;
+}
+}
+{
+var83 = hash_collection__HashMap___91d_93d(var80, var_tag);
+}
+{
+{ /* Inline kernel#Int#+ (var74,var83) on <var74:Int> */
+/* Covariant cast for argument 0 (i) <var83:nullable Object(Int)> isa OTHER */
+/* <var83:nullable Object(Int)> isa OTHER */
+var86 = 1; /* easy <var83:nullable Object(Int)> isa OTHER*/
+if (unlikely(!var86)) {
+var_class_name89 = var83 == NULL ? "null" : var83->type->name;
+PRINT_ERROR("Runtime error: Cast failed. Expected `%s`, got `%s`", "OTHER", var_class_name89);
+PRINT_ERROR(" (%s:%d)\n", "lib/standard/kernel.nit", 328);
+show_backtrace(1);
+}
+var90 = ((struct instance_kernel__Int*)var83)->value; /* autounbox from nullable Object to Int */;
+var91 = var74 + var90;
+var84 = var91;
+goto RET_LABEL85;
+RET_LABEL85:(void)0;
+}
+}
+{
+var92 = BOX_kernel__Int(var84); /* autobox from Int to nullable Object */
+hash_collection__HashMap___91d_93d_61d(var_count_type_test_total, var_tag, var92); /* 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> */
+var95 = self->attrs[COLOR_abstract_compiler__AbstractCompiler___count_type_test_resolved].val; /* _count_type_test_resolved on <self:AbstractCompiler> */
+if (unlikely(var95 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _count_type_test_resolved");
+PRINT_ERROR(" (%s:%d)\n", "src/abstract_compiler.nit", 889);
+show_backtrace(1);
+}
+var93 = var95;
+RET_LABEL94:(void)0;
+}
+}
+var_ = var93;
+if (varonce96) {
+var97 = varonce96;
+} else {
+var98 = "total";
+var99 = 5;
+var100 = string__NativeString__to_s_with_length(var98, var99);
+var97 = var100;
+varonce96 = var97;
+}
+var_101 = var97;
+{
+var102 = hash_collection__HashMap___91d_93d(var_, var_101);
+}
+{
+{ /* Inline abstract_compiler#AbstractCompiler#count_type_test_resolved (self) on <self:AbstractCompiler> */
+var105 = self->attrs[COLOR_abstract_compiler__AbstractCompiler___count_type_test_resolved].val; /* _count_type_test_resolved on <self:AbstractCompiler> */
+if (unlikely(var105 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _count_type_test_resolved");
+PRINT_ERROR(" (%s:%d)\n", "src/abstract_compiler.nit", 889);
+show_backtrace(1);
+}
+var103 = var105;
+RET_LABEL104:(void)0;
+}
+}
+{
+var106 = hash_collection__HashMap___91d_93d(var103, var_tag);
+}
+{
+{ /* Inline kernel#Int#+ (var102,var106) on <var102:nullable Object(Int)> */
+/* Covariant cast for argument 0 (i) <var106:nullable Object(Int)> isa OTHER */
+/* <var106:nullable Object(Int)> isa OTHER */
+var109 = 1; /* easy <var106:nullable Object(Int)> isa OTHER*/
+if (unlikely(!var109)) {
+var_class_name112 = var106 == NULL ? "null" : var106->type->name;
+PRINT_ERROR("Runtime error: Cast failed. Expected `%s`, got `%s`", "OTHER", var_class_name112);
+PRINT_ERROR(" (%s:%d)\n", "lib/standard/kernel.nit", 328);
+show_backtrace(1);
+}
+var113 = ((struct instance_kernel__Int*)var102)->value; /* autounbox from nullable Object to Int */;
+var114 = ((struct instance_kernel__Int*)var106)->value; /* autounbox from nullable Object to Int */;
+var115 = var113 + var114;
+var107 = var115;
+goto RET_LABEL108;
+RET_LABEL108:(void)0;
+}
+}
+{
+var116 = BOX_kernel__Int(var107); /* autobox from Int to nullable Object */
+hash_collection__HashMap___91d_93d_61d(var_, var_101, var116); /* Direct call hash_collection#HashMap#[]= on <var_:HashMap[String, Int]>*/
+}
+{
+{ /* Inline abstract_compiler#AbstractCompiler#count_type_test_unresolved (self) on <self:AbstractCompiler> */
+var119 = self->attrs[COLOR_abstract_compiler__AbstractCompiler___count_type_test_unresolved].val; /* _count_type_test_unresolved on <self:AbstractCompiler> */
+if (unlikely(var119 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _count_type_test_unresolved");
+PRINT_ERROR(" (%s:%d)\n", "src/abstract_compiler.nit", 890);
+show_backtrace(1);
+}
+var117 = var119;
+RET_LABEL118:(void)0;
+}
+}
+var_120 = var117;
+if (varonce121) {
+var122 = varonce121;
+} else {
+var123 = "total";
+var124 = 5;
+var125 = string__NativeString__to_s_with_length(var123, var124);
+var122 = var125;
+varonce121 = var122;
+}
+var_126 = var122;
+{
+var127 = hash_collection__HashMap___91d_93d(var_120, var_126);
+}
+{
+{ /* Inline abstract_compiler#AbstractCompiler#count_type_test_unresolved (self) on <self:AbstractCompiler> */
+var130 = self->attrs[COLOR_abstract_compiler__AbstractCompiler___count_type_test_unresolved].val; /* _count_type_test_unresolved on <self:AbstractCompiler> */
+if (unlikely(var130 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _count_type_test_unresolved");
+PRINT_ERROR(" (%s:%d)\n", "src/abstract_compiler.nit", 890);
+show_backtrace(1);
+}
+var128 = var130;
+RET_LABEL129:(void)0;
+}
+}
+{
+var131 = hash_collection__HashMap___91d_93d(var128, var_tag);
+}
+{
+{ /* Inline kernel#Int#+ (var127,var131) on <var127:nullable Object(Int)> */
+/* Covariant cast for argument 0 (i) <var131:nullable Object(Int)> isa OTHER */
+/* <var131:nullable Object(Int)> isa OTHER */
+var134 = 1; /* easy <var131:nullable Object(Int)> isa OTHER*/
+if (unlikely(!var134)) {
+var_class_name137 = var131 == NULL ? "null" : var131->type->name;
+PRINT_ERROR("Runtime error: Cast failed. Expected `%s`, got `%s`", "OTHER", var_class_name137);
+PRINT_ERROR(" (%s:%d)\n", "lib/standard/kernel.nit", 328);
+show_backtrace(1);
+}
+var138 = ((struct instance_kernel__Int*)var127)->value; /* autounbox from nullable Object to Int */;
+var139 = ((struct instance_kernel__Int*)var131)->value; /* autounbox from nullable Object to Int */;
+var140 = var138 + var139;
+var132 = var140;
+goto RET_LABEL133;
+RET_LABEL133:(void)0;
+}
+}
+{
+var141 = BOX_kernel__Int(var132); /* autobox from Int to nullable Object */
+hash_collection__HashMap___91d_93d_61d(var_120, var_126, var141); /* Direct call hash_collection#HashMap#[]= on <var_120:HashMap[String, Int]>*/
+}
+{
+{ /* Inline abstract_compiler#AbstractCompiler#count_type_test_skipped (self) on <self:AbstractCompiler> */
+var144 = self->attrs[COLOR_abstract_compiler__AbstractCompiler___count_type_test_skipped].val; /* _count_type_test_skipped on <self:AbstractCompiler> */
+if (unlikely(var144 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _count_type_test_skipped");
+PRINT_ERROR(" (%s:%d)\n", "src/abstract_compiler.nit", 891);
+show_backtrace(1);
+}
+var142 = var144;
+RET_LABEL143:(void)0;
+}
+}
+var_145 = var142;
+if (varonce146) {
+var147 = varonce146;
+} else {
+var148 = "total";
+var149 = 5;
+var150 = string__NativeString__to_s_with_length(var148, var149);
+var147 = var150;
+varonce146 = var147;
+}
+var_151 = var147;
+{
+var152 = hash_collection__HashMap___91d_93d(var_145, var_151);
+}
+{
+{ /* Inline abstract_compiler#AbstractCompiler#count_type_test_skipped (self) on <self:AbstractCompiler> */
+var155 = self->attrs[COLOR_abstract_compiler__AbstractCompiler___count_type_test_skipped].val; /* _count_type_test_skipped on <self:AbstractCompiler> */
+if (unlikely(var155 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _count_type_test_skipped");
+PRINT_ERROR(" (%s:%d)\n", "src/abstract_compiler.nit", 891);
+show_backtrace(1);
+}
+var153 = var155;
+RET_LABEL154:(void)0;
+}
+}
+{
+var156 = hash_collection__HashMap___91d_93d(var153, var_tag);
+}
+{
+{ /* Inline kernel#Int#+ (var152,var156) on <var152:nullable Object(Int)> */
+/* Covariant cast for argument 0 (i) <var156:nullable Object(Int)> isa OTHER */
+/* <var156:nullable Object(Int)> isa OTHER */
+var159 = 1; /* easy <var156:nullable Object(Int)> isa OTHER*/
+if (unlikely(!var159)) {
+var_class_name162 = var156 == NULL ? "null" : var156->type->name;
+PRINT_ERROR("Runtime error: Cast failed. Expected `%s`, got `%s`", "OTHER", var_class_name162);
+PRINT_ERROR(" (%s:%d)\n", "lib/standard/kernel.nit", 328);
+show_backtrace(1);
+}
+var163 = ((struct instance_kernel__Int*)var152)->value; /* autounbox from nullable Object to Int */;
+var164 = ((struct instance_kernel__Int*)var156)->value; /* autounbox from nullable Object to Int */;
+var165 = var163 + var164;
+var157 = var165;
+goto RET_LABEL158;
+RET_LABEL158:(void)0;
+}
+}
+{
+var166 = BOX_kernel__Int(var157); /* autobox from Int to nullable Object */
+hash_collection__HashMap___91d_93d_61d(var_145, var_151, var166); /* Direct call hash_collection#HashMap#[]= on <var_145:HashMap[String, Int]>*/
+}
+var_167 = var_count_type_test_total;
+if (varonce168) {
+var169 = varonce168;
+} else {
+var170 = "total";
+var171 = 5;
+var172 = string__NativeString__to_s_with_length(var170, var171);
+var169 = var172;
+varonce168 = var169;
+}
+var_173 = var169;
+{
+var174 = hash_collection__HashMap___91d_93d(var_167, var_173);
+}
+{
+var175 = hash_collection__HashMap___91d_93d(var_count_type_test_total, var_tag);
+}
+{
+{ /* Inline kernel#Int#+ (var174,var175) on <var174:nullable Object(Int)> */
+/* Covariant cast for argument 0 (i) <var175:nullable Object(Int)> isa OTHER */
+/* <var175:nullable Object(Int)> isa OTHER */
+var178 = 1; /* easy <var175:nullable Object(Int)> isa OTHER*/
+if (unlikely(!var178)) {
+var_class_name181 = var175 == NULL ? "null" : var175->type->name;
+PRINT_ERROR("Runtime error: Cast failed. Expected `%s`, got `%s`", "OTHER", var_class_name181);
+PRINT_ERROR(" (%s:%d)\n", "lib/standard/kernel.nit", 328);
+show_backtrace(1);
+}
+var182 = ((struct instance_kernel__Int*)var174)->value; /* autounbox from nullable Object to Int */;
+var183 = ((struct instance_kernel__Int*)var175)->value; /* autounbox from nullable Object to Int */;
+var184 = var182 + var183;
+var176 = var184;
+goto RET_LABEL177;
+RET_LABEL177:(void)0;
+}
+}
+{
+var185 = BOX_kernel__Int(var176); /* autobox from Int to nullable Object */
+hash_collection__HashMap___91d_93d_61d(var_167, var_173, var185); /* Direct call hash_collection#HashMap#[]= on <var_167:HashMap[String, Int]>*/
+}
+CONTINUE_label: (void)0;
+{
+array__ArrayIterator__next(var63); /* Direct call array#ArrayIterator#next on <var63:ArrayIterator[nullable Object]>*/
+}
+}
+BREAK_label: (void)0;
+if (varonce186) {
+var187 = varonce186;
+} else {
+var188 = "total";
+var189 = 5;
+var190 = string__NativeString__to_s_with_length(var188, var189);
+var187 = var190;
+varonce186 = var187;
+}
+{
+var191 = hash_collection__HashMap___91d_93d(var_count_type_test_total, var187);
+}
+var192 = ((struct instance_kernel__Int*)var191)->value; /* autounbox from nullable Object to Int */;
+var_count_type_test = var192;
+{
+{ /* Inline abstract_compiler#AbstractCompiler#count_type_test_tags (self) on <self:AbstractCompiler> */
+var195 = self->attrs[COLOR_abstract_compiler__AbstractCompiler___count_type_test_tags].val; /* _count_type_test_tags on <self:AbstractCompiler> */
+if (unlikely(var195 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _count_type_test_tags");
+PRINT_ERROR(" (%s:%d)\n", "src/abstract_compiler.nit", 888);
+show_backtrace(1);
+}
+var193 = var195;
+RET_LABEL194:(void)0;
+}
+}
+{
+var196 = array__Collection__to_a(var193);
+}
+var_tags = var196;
+if (varonce197) {
+var198 = varonce197;
+} else {
+var199 = "total";
+var200 = 5;
+var201 = string__NativeString__to_s_with_length(var199, var200);
+var198 = var201;
+varonce197 = var198;
+}
+{
+array__Array__add(var_tags, var198); /* Direct call array#Array#add on <var_tags:Array[String]>*/
+}
+{
+var202 = array__AbstractArrayRead__iterator(var_tags);
+}
+for(;;) {
+{
+var203 = array__ArrayIterator__is_ok(var202);
+}
+if(!var203) break;
+{
+var204 = array__ArrayIterator__item(var202);
+}
+var_tag205 = var204;
+var206 = NEW_array__Array(&type_array__Arraykernel__Object);
+{ /* var206 = array_instance Array[Object] */
+var207 = 1;
+var208 = NEW_array__NativeArray(var207, &type_array__NativeArraykernel__Object);
+((struct instance_array__NativeArray*)var208)->values[0] = (val*) var_tag205;
+{
+((void (*)(val*, val*, long))(var206->class->vft[COLOR_array__Array__with_native]))(var206, var208, var207) /* with_native on <var206:Array[Object]>*/;
+}
+}
+{
+file__Object__printn(self, var206); /* Direct call file#Object#printn on <self:AbstractCompiler>*/
+}
+if (varonce209) {
+var210 = varonce209;
+} else {
+var211 = "\11";
+var212 = 1;
+var213 = string__NativeString__to_s_with_length(var211, var212);
+var210 = var213;
+varonce209 = var210;
+}
+{
+{ /* Inline abstract_compiler#AbstractCompiler#count_type_test_resolved (self) on <self:AbstractCompiler> */
+var216 = self->attrs[COLOR_abstract_compiler__AbstractCompiler___count_type_test_resolved].val; /* _count_type_test_resolved on <self:AbstractCompiler> */
+if (unlikely(var216 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _count_type_test_resolved");
+PRINT_ERROR(" (%s:%d)\n", "src/abstract_compiler.nit", 889);
+show_backtrace(1);
+}
+var214 = var216;
+RET_LABEL215:(void)0;
+}
+}
+{
+var217 = hash_collection__HashMap___91d_93d(var214, var_tag205);
+}
+if (varonce218) {
+var219 = varonce218;
 } else {
+var220 = " (";
+var221 = 2;
+var222 = string__NativeString__to_s_with_length(var220, var221);
+var219 = var222;
+varonce218 = var219;
+}
+{
+{ /* Inline abstract_compiler#AbstractCompiler#count_type_test_resolved (self) on <self:AbstractCompiler> */
+var225 = self->attrs[COLOR_abstract_compiler__AbstractCompiler___count_type_test_resolved].val; /* _count_type_test_resolved on <self:AbstractCompiler> */
+if (unlikely(var225 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _count_type_test_resolved");
+PRINT_ERROR(" (%s:%d)\n", "src/abstract_compiler.nit", 889);
+show_backtrace(1);
+}
+var223 = var225;
+RET_LABEL224:(void)0;
+}
+}
+{
+var226 = hash_collection__HashMap___91d_93d(var223, var_tag205);
+}
+{
+var228 = ((struct instance_kernel__Int*)var226)->value; /* autounbox from nullable Object to Int */;
+var227 = abstract_compiler__AbstractCompiler__div(self, var228, var_count_type_test);
+}
+if (varonce229) {
+var230 = varonce229;
+} else {
+var231 = "%)";
+var232 = 2;
+var233 = string__NativeString__to_s_with_length(var231, var232);
+var230 = var233;
+varonce229 = var230;
+}
+var234 = NEW_array__Array(&type_array__Arraykernel__Object);
+{ /* var234 = array_instance Array[Object] */
+var235 = 5;
+var236 = NEW_array__NativeArray(var235, &type_array__NativeArraykernel__Object);
+((struct instance_array__NativeArray*)var236)->values[0] = (val*) var210;
+((struct instance_array__NativeArray*)var236)->values[1] = (val*) var217;
+((struct instance_array__NativeArray*)var236)->values[2] = (val*) var219;
+((struct instance_array__NativeArray*)var236)->values[3] = (val*) var227;
+((struct instance_array__NativeArray*)var236)->values[4] = (val*) var230;
+{
+((void (*)(val*, val*, long))(var234->class->vft[COLOR_array__Array__with_native]))(var234, var236, var235) /* with_native on <var234:Array[Object]>*/;
+}
+}
+{
+var237 = ((val* (*)(val*))(var234->class->vft[COLOR_string__Object__to_s]))(var234) /* to_s on <var234:Array[Object]>*/;
+}
+var238 = NEW_array__Array(&type_array__Arraykernel__Object);
+{ /* var238 = array_instance Array[Object] */
+var239 = 1;
+var240 = NEW_array__NativeArray(var239, &type_array__NativeArraykernel__Object);
+((struct instance_array__NativeArray*)var240)->values[0] = (val*) var237;
+{
+((void (*)(val*, val*, long))(var238->class->vft[COLOR_array__Array__with_native]))(var238, var240, var239) /* with_native on <var238:Array[Object]>*/;
+}
+}
+{
+file__Object__printn(self, var238); /* Direct call file#Object#printn on <self:AbstractCompiler>*/
+}
+if (varonce241) {
+var242 = varonce241;
+} else {
+var243 = "\11";
+var244 = 1;
+var245 = string__NativeString__to_s_with_length(var243, var244);
+var242 = var245;
+varonce241 = var242;
+}
+{
+{ /* Inline abstract_compiler#AbstractCompiler#count_type_test_unresolved (self) on <self:AbstractCompiler> */
+var248 = self->attrs[COLOR_abstract_compiler__AbstractCompiler___count_type_test_unresolved].val; /* _count_type_test_unresolved on <self:AbstractCompiler> */
+if (unlikely(var248 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _count_type_test_unresolved");
+PRINT_ERROR(" (%s:%d)\n", "src/abstract_compiler.nit", 890);
+show_backtrace(1);
+}
+var246 = var248;
+RET_LABEL247:(void)0;
+}
+}
+{
+var249 = hash_collection__HashMap___91d_93d(var246, var_tag205);
+}
+if (varonce250) {
+var251 = varonce250;
+} else {
+var252 = " (";
+var253 = 2;
+var254 = string__NativeString__to_s_with_length(var252, var253);
+var251 = var254;
+varonce250 = var251;
+}
+{
+{ /* Inline abstract_compiler#AbstractCompiler#count_type_test_unresolved (self) on <self:AbstractCompiler> */
+var257 = self->attrs[COLOR_abstract_compiler__AbstractCompiler___count_type_test_unresolved].val; /* _count_type_test_unresolved on <self:AbstractCompiler> */
+if (unlikely(var257 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _count_type_test_unresolved");
+PRINT_ERROR(" (%s:%d)\n", "src/abstract_compiler.nit", 890);
+show_backtrace(1);
+}
+var255 = var257;
+RET_LABEL256:(void)0;
+}
+}
+{
+var258 = hash_collection__HashMap___91d_93d(var255, var_tag205);
+}
+{
+var260 = ((struct instance_kernel__Int*)var258)->value; /* autounbox from nullable Object to Int */;
+var259 = abstract_compiler__AbstractCompiler__div(self, var260, var_count_type_test);
+}
+if (varonce261) {
+var262 = varonce261;
+} else {
+var263 = "%)";
+var264 = 2;
+var265 = string__NativeString__to_s_with_length(var263, var264);
+var262 = var265;
+varonce261 = var262;
+}
+var266 = NEW_array__Array(&type_array__Arraykernel__Object);
+{ /* var266 = array_instance Array[Object] */
+var267 = 5;
+var268 = NEW_array__NativeArray(var267, &type_array__NativeArraykernel__Object);
+((struct instance_array__NativeArray*)var268)->values[0] = (val*) var242;
+((struct instance_array__NativeArray*)var268)->values[1] = (val*) var249;
+((struct instance_array__NativeArray*)var268)->values[2] = (val*) var251;
+((struct instance_array__NativeArray*)var268)->values[3] = (val*) var259;
+((struct instance_array__NativeArray*)var268)->values[4] = (val*) var262;
+{
+((void (*)(val*, val*, long))(var266->class->vft[COLOR_array__Array__with_native]))(var266, var268, var267) /* with_native on <var266:Array[Object]>*/;
+}
+}
+{
+var269 = ((val* (*)(val*))(var266->class->vft[COLOR_string__Object__to_s]))(var266) /* to_s on <var266:Array[Object]>*/;
+}
+var270 = NEW_array__Array(&type_array__Arraykernel__Object);
+{ /* var270 = array_instance Array[Object] */
+var271 = 1;
+var272 = NEW_array__NativeArray(var271, &type_array__NativeArraykernel__Object);
+((struct instance_array__NativeArray*)var272)->values[0] = (val*) var269;
+{
+((void (*)(val*, val*, long))(var270->class->vft[COLOR_array__Array__with_native]))(var270, var272, var271) /* with_native on <var270:Array[Object]>*/;
+}
+}
+{
+file__Object__printn(self, var270); /* Direct call file#Object#printn on <self:AbstractCompiler>*/
+}
+if (varonce273) {
+var274 = varonce273;
+} else {
+var275 = "\11";
+var276 = 1;
+var277 = string__NativeString__to_s_with_length(var275, var276);
+var274 = var277;
+varonce273 = var274;
+}
+{
+{ /* Inline abstract_compiler#AbstractCompiler#count_type_test_skipped (self) on <self:AbstractCompiler> */
+var280 = self->attrs[COLOR_abstract_compiler__AbstractCompiler___count_type_test_skipped].val; /* _count_type_test_skipped on <self:AbstractCompiler> */
+if (unlikely(var280 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _count_type_test_skipped");
+PRINT_ERROR(" (%s:%d)\n", "src/abstract_compiler.nit", 891);
+show_backtrace(1);
+}
+var278 = var280;
+RET_LABEL279:(void)0;
+}
+}
+{
+var281 = hash_collection__HashMap___91d_93d(var278, var_tag205);
+}
+if (varonce282) {
+var283 = varonce282;
+} else {
+var284 = " (";
+var285 = 2;
+var286 = string__NativeString__to_s_with_length(var284, var285);
+var283 = var286;
+varonce282 = var283;
+}
+{
+{ /* Inline abstract_compiler#AbstractCompiler#count_type_test_skipped (self) on <self:AbstractCompiler> */
+var289 = self->attrs[COLOR_abstract_compiler__AbstractCompiler___count_type_test_skipped].val; /* _count_type_test_skipped on <self:AbstractCompiler> */
+if (unlikely(var289 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _count_type_test_skipped");
+PRINT_ERROR(" (%s:%d)\n", "src/abstract_compiler.nit", 891);
+show_backtrace(1);
+}
+var287 = var289;
+RET_LABEL288:(void)0;
+}
+}
+{
+var290 = hash_collection__HashMap___91d_93d(var287, var_tag205);
+}
+{
+var292 = ((struct instance_kernel__Int*)var290)->value; /* autounbox from nullable Object to Int */;
+var291 = abstract_compiler__AbstractCompiler__div(self, var292, var_count_type_test);
+}
+if (varonce293) {
+var294 = varonce293;
+} else {
+var295 = "%)";
+var296 = 2;
+var297 = string__NativeString__to_s_with_length(var295, var296);
+var294 = var297;
+varonce293 = var294;
+}
+var298 = NEW_array__Array(&type_array__Arraykernel__Object);
+{ /* var298 = array_instance Array[Object] */
+var299 = 5;
+var300 = NEW_array__NativeArray(var299, &type_array__NativeArraykernel__Object);
+((struct instance_array__NativeArray*)var300)->values[0] = (val*) var274;
+((struct instance_array__NativeArray*)var300)->values[1] = (val*) var281;
+((struct instance_array__NativeArray*)var300)->values[2] = (val*) var283;
+((struct instance_array__NativeArray*)var300)->values[3] = (val*) var291;
+((struct instance_array__NativeArray*)var300)->values[4] = (val*) var294;
+{
+((void (*)(val*, val*, long))(var298->class->vft[COLOR_array__Array__with_native]))(var298, var300, var299) /* with_native on <var298:Array[Object]>*/;
+}
+}
+{
+var301 = ((val* (*)(val*))(var298->class->vft[COLOR_string__Object__to_s]))(var298) /* to_s on <var298:Array[Object]>*/;
+}
+var302 = NEW_array__Array(&type_array__Arraykernel__Object);
+{ /* var302 = array_instance Array[Object] */
+var303 = 1;
+var304 = NEW_array__NativeArray(var303, &type_array__NativeArraykernel__Object);
+((struct instance_array__NativeArray*)var304)->values[0] = (val*) var301;
+{
+((void (*)(val*, val*, long))(var302->class->vft[COLOR_array__Array__with_native]))(var302, var304, var303) /* with_native on <var302:Array[Object]>*/;
+}
+}
+{
+file__Object__printn(self, var302); /* Direct call file#Object#printn on <self:AbstractCompiler>*/
+}
+if (varonce305) {
+var306 = varonce305;
+} else {
+var307 = "\11";
+var308 = 1;
+var309 = string__NativeString__to_s_with_length(var307, var308);
+var306 = var309;
+varonce305 = var306;
+}
+{
+var310 = hash_collection__HashMap___91d_93d(var_count_type_test_total, var_tag205);
+}
+if (varonce311) {
+var312 = varonce311;
+} else {
+var313 = " (";
+var314 = 2;
+var315 = string__NativeString__to_s_with_length(var313, var314);
+var312 = var315;
+varonce311 = var312;
+}
+{
+var316 = hash_collection__HashMap___91d_93d(var_count_type_test_total, var_tag205);
+}
+{
+var318 = ((struct instance_kernel__Int*)var316)->value; /* autounbox from nullable Object to Int */;
+var317 = abstract_compiler__AbstractCompiler__div(self, var318, var_count_type_test);
+}
+if (varonce319) {
+var320 = varonce319;
+} else {
+var321 = "%)";
+var322 = 2;
+var323 = string__NativeString__to_s_with_length(var321, var322);
+var320 = var323;
+varonce319 = var320;
+}
+var324 = NEW_array__Array(&type_array__Arraykernel__Object);
+{ /* var324 = array_instance Array[Object] */
+var325 = 5;
+var326 = NEW_array__NativeArray(var325, &type_array__NativeArraykernel__Object);
+((struct instance_array__NativeArray*)var326)->values[0] = (val*) var306;
+((struct instance_array__NativeArray*)var326)->values[1] = (val*) var310;
+((struct instance_array__NativeArray*)var326)->values[2] = (val*) var312;
+((struct instance_array__NativeArray*)var326)->values[3] = (val*) var317;
+((struct instance_array__NativeArray*)var326)->values[4] = (val*) var320;
+{
+((void (*)(val*, val*, long))(var324->class->vft[COLOR_array__Array__with_native]))(var324, var326, var325) /* with_native on <var324:Array[Object]>*/;
+}
+}
+{
+var327 = ((val* (*)(val*))(var324->class->vft[COLOR_string__Object__to_s]))(var324) /* to_s on <var324:Array[Object]>*/;
+}
+var328 = NEW_array__Array(&type_array__Arraykernel__Object);
+{ /* var328 = array_instance Array[Object] */
+var329 = 1;
+var330 = NEW_array__NativeArray(var329, &type_array__NativeArraykernel__Object);
+((struct instance_array__NativeArray*)var330)->values[0] = (val*) var327;
+{
+((void (*)(val*, val*, long))(var328->class->vft[COLOR_array__Array__with_native]))(var328, var330, var329) /* with_native on <var328:Array[Object]>*/;
+}
+}
+{
+file__Object__printn(self, var328); /* Direct call file#Object#printn on <self:AbstractCompiler>*/
+}
+if (varonce331) {
+var332 = varonce331;
+} else {
+var333 = "";
+var334 = 0;
+var335 = string__NativeString__to_s_with_length(var333, var334);
+var332 = var335;
+varonce331 = var332;
+}
+{
+file__Object__print(self, var332); /* Direct call file#Object#print on <self:AbstractCompiler>*/
+}
+CONTINUE_label336: (void)0;
+{
+array__ArrayIterator__next(var202); /* Direct call array#ArrayIterator#next on <var202:ArrayIterator[nullable Object]>*/
+}
+}
+BREAK_label336: (void)0;
+} else {
+}
+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:;
+}
+/* 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:;
+}
+/* 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 */;
+long var_a /* var a: Int */;
+long var_b /* var b: Int */;
+long var1 /* : Int */;
+short int var2 /* : Bool */;
+short int var3 /* : Bool */;
+short int var5 /* : Bool */;
+static val* varonce;
+val* var6 /* : String */;
+char* var7 /* : NativeString */;
+long var8 /* : Int */;
+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 */;
+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;
+}
+var2 = var3;
+}
+if (var2){
+if (varonce) {
+var6 = varonce;
+} else {
+var7 = "n/a";
+var8 = 3;
+var9 = string__NativeString__to_s_with_length(var7, var8);
+var6 = var9;
+varonce = var6;
+}
+var = var6;
+goto RET_LABEL;
+} else {
+}
+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", 332);
+show_backtrace(1);
+}
+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", 333);
+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", 298);
+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#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__AbstractCompiler__div(self, p0, p1);
+var = var1;
+RET_LABEL:;
+return var;
+}
+/* method abstract_compiler#CodeFile#name for (self: CodeFile): String */
+val* abstract_compiler__CodeFile__name(val* self) {
+val* var /* : String */;
+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", "src/abstract_compiler.nit", 954);
+show_backtrace(1);
+}
+var = var1;
+RET_LABEL:;
+return var;
+}
+/* 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", "src/abstract_compiler.nit", 954);
+show_backtrace(1);
+}
+var1 = var3;
+RET_LABEL2:(void)0;
+}
+var = var1;
+RET_LABEL:;
+return var;
+}
+/* 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", "src/abstract_compiler.nit", 955);
+show_backtrace(1);
+}
+var = var1;
+RET_LABEL:;
+return var;
+}
+/* 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", "src/abstract_compiler.nit", 955);
+show_backtrace(1);
+}
+var1 = var3;
+RET_LABEL2:(void)0;
+}
+var = var1;
+RET_LABEL:;
+return var;
+}
+/* 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", "src/abstract_compiler.nit", 956);
+show_backtrace(1);
+}
+var = var1;
+RET_LABEL:;
+return var;
+}
+/* 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", "src/abstract_compiler.nit", 956);
+show_backtrace(1);
+}
+var1 = var3;
+RET_LABEL2:(void)0;
+}
+var = var1;
+RET_LABEL:;
+return var;
+}
+/* method abstract_compiler#CodeFile#init for (self: CodeFile, String) */
+void abstract_compiler__CodeFile__init(val* self, val* p0) {
+self->attrs[COLOR_abstract_compiler__CodeFile___name].val = p0; /* _name on <self:CodeFile> */
+RET_LABEL:;
+}
+/* method abstract_compiler#CodeFile#init for (self: Object, String) */
+void VIRTUAL_abstract_compiler__CodeFile__init(val* self, val* p0) {
+{ /* Inline abstract_compiler#CodeFile#init (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#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", "src/abstract_compiler.nit", 961);
+show_backtrace(1);
+}
+var = var1;
+RET_LABEL:;
+return var;
+}
+/* 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", "src/abstract_compiler.nit", 961);
+show_backtrace(1);
+}
+var1 = var3;
+RET_LABEL2:(void)0;
+}
+var = var1;
+RET_LABEL:;
+return var;
+}
+/* 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:;
+}
+/* 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;
+}
+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", "src/abstract_compiler.nit", 962);
+show_backtrace(1);
+}
+var = var1;
+RET_LABEL:;
+return var;
+}
+/* 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", "src/abstract_compiler.nit", 962);
+show_backtrace(1);
+}
+var1 = var3;
+RET_LABEL2:(void)0;
+}
+var = var1;
+RET_LABEL:;
+return var;
+}
+/* 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", "src/abstract_compiler.nit", 963);
+show_backtrace(1);
+}
+var = var1;
+RET_LABEL:;
+return var;
+}
+/* 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", "src/abstract_compiler.nit", 963);
+show_backtrace(1);
+}
+var1 = var3;
+RET_LABEL2:(void)0;
+}
+var = var1;
+RET_LABEL:;
+return var;
+}
+/* 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", "src/abstract_compiler.nit", 963);
+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#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#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;
+}
+}
+{
+{ /* 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", "src/abstract_compiler.nit", 955);
+show_backtrace(1);
+}
+var = var3;
+RET_LABEL2:(void)0;
+}
+}
+{
+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", "src/abstract_compiler.nit", 984);
+show_backtrace(1);
+}
+var = var1;
+RET_LABEL:;
+return var;
+}
+/* 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", "src/abstract_compiler.nit", 984);
+show_backtrace(1);
+}
+var1 = var3;
+RET_LABEL2:(void)0;
+}
+var = var1;
+RET_LABEL:;
+return var;
+}
+/* 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", "src/abstract_compiler.nit", 984);
+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", "src/abstract_compiler.nit", 984);
+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#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#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#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#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#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#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#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#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", "src/abstract_compiler.nit", 984);
+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", "src/abstract_compiler.nit", 436);
+show_backtrace(1);
+}
+var4 = var6;
+RET_LABEL5:(void)0;
+}
+}
+{
+var7 = model__MModule__object_type(var4);
+}
+var = var7;
+goto RET_LABEL;
+RET_LABEL:;
+return var;
+}
+/* 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;
+}
+/* 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", "src/abstract_compiler.nit", 984);
+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", "src/abstract_compiler.nit", 436);
+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#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", "src/abstract_compiler.nit", 999);
+show_backtrace(1);
+}
+var = var1;
+RET_LABEL:;
+return var;
+}
+/* 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", "src/abstract_compiler.nit", 999);
+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 */;
+int cltype;
+int idtype;
+const struct type* type_struct;
+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) {
+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", "src/abstract_compiler.nit", 1001);
+show_backtrace(1);
+}
+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 {
+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", "src/abstract_compiler.nit", 984);
+show_backtrace(1);
+}
+self->attrs[COLOR_abstract_compiler__AbstractCompilerVisitor___compiler].val = var_compiler; /* _compiler on <self:AbstractCompilerVisitor> */
+RET_LABEL1:(void)0;
+}
+}
+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", "src/abstract_compiler.nit", 465);
+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:;
+}
+/* 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", "src/abstract_compiler.nit", 984);
+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", "src/abstract_compiler.nit", 436);
+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#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;
+val* var2 /* : AbstractCompiler */;
+val* var4 /* : AbstractCompiler */;
+val* var5 /* : ModelBuilder */;
+val* var7 /* : ModelBuilder */;
+val* var8 /* : nullable ANode */;
+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 = var_recv->type->type_table[cltype] == idtype;
+}
+if (unlikely(!var1)) {
+PRINT_ERROR("Runtime error: %s", "Assert failed");
+PRINT_ERROR(" (%s:%d)\n", "src/abstract_compiler.nit", 1013);
+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", "src/abstract_compiler.nit", 984);
+show_backtrace(1);
+}
+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", "src/abstract_compiler.nit", 443);
+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;
+}
+}
+if (unlikely(var8 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Cast failed");
+PRINT_ERROR(" (%s:%d)\n", "src/abstract_compiler.nit", 1014);
+show_backtrace(1);
+}
+{
+{ /* 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", "src/model/model.nit", 969);
+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", "src/abstract_compiler.nit", 984);
+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", "src/abstract_compiler.nit", 436);
+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#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#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_args /* var args: Array[RuntimeVariable] */;
+val* var1 /* : MMethod */;
+val* var3 /* : MMethod */;
+val* var4 /* : nullable RuntimeVariable */;
+var_callsite = p0;
+var_args = p1;
+{
+{ /* Inline typing#CallSite#mproperty (var_callsite) on <var_callsite:CallSite> */
+var3 = var_callsite->attrs[COLOR_typing__CallSite___mproperty].val; /* _mproperty on <var_callsite:CallSite> */
+if (unlikely(var3 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _mproperty");
+PRINT_ERROR(" (%s:%d)\n", "src/typing.nit", 422);
+show_backtrace(1);
+}
+var1 = var3;
+RET_LABEL2:(void)0;
+}
+}
+{
+var4 = separate_compiler__SeparateCompilerVisitor__send(self, var1, var_args);
+}
+var = var4;
+goto RET_LABEL;
+RET_LABEL:;
+return var;
+}
+/* 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#AbstractCompilerVisitor#varargize for (self: AbstractCompilerVisitor, MPropDef, MSignature, Array[RuntimeVariable]) */
+void abstract_compiler__AbstractCompilerVisitor__varargize(val* self, val* p0, val* p1, val* p2) {
+val* var_mpropdef /* var mpropdef: MPropDef */;
+val* var_msignature /* var msignature: MSignature */;
+val* var_args /* var args: Array[RuntimeVariable] */;
+val* var /* : nullable Object */;
+val* var_recv /* var recv: RuntimeVariable */;
+long var1 /* : Int */;
+long var3 /* : Int */;
+long var_vararg_rank /* var vararg_rank: Int */;
+long var4 /* : Int */;
+short int var5 /* : Bool */;
+short int var7 /* : Bool */;
+int cltype;
+int idtype;
+const char* var_class_name;
+short int var8 /* : Bool */;
+long var9 /* : Int */;
+long var10 /* : Int */;
+long var11 /* : Int */;
+long var12 /* : Int */;
+short int var14 /* : Bool */;
+int cltype15;
+int idtype16;
+const char* var_class_name17;
+long var18 /* : Int */;
+short int var19 /* : Bool */;
+short int var21 /* : Bool */;
+int cltype22;
+int idtype23;
+const char* var_class_name24;
+short int var25 /* : Bool */;
+val* var_rawargs /* var rawargs: Array[RuntimeVariable] */;
+val* var26 /* : Array[RuntimeVariable] */;
+val* var27 /* : nullable Object */;
+val* var28 /* : Range[Int] */;
+long var29 /* : Int */;
+val* var30 /* : Discrete */;
+val* var31 /* : Discrete */;
+val* var32 /* : Iterator[Discrete] */;
+short int var33 /* : Bool */;
+val* var34 /* : nullable Object */;
+long var_i /* var i: Int */;
+long var35 /* : Int */;
+long var36 /* : Int */;
+long var37 /* : Int */;
+short int var39 /* : Bool */;
+int cltype40;
+int idtype41;
+const char* var_class_name42;
+long var43 /* : Int */;
+val* var44 /* : nullable Object */;
+long var45 /* : Int */;
+long var46 /* : Int */;
+short int var48 /* : Bool */;
+int cltype49;
+int idtype50;
+const char* var_class_name51;
+long var52 /* : Int */;
+long var53 /* : Int */;
+long var54 /* : Int */;
+short int var56 /* : Bool */;
+int cltype57;
+int idtype58;
+const char* var_class_name59;
+long var60 /* : Int */;
+long var61 /* : Int */;
+long var62 /* : Int */;
+short int var64 /* : Bool */;
+int cltype65;
+int idtype66;
+const char* var_class_name67;
+long var68 /* : Int */;
+long var_vararg_lastrank /* var vararg_lastrank: Int */;
+val* var69 /* : Array[RuntimeVariable] */;
+val* var_vararg /* var vararg: Array[RuntimeVariable] */;
+val* var70 /* : Range[Int] */;
+val* var71 /* : Discrete */;
+val* var72 /* : Discrete */;
+val* var73 /* : Iterator[Discrete] */;
+short int var74 /* : Bool */;
+val* var75 /* : nullable Object */;
+long var_i76 /* var i: Int */;
+long var77 /* : Int */;
+long var78 /* : Int */;
+long var79 /* : Int */;
+short int var81 /* : Bool */;
+int cltype82;
+int idtype83;
+const char* var_class_name84;
+long var85 /* : Int */;
+val* var86 /* : nullable Object */;
+val* var88 /* : Array[MParameter] */;
+val* var90 /* : Array[MParameter] */;
+val* var91 /* : nullable Object */;
+val* var92 /* : MType */;
+val* var94 /* : MType */;
+val* var_elttype /* var elttype: MType */;
+val* var95 /* : RuntimeVariable */;
+val* var96 /* : Range[Int] */;
+long var97 /* : Int */;
+long var98 /* : Int */;
+short int var100 /* : Bool */;
+int cltype101;
+int idtype102;
+const char* var_class_name103;
+long var104 /* : Int */;
+long var105 /* : Int */;
+long var106 /* : Int */;
+long var107 /* : Int */;
+short int var109 /* : Bool */;
+int cltype110;
+int idtype111;
+const char* var_class_name112;
+long var113 /* : Int */;
+val* var114 /* : Discrete */;
+val* var115 /* : Discrete */;
+val* var116 /* : Iterator[Discrete] */;
+short int var117 /* : Bool */;
+val* var118 /* : nullable Object */;
+long var_i119 /* var i: Int */;
+long var120 /* : Int */;
+long var121 /* : Int */;
+long var122 /* : Int */;
+short int var124 /* : Bool */;
+int cltype125;
+int idtype126;
+const char* var_class_name127;
+long var128 /* : Int */;
+val* var129 /* : nullable Object */;
+var_mpropdef = p0;
+var_msignature = p1;
+var_args = p2;
+{
+var = abstract_collection__SequenceRead__first(var_args);
+}
+var_recv = var;
+{
+{ /* Inline model#MSignature#vararg_rank (var_msignature) on <var_msignature:MSignature> */
+var3 = var_msignature->attrs[COLOR_model__MSignature___vararg_rank].l; /* _vararg_rank on <var_msignature:MSignature> */
+var1 = var3;
+RET_LABEL2:(void)0;
+}
+}
+var_vararg_rank = var1;
+var4 = 0;
+{
+{ /* Inline kernel#Int#>= (var_vararg_rank,var4) on <var_vararg_rank:Int> */
+/* Covariant cast for argument 0 (i) <var4:Int> isa OTHER */
+/* <var4:Int> isa OTHER */
+var7 = 1; /* easy <var4:Int> isa OTHER*/
+if (unlikely(!var7)) {
+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", 326);
+show_backtrace(1);
+}
+var8 = var_vararg_rank >= var4;
+var5 = var8;
+goto RET_LABEL6;
+RET_LABEL6:(void)0;
+}
+}
+if (var5){
+{
+var9 = array__AbstractArrayRead__length(var_args);
+}
+{
+var10 = model__MSignature__arity(var_msignature);
+}
+var11 = 1;
+{
+{ /* Inline kernel#Int#+ (var10,var11) on <var10:Int> */
+/* Covariant cast for argument 0 (i) <var11:Int> isa OTHER */
+/* <var11:Int> isa OTHER */
+var14 = 1; /* easy <var11:Int> isa OTHER*/
+if (unlikely(!var14)) {
+var_class_name17 = type_kernel__Int.name;
+PRINT_ERROR("Runtime error: Cast failed. Expected `%s`, got `%s`", "OTHER", var_class_name17);
+PRINT_ERROR(" (%s:%d)\n", "lib/standard/kernel.nit", 328);
+show_backtrace(1);
+}
+var18 = var10 + var11;
+var12 = var18;
+goto RET_LABEL13;
+RET_LABEL13:(void)0;
+}
+}
+{
+{ /* Inline kernel#Int#>= (var9,var12) on <var9:Int> */
+/* Covariant cast for argument 0 (i) <var12:Int> isa OTHER */
+/* <var12:Int> isa OTHER */
+var21 = 1; /* easy <var12:Int> isa OTHER*/
+if (unlikely(!var21)) {
+var_class_name24 = type_kernel__Int.name;
+PRINT_ERROR("Runtime error: Cast failed. Expected `%s`, got `%s`", "OTHER", var_class_name24);
+PRINT_ERROR(" (%s:%d)\n", "lib/standard/kernel.nit", 326);
+show_backtrace(1);
+}
+var25 = var9 >= var12;
+var19 = var25;
+goto RET_LABEL20;
+RET_LABEL20:(void)0;
+}
+}
+if (unlikely(!var19)) {
+PRINT_ERROR("Runtime error: %s", "Assert failed");
+PRINT_ERROR(" (%s:%d)\n", "src/abstract_compiler.nit", 1036);
+show_backtrace(1);
+}
+var_rawargs = var_args;
+var26 = NEW_array__Array(&type_array__Arrayabstract_compiler__RuntimeVariable);
+{
+array__Array__init(var26); /* Direct call array#Array#init on <var26:Array[RuntimeVariable]>*/
+}
+var_args = var26;
+{
+var27 = abstract_collection__SequenceRead__first(var_rawargs);
+}
+{
+array__Array__add(var_args, var27); /* Direct call array#Array#add on <var_args:Array[RuntimeVariable]>*/
+}
+var28 = NEW_range__Range(&type_range__Rangekernel__Int);
+var29 = 0;
+{
+var30 = BOX_kernel__Int(var29); /* autobox from Int to Discrete */
+var31 = BOX_kernel__Int(var_vararg_rank); /* autobox from Int to Discrete */
+range__Range__without_last(var28, var30, var31); /* Direct call range#Range#without_last on <var28:Range[Int]>*/
+}
+{
+var32 = range__Range__iterator(var28);
+}
+for(;;) {
+{
+var33 = ((short int (*)(val*))(var32->class->vft[COLOR_abstract_collection__Iterator__is_ok]))(var32) /* is_ok on <var32:Iterator[Discrete]>*/;
+}
+if(!var33) break;
+{
+var34 = ((val* (*)(val*))(var32->class->vft[COLOR_abstract_collection__Iterator__item]))(var32) /* item on <var32:Iterator[Discrete]>*/;
+}
+var35 = ((struct instance_kernel__Int*)var34)->value; /* autounbox from nullable Object to Int */;
+var_i = var35;
+var36 = 1;
+{
+{ /* Inline kernel#Int#+ (var_i,var36) on <var_i:Int> */
+/* Covariant cast for argument 0 (i) <var36:Int> isa OTHER */
+/* <var36:Int> isa OTHER */
+var39 = 1; /* easy <var36:Int> isa OTHER*/
+if (unlikely(!var39)) {
+var_class_name42 = type_kernel__Int.name;
+PRINT_ERROR("Runtime error: Cast failed. Expected `%s`, got `%s`", "OTHER", var_class_name42);
+PRINT_ERROR(" (%s:%d)\n", "lib/standard/kernel.nit", 328);
+show_backtrace(1);
+}
+var43 = var_i + var36;
+var37 = var43;
+goto RET_LABEL38;
+RET_LABEL38:(void)0;
+}
+}
+{
+var44 = array__Array___91d_93d(var_rawargs, var37);
+}
+{
+array__Array__add(var_args, var44); /* Direct call array#Array#add on <var_args:Array[RuntimeVariable]>*/
+}
+CONTINUE_label: (void)0;
+{
+((void (*)(val*))(var32->class->vft[COLOR_abstract_collection__Iterator__next]))(var32) /* next on <var32:Iterator[Discrete]>*/;
+}
+}
+BREAK_label: (void)0;
+{
+var45 = array__AbstractArrayRead__length(var_rawargs);
+}
+{
+{ /* Inline kernel#Int#+ (var_vararg_rank,var45) on <var_vararg_rank:Int> */
+/* Covariant cast for argument 0 (i) <var45:Int> isa OTHER */
+/* <var45:Int> isa OTHER */
+var48 = 1; /* easy <var45:Int> isa OTHER*/
+if (unlikely(!var48)) {
+var_class_name51 = type_kernel__Int.name;
+PRINT_ERROR("Runtime error: Cast failed. Expected `%s`, got `%s`", "OTHER", var_class_name51);
+PRINT_ERROR(" (%s:%d)\n", "lib/standard/kernel.nit", 328);
+show_backtrace(1);
+}
+var52 = var_vararg_rank + var45;
+var46 = var52;
+goto RET_LABEL47;
+RET_LABEL47:(void)0;
+}
+}
+var53 = 1;
+{
+{ /* Inline kernel#Int#- (var46,var53) on <var46:Int> */
+/* Covariant cast for argument 0 (i) <var53:Int> isa OTHER */
+/* <var53:Int> isa OTHER */
+var56 = 1; /* easy <var53:Int> isa OTHER*/
+if (unlikely(!var56)) {
+var_class_name59 = type_kernel__Int.name;
+PRINT_ERROR("Runtime error: Cast failed. Expected `%s`, got `%s`", "OTHER", var_class_name59);
+PRINT_ERROR(" (%s:%d)\n", "lib/standard/kernel.nit", 331);
+show_backtrace(1);
+}
+var60 = var46 - var53;
+var54 = var60;
+goto RET_LABEL55;
+RET_LABEL55:(void)0;
+}
+}
+{
+var61 = model__MSignature__arity(var_msignature);
+}
+{
+{ /* Inline kernel#Int#- (var54,var61) on <var54:Int> */
+/* Covariant cast for argument 0 (i) <var61:Int> isa OTHER */
+/* <var61:Int> isa OTHER */
+var64 = 1; /* easy <var61:Int> isa OTHER*/
+if (unlikely(!var64)) {
+var_class_name67 = type_kernel__Int.name;
+PRINT_ERROR("Runtime error: Cast failed. Expected `%s`, got `%s`", "OTHER", var_class_name67);
+PRINT_ERROR(" (%s:%d)\n", "lib/standard/kernel.nit", 331);
+show_backtrace(1);
+}
+var68 = var54 - var61;
+var62 = var68;
+goto RET_LABEL63;
+RET_LABEL63:(void)0;
+}
+}
+var_vararg_lastrank = var62;
+var69 = NEW_array__Array(&type_array__Arrayabstract_compiler__RuntimeVariable);
+{
+array__Array__init(var69); /* Direct call array#Array#init on <var69:Array[RuntimeVariable]>*/
+}
+var_vararg = var69;
+var70 = NEW_range__Range(&type_range__Rangekernel__Int);
+{
+var71 = BOX_kernel__Int(var_vararg_rank); /* autobox from Int to Discrete */
+var72 = BOX_kernel__Int(var_vararg_lastrank); /* autobox from Int to Discrete */
+range__Range__init(var70, var71, var72); /* Direct call range#Range#init on <var70:Range[Int]>*/
+}
+{
+var73 = range__Range__iterator(var70);
+}
+for(;;) {
+{
+var74 = ((short int (*)(val*))(var73->class->vft[COLOR_abstract_collection__Iterator__is_ok]))(var73) /* is_ok on <var73:Iterator[Discrete]>*/;
+}
+if(!var74) break;
+{
+var75 = ((val* (*)(val*))(var73->class->vft[COLOR_abstract_collection__Iterator__item]))(var73) /* item on <var73:Iterator[Discrete]>*/;
+}
+var77 = ((struct instance_kernel__Int*)var75)->value; /* autounbox from nullable Object to Int */;
+var_i76 = var77;
+var78 = 1;
+{
+{ /* Inline kernel#Int#+ (var_i76,var78) on <var_i76:Int> */
+/* Covariant cast for argument 0 (i) <var78:Int> isa OTHER */
+/* <var78:Int> isa OTHER */
+var81 = 1; /* easy <var78:Int> isa OTHER*/
+if (unlikely(!var81)) {
+var_class_name84 = type_kernel__Int.name;
+PRINT_ERROR("Runtime error: Cast failed. Expected `%s`, got `%s`", "OTHER", var_class_name84);
+PRINT_ERROR(" (%s:%d)\n", "lib/standard/kernel.nit", 328);
+show_backtrace(1);
+}
+var85 = var_i76 + var78;
+var79 = var85;
+goto RET_LABEL80;
+RET_LABEL80:(void)0;
+}
+}
+{
+var86 = array__Array___91d_93d(var_rawargs, var79);
+}
+{
+array__Array__add(var_vararg, var86); /* Direct call array#Array#add on <var_vararg:Array[RuntimeVariable]>*/
+}
+CONTINUE_label87: (void)0;
+{
+((void (*)(val*))(var73->class->vft[COLOR_abstract_collection__Iterator__next]))(var73) /* next on <var73:Iterator[Discrete]>*/;
+}
+}
+BREAK_label87: (void)0;
+{
+{ /* Inline model#MSignature#mparameters (var_msignature) on <var_msignature:MSignature> */
+var90 = var_msignature->attrs[COLOR_model__MSignature___mparameters].val; /* _mparameters on <var_msignature:MSignature> */
+if (unlikely(var90 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _mparameters");
+PRINT_ERROR(" (%s:%d)\n", "src/model/model.nit", 1452);
+show_backtrace(1);
+}
+var88 = var90;
+RET_LABEL89:(void)0;
+}
+}
+{
+var91 = array__Array___91d_93d(var88, var_vararg_rank);
+}
+{
+{ /* Inline model#MParameter#mtype (var91) on <var91:nullable Object(MParameter)> */
+var94 = var91->attrs[COLOR_model__MParameter___mtype].val; /* _mtype on <var91:nullable Object(MParameter)> */
+if (unlikely(var94 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _mtype");
+PRINT_ERROR(" (%s:%d)\n", "src/model/model.nit", 1552);
+show_backtrace(1);
+}
+var92 = var94;
+RET_LABEL93:(void)0;
+}
+}
+var_elttype = var92;
+{
+var95 = separate_compiler__SeparateCompilerVisitor__vararg_instance(self, var_mpropdef, var_recv, var_vararg, var_elttype);
+}
+{
+array__Array__add(var_args, var95); /* Direct call array#Array#add on <var_args:Array[RuntimeVariable]>*/
+}
+var96 = NEW_range__Range(&type_range__Rangekernel__Int);
+var97 = 1;
+{
+{ /* Inline kernel#Int#+ (var_vararg_lastrank,var97) on <var_vararg_lastrank:Int> */
+/* Covariant cast for argument 0 (i) <var97:Int> isa OTHER */
+/* <var97:Int> isa OTHER */
+var100 = 1; /* easy <var97:Int> isa OTHER*/
+if (unlikely(!var100)) {
+var_class_name103 = type_kernel__Int.name;
+PRINT_ERROR("Runtime error: Cast failed. Expected `%s`, got `%s`", "OTHER", var_class_name103);
+PRINT_ERROR(" (%s:%d)\n", "lib/standard/kernel.nit", 328);
+show_backtrace(1);
+}
+var104 = var_vararg_lastrank + var97;
+var98 = var104;
+goto RET_LABEL99;
+RET_LABEL99:(void)0;
+}
+}
+{
+var105 = array__AbstractArrayRead__length(var_rawargs);
+}
+var106 = 1;
+{
+{ /* Inline kernel#Int#- (var105,var106) on <var105:Int> */
+/* Covariant cast for argument 0 (i) <var106:Int> isa OTHER */
+/* <var106:Int> isa OTHER */
+var109 = 1; /* easy <var106:Int> isa OTHER*/
+if (unlikely(!var109)) {
+var_class_name112 = type_kernel__Int.name;
+PRINT_ERROR("Runtime error: Cast failed. Expected `%s`, got `%s`", "OTHER", var_class_name112);
+PRINT_ERROR(" (%s:%d)\n", "lib/standard/kernel.nit", 331);
+show_backtrace(1);
+}
+var113 = var105 - var106;
+var107 = var113;
+goto RET_LABEL108;
+RET_LABEL108:(void)0;
+}
+}
+{
+var114 = BOX_kernel__Int(var98); /* autobox from Int to Discrete */
+var115 = BOX_kernel__Int(var107); /* autobox from Int to Discrete */
+range__Range__without_last(var96, var114, var115); /* Direct call range#Range#without_last on <var96:Range[Int]>*/
+}
+{
+var116 = range__Range__iterator(var96);
+}
+for(;;) {
+{
+var117 = ((short int (*)(val*))(var116->class->vft[COLOR_abstract_collection__Iterator__is_ok]))(var116) /* is_ok on <var116:Iterator[Discrete]>*/;
+}
+if(!var117) break;
+{
+var118 = ((val* (*)(val*))(var116->class->vft[COLOR_abstract_collection__Iterator__item]))(var116) /* item on <var116:Iterator[Discrete]>*/;
+}
+var120 = ((struct instance_kernel__Int*)var118)->value; /* autounbox from nullable Object to Int */;
+var_i119 = var120;
+var121 = 1;
+{
+{ /* Inline kernel#Int#+ (var_i119,var121) on <var_i119:Int> */
+/* Covariant cast for argument 0 (i) <var121:Int> isa OTHER */
+/* <var121:Int> isa OTHER */
+var124 = 1; /* easy <var121:Int> isa OTHER*/
+if (unlikely(!var124)) {
+var_class_name127 = type_kernel__Int.name;
+PRINT_ERROR("Runtime error: Cast failed. Expected `%s`, got `%s`", "OTHER", var_class_name127);
+PRINT_ERROR(" (%s:%d)\n", "lib/standard/kernel.nit", 328);
+show_backtrace(1);
+}
+var128 = var_i119 + var121;
+var122 = var128;
+goto RET_LABEL123;
+RET_LABEL123:(void)0;
+}
+}
+{
+var129 = array__Array___91d_93d(var_rawargs, var122);
+}
+{
+array__Array__add(var_args, var129); /* Direct call array#Array#add on <var_args:Array[RuntimeVariable]>*/
+}
+CONTINUE_label130: (void)0;
+{
+((void (*)(val*))(var116->class->vft[COLOR_abstract_collection__Iterator__next]))(var116) /* next on <var116:Iterator[Discrete]>*/;
+}
+}
+BREAK_label130: (void)0;
+{
+array__AbstractArray__clear(var_rawargs); /* Direct call array#AbstractArray#clear on <var_rawargs:Array[RuntimeVariable]>*/
+}
+{
+abstract_collection__SimpleCollection__add_all(var_rawargs, var_args); /* Direct call abstract_collection#SimpleCollection#add_all on <var_rawargs:Array[RuntimeVariable]>*/
+}
+} else {
+}
+RET_LABEL:;
+}
+/* method abstract_compiler#AbstractCompilerVisitor#varargize for (self: Object, MPropDef, MSignature, Array[RuntimeVariable]) */
+void VIRTUAL_abstract_compiler__AbstractCompilerVisitor__varargize(val* self, val* p0, val* p1, val* p2) {
+abstract_compiler__AbstractCompilerVisitor__varargize(self, p0, p1, p2); /* Direct call abstract_compiler#AbstractCompilerVisitor#varargize on <self:Object(AbstractCompilerVisitor)>*/
+RET_LABEL:;
+}
+/* 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 {
+}
+{
+{ /* 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", "src/abstract_compiler.nit", 984);
+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", "src/abstract_compiler.nit", 436);
+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", "src/abstract_compiler.nit", 1069);
+show_backtrace(1);
+} else {
+{ /* 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", "src/abstract_compiler.nit", 1535);
+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", "src/abstract_compiler.nit", 1535);
+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;
+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>*/;
 }
-if (varonce) {
-var12 = varonce;
+var2 = !var1;
+if (var2){
+var = var_mtype;
+goto RET_LABEL;
 } else {
-var13 = "==";
-var14 = 2;
-var15 = string__NativeString__to_s_with_length(var13, var14);
-var12 = var15;
-varonce = var12;
 }
-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;
+{
+{ /* 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", "src/abstract_compiler.nit", 1487);
+show_backtrace(1);
 }
-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_;
+var3 = var5;
+RET_LABEL4:(void)0;
 }
-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 {
 }
-if (varonce23) {
-var24 = varonce23;
-} else {
-var25 = "Int";
-var26 = 3;
-var27 = string__NativeString__to_s_with_length(var25, var26);
-var24 = var27;
-varonce23 = var24;
+{
+{ /* 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;
 }
-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;
 }
-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;
+if (var6 == NULL) {
+PRINT_ERROR("Runtime error: %s", "Receiver is null");
+PRINT_ERROR(" (%s:%d)\n", "src/abstract_compiler.nit", 1075);
+show_backtrace(1);
 } else {
-var37 = "printf(\"%ld\\n\", ";
-var38 = 16;
-var39 = string__NativeString__to_s_with_length(var37, var38);
-var36 = var39;
-varonce35 = var36;
+{ /* 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", "src/abstract_compiler.nit", 1535);
+show_backtrace(1);
 }
-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;
+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", "src/abstract_compiler.nit", 1535);
+show_backtrace(1);
 }
-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);
+var9 = var11;
+RET_LABEL10:(void)0;
 }
-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;
 }
-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>*/;
-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;
-}
-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;
+{
+{ /* 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", "src/abstract_compiler.nit", 984);
+show_backtrace(1);
 }
-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;
+var12 = var14;
+RET_LABEL13:(void)0;
 }
-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;
+{
+{ /* 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", "src/abstract_compiler.nit", 436);
+show_backtrace(1);
+}
+var15 = var17;
+RET_LABEL16:(void)0;
 }
-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;
-}
-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;
-}
-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;
-}
-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;
-}
-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);
+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>*/;
 }
-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>*/;
+var = var19;
 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>*/;
+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", "src/abstract_compiler.nit", 1487);
+show_backtrace(1);
+}
+var2 = var4;
+RET_LABEL3:(void)0;
+}
+}
+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", "src/abstract_compiler.nit", 984);
+show_backtrace(1);
+}
+var5 = var7;
+RET_LABEL6:(void)0;
+}
+}
+{
+{ /* 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", "src/abstract_compiler.nit", 436);
+show_backtrace(1);
+}
+var8 = var10;
+RET_LABEL9:(void)0;
+}
+}
+var11 = NULL;
+{
+var12 = model__MType__is_subtype(var_valmtype, var8, var11, var_mtype);
+}
+if (var12){
+var = var_value;
 goto RET_LABEL;
 } else {
-if (varonce231) {
-var232 = varonce231;
+}
+/* <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 {
-var233 = "rshift";
-var234 = 6;
-var235 = string__NativeString__to_s_with_length(var233, var234);
-var232 = var235;
-varonce231 = var232;
+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", "src/model/model.nit", 1375);
+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", "src/abstract_compiler.nit", 984);
+show_backtrace(1);
+}
+var18 = var20;
+RET_LABEL19:(void)0;
 }
-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;
+}
+{
+{ /* 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", "src/abstract_compiler.nit", 436);
+show_backtrace(1);
+}
+var21 = var23;
+RET_LABEL22:(void)0;
+}
+}
+var24 = NULL;
+{
+var25 = model__MType__is_subtype(var15, var21, var24, var_mtype);
+}
+var13 = var25;
 } else {
-var241 = " >> ";
-var242 = 4;
-var243 = string__NativeString__to_s_with_length(var241, var242);
-var240 = var243;
-varonce239 = var240;
+var13 = var_;
 }
-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>*/;
+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", "src/abstract_compiler.nit", 1481);
+show_backtrace(1);
+}
+var27 = var29;
+RET_LABEL28:(void)0;
+}
+}
+{
+{ /* 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", "src/model/model.nit", 1375);
+show_backtrace(1);
+}
+var30 = var32;
+RET_LABEL31:(void)0;
+}
+}
+{
+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 (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>*/;
+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", "src/abstract_compiler.nit", 1481);
+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 {
-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;
+var1 = var_t->type->type_table[cltype] == idtype;
+}
+if (unlikely(!var1)) {
+PRINT_ERROR("Runtime error: %s", "Assert failed");
+PRINT_ERROR(" (%s:%d)\n", "src/abstract_compiler.nit", 1128);
+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", "src/abstract_compiler.nit", 984);
+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", "src/abstract_compiler.nit", 436);
+show_backtrace(1);
+}
+var5 = var7;
+RET_LABEL6:(void)0;
+}
+}
+{
+var8 = model__MProperty__lookup_first_definition(var_m, var5, var_t);
 }
-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>*/;
+var_propdef = var8;
+{
+var9 = separate_compiler__SeparateCompilerVisitor__call(self, var_propdef, var_t, var_args);
+}
+var = var9;
 goto RET_LABEL;
+RET_LABEL:;
+return var;
+}
+/* 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;
+}
+/* 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 {
-if (varonce283) {
-var284 = varonce283;
-} else {
-var285 = "<";
-var286 = 1;
-var287 = string__NativeString__to_s_with_length(var285, var286);
-var284 = var287;
-varonce283 = var284;
+var1 = var_t->type->type_table[cltype] == idtype;
 }
-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);
+if (unlikely(!var1)) {
+PRINT_ERROR("Runtime error: %s", "Assert failed");
+PRINT_ERROR(" (%s:%d)\n", "src/abstract_compiler.nit", 1136);
+show_backtrace(1);
 }
-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);
+{
+{ /* 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", "src/abstract_compiler.nit", 984);
+show_backtrace(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>*/;
+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", "src/abstract_compiler.nit", 436);
+show_backtrace(1);
+}
+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 (varonce303) {
-var304 = varonce303;
-} else {
-var305 = ">";
-var306 = 1;
-var307 = string__NativeString__to_s_with_length(var305, var306);
-var304 = var307;
-varonce303 = var304;
+RET_LABEL:;
+return var;
 }
-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;
+/* 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;
 }
-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>*/;
+/* 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", "src/abstract_compiler.nit", 984);
+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", "src/abstract_compiler.nit", 443);
+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", "src/modelbuilder.nit", 101);
+show_backtrace(1);
+}
+var6 = var8;
+RET_LABEL7:(void)0;
+}
+}
+{
+{ /* Inline abstract_compiler#ToolContext#opt_no_check_other (var6) on <var6:ToolContext> */
+var11 = var6->attrs[COLOR_abstract_compiler__ToolContext___opt_no_check_other].val; /* _opt_no_check_other on <var6:ToolContext> */
+if (unlikely(var11 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _opt_no_check_other");
+PRINT_ERROR(" (%s:%d)\n", "src/abstract_compiler.nit", 54);
+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 (varonce323) {
-var324 = varonce323;
-} else {
-var325 = "<=";
-var326 = 2;
-var327 = string__NativeString__to_s_with_length(var325, var326);
-var324 = var327;
-varonce323 = var324;
 }
-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;
+{
+{ /* 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", "src/abstract_compiler.nit", 1487);
+show_backtrace(1);
 }
-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;
-} else {
-var345 = ">=";
-var346 = 2;
-var347 = string__NativeString__to_s_with_length(var345, var346);
-var344 = var347;
-varonce343 = var344;
+var17 = var19;
+RET_LABEL18:(void)0;
 }
-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;
-}
-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;
-} else {
 }
+/* <var17:MType> isa MNullableType */
+cltype = type_model__MNullableType.color;
+idtype = type_model__MNullableType.id;
+if(cltype >= var17->type->table_size) {
+var20 = 0;
+} else {
+var20 = var17->type->type_table[cltype] == idtype;
 }
+var_ = var20;
+if (var20){
+var16 = var_;
+} else {
+{
+{ /* 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", "src/abstract_compiler.nit", 1487);
+show_backtrace(1);
 }
+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 {
+var24 = var21->type->type_table[cltype25] == idtype26;
 }
+var16 = var24;
 }
+var_maybenull = var16;
+if (var_maybenull){
+if (varonce) {
+var27 = varonce;
+} else {
+var28 = "if (unlikely(";
+var29 = 13;
+var30 = string__NativeString__to_s_with_length(var28, var29);
+var27 = var30;
+varonce = var27;
 }
+if (varonce31) {
+var32 = varonce31;
+} else {
+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 {
+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 {
+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:;
 }
-} else {
-if (varonce394) {
-var395 = varonce394;
-} else {
-var396 = "Char";
-var397 = 4;
-var398 = string__NativeString__to_s_with_length(var396, var397);
-var395 = var398;
-varonce394 = var395;
+/* 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", "src/abstract_compiler.nit", 1169);
+show_backtrace(1);
 }
-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;
-} 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;
-} else {
-var414 = ");";
-var415 = 2;
-var416 = string__NativeString__to_s_with_length(var414, var415);
-var413 = var416;
-varonce412 = var413;
-}
-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>*/;
-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;
-}
-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;
-}
-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>*/;
-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;
+var = var1;
+RET_LABEL:;
+return var;
 }
-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;
+/* 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", "src/abstract_compiler.nit", 1169);
+show_backtrace(1);
+}
+var1 = var3;
+RET_LABEL2:(void)0;
 }
-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;
-} else {
-if (varonce458) {
-var459 = varonce458;
-} else {
-var460 = "-";
-var461 = 1;
-var462 = string__NativeString__to_s_with_length(var460, var461);
-var459 = var462;
-varonce458 = var459;
+var = var1;
+RET_LABEL:;
+return var;
 }
-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;
+/* 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;
 }
-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>*/;
-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>*/;
-goto RET_LABEL;
-} else {
-if (varonce489) {
-var490 = varonce489;
-} else {
-var491 = "!=";
-var492 = 2;
-var493 = string__NativeString__to_s_with_length(var491, var492);
-var490 = var493;
-varonce489 = var490;
-}
-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;
+/* 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;
 }
-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;
+var = var1;
+RET_LABEL:;
+return var;
 }
-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;
-}
-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;
-}
-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;
-}
-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);
-}
-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;
+/* 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:;
 }
-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;
+/* 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;
 }
-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;
-}
-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>*/;
-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;
-} else {
+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", "src/abstract_compiler.nit", 1169);
+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", "src/abstract_compiler.nit", 1169);
+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 {
 }
+{
+{ /* 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;
 }
 }
+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", 328);
+show_backtrace(1);
 }
+var16 = var9 + var12;
+var13 = var16;
+goto RET_LABEL14;
+RET_LABEL14:(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;
+var_i = var13;
+for(;;) {
+{
+var17 = string__Int__to_s(var_i);
 }
-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;
+{
+var18 = string__FlatString___43d(var_s, var17);
 }
-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;
+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", "src/abstract_compiler.nit", 1169);
+show_backtrace(1);
 }
-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);
+var19 = var21;
+RET_LABEL20:(void)0;
 }
-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;
-}
-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>*/;
-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>*/;
-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", "src/abstract_compiler.nit", 1169);
+show_backtrace(1);
 }
-} else {
-if (varonce740) {
-var741 = varonce740;
-} else {
-var742 = "Float";
-var743 = 5;
-var744 = string__NativeString__to_s_with_length(var742, var743);
-var741 = var744;
-varonce740 = var741;
+var25 = var27;
+RET_LABEL26:(void)0;
 }
-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;
-}
-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;
 }
-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;
+{
+hash_collection__HashSet__add(var25, var_s2); /* Direct call hash_collection#HashSet#add on <var25:HashSet[String]>*/
 }
-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);
-}
-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);
-}
-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 = var_s2;
 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;
-}
-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;
 }
-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;
+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", 328);
+show_backtrace(1);
+}
+var35 = var_i + var28;
+var29 = var35;
+goto RET_LABEL30;
+RET_LABEL30:(void)0;
 }
-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;
+var_i = var29;
+CONTINUE_label: (void)0;
 }
-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);
+BREAK_label: (void)0;
+RET_LABEL:;
+return var;
 }
-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);
+/* 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;
 }
-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;
-} else {
-var880 = "*";
-var881 = 1;
-var882 = string__NativeString__to_s_with_length(var880, var881);
-var879 = var882;
-varonce878 = var879;
-}
-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;
-}
-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>*/;
-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>*/;
-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;
-} else {
-if (varonce929) {
-var930 = varonce929;
-} else {
-var931 = "!=";
-var932 = 2;
-var933 = string__NativeString__to_s_with_length(var931, var932);
-var930 = var933;
-varonce929 = var930;
-}
-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;
-} 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;
-} 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;
-} 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;
-} 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;
-} 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;
+/* 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 {
+var2 = 1; /* arg is null and recv is not */
 }
+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;
 }
+var7 = !var5;
+var3 = var7;
+goto RET_LABEL4;
+RET_LABEL4:(void)0;
 }
+var2 = var3;
 }
+if (unlikely(!var2)) {
+PRINT_ERROR("Runtime error: %s", "Assert failed");
+PRINT_ERROR(" (%s:%d)\n", "src/abstract_compiler.nit", 1194);
+show_backtrace(1);
 }
+{
+{ /* 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", "src/abstract_compiler.nit", 1203);
+show_backtrace(1);
 }
+var8 = var10;
+RET_LABEL9:(void)0;
 }
 }
+{
+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", "src/abstract_compiler.nit", 1203);
+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 {
-if (varonce1049) {
-var1050 = varonce1049;
-} else {
-var1051 = "NativeString";
-var1052 = 12;
-var1053 = string__NativeString__to_s_with_length(var1051, var1052);
-var1050 = var1053;
-varonce1049 = var1050;
+var20 = 0; /* arg is null but recv is not */
 }
-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;
+if (0) {
+var21 = string__FlatString___61d_61d(var_name, var19);
+var20 = var21;
 }
-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;
+if (var20){
+if (varonce) {
+var22 = varonce;
 } else {
-var1065 = "[";
-var1066 = 1;
-var1067 = string__NativeString__to_s_with_length(var1065, var1066);
-var1064 = var1067;
-varonce1063 = var1064;
+var23 = "label";
+var24 = 5;
+var25 = string__NativeString__to_s_with_length(var23, var24);
+var22 = var25;
+varonce = var22;
 }
-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;
+var_name = var22;
 } else {
-var1072 = "]";
-var1073 = 1;
-var1074 = string__NativeString__to_s_with_length(var1072, var1073);
-var1071 = var1074;
-varonce1070 = var1071;
 }
-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);
+{
+var26 = abstract_compiler__AbstractCompilerVisitor__get_name(self, var_name);
 }
-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);
+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", "src/abstract_compiler.nit", 1203);
+show_backtrace(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>*/;
+var27 = var29;
+RET_LABEL28:(void)0;
+}
+}
+{
+hash_collection__HashMap___91d_93d_61d(var27, var_e, var_name); /* Direct call hash_collection#HashMap#[]= on <var27:HashMap[EscapeMark, String]>*/
+}
+var = var_name;
 goto RET_LABEL;
-} else {
+RET_LABEL:;
+return var;
 }
+/* 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#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", "src/abstract_compiler.nit", 1203);
+show_backtrace(1);
 }
+var = var1;
+RET_LABEL:;
+return var;
 }
-} else {
-if (varonce1184) {
-var1185 = varonce1184;
-} else {
-var1186 = "NativeArray";
-var1187 = 11;
-var1188 = string__NativeString__to_s_with_length(var1186, var1187);
-var1185 = var1188;
-varonce1184 = var1185;
+/* 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", "src/abstract_compiler.nit", 1203);
+show_backtrace(1);
+}
+var1 = var3;
+RET_LABEL2:(void)0;
 }
-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 {
+var = var1;
+RET_LABEL:;
+return var;
 }
+/* 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", "src/abstract_compiler.nit", 1211);
+show_backtrace(1);
 }
+var = var1;
+RET_LABEL:;
+return var;
 }
+/* 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", "src/abstract_compiler.nit", 1211);
+show_backtrace(1);
+}
+var1 = var3;
+RET_LABEL2:(void)0;
 }
+var = var1;
+RET_LABEL:;
+return var;
 }
+/* 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* var9 /* : String */;
+char* var10 /* : NativeString */;
+long var11 /* : Int */;
+val* var12 /* : FlatString */;
+val* var13 /* : String */;
+val* var15 /* : String */;
+val* var16 /* : Array[Object] */;
+long var17 /* : Int */;
+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 */;
+char* var29 /* : NativeString */;
+long var30 /* : Int */;
+val* var31 /* : FlatString */;
+static val* varonce32;
+val* var33 /* : String */;
+char* var34 /* : NativeString */;
+long var35 /* : Int */;
+val* var36 /* : FlatString */;
+static val* varonce37;
+val* var38 /* : String */;
+char* var39 /* : NativeString */;
+long var40 /* : Int */;
+val* var41 /* : FlatString */;
+static val* varonce42;
+val* var43 /* : String */;
+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", "src/abstract_compiler.nit", 1211);
+show_backtrace(1);
+}
+var1 = var3;
+RET_LABEL2:(void)0;
+}
+}
+{
+var4 = abstract_collection__MapRead__has_key(var1, var_variable);
 }
-if (varonce1190) {
-var1191 = varonce1190;
-} else {
-var1192 = "exit";
-var1193 = 4;
-var1194 = string__NativeString__to_s_with_length(var1192, var1193);
-var1191 = var1194;
-varonce1190 = var1191;
+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", "src/abstract_compiler.nit", 1211);
+show_backtrace(1);
 }
-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;
-} else {
-var1198 = "exit(";
-var1199 = 5;
-var1200 = string__NativeString__to_s_with_length(var1198, var1199);
-var1197 = var1200;
-varonce1196 = var1197;
+var5 = var7;
+RET_LABEL6:(void)0;
 }
-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;
 }
-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);
+{
+var8 = hash_collection__HashMap___91d_93d(var5, var_variable);
 }
-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>*/;
+var = var8;
 goto RET_LABEL;
 } else {
-if (varonce1212) {
-var1213 = varonce1212;
+if (varonce) {
+var9 = varonce;
 } else {
-var1214 = "sys";
-var1215 = 3;
-var1216 = string__NativeString__to_s_with_length(var1214, var1215);
-var1213 = var1216;
-varonce1212 = var1213;
+var10 = "var_";
+var11 = 4;
+var12 = string__NativeString__to_s_with_length(var10, var11);
+var9 = var12;
+varonce = var9;
 }
-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;
+{
+{ /* 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", "src/scope.nit", 36);
+show_backtrace(1);
 }
-if (var_ret == NULL) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "src/abstract_compiler.nit", 1548);
-exit(1);
+var13 = var15;
+RET_LABEL14:(void)0;
 }
-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;
-} else {
-var1249 = "calloc_array";
-var1250 = 12;
-var1251 = string__NativeString__to_s_with_length(var1249, var1250);
-var1248 = var1251;
-varonce1247 = var1248;
 }
-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);
+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]>*/;
+}
 }
-((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;
+{
+var19 = ((val* (*)(val*))(var16->class->vft[COLOR_string__Object__to_s]))(var16) /* to_s on <var16:Array[Object]>*/;
+}
+{
+var20 = abstract_compiler__AbstractCompilerVisitor__get_name(self, var19);
+}
+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 (unlikely(var21 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Cast failed");
+PRINT_ERROR(" (%s:%d)\n", "src/abstract_compiler.nit", 1220);
+show_backtrace(1);
+}
+var_mtype = var21;
+{
+var24 = abstract_compiler__AbstractCompilerVisitor__anchor(self, var_mtype);
+}
+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>*/
+}
+var_res = var25;
+{
+var26 = ((val* (*)(val*))(var_mtype->class->vft[COLOR_abstract_compiler__MType__ctype]))(var_mtype) /* ctype on <var_mtype:MType>*/;
+}
+if (varonce27) {
+var28 = varonce27;
 } 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;
+var29 = " ";
+var30 = 1;
+var31 = string__NativeString__to_s_with_length(var29, var30);
+var28 = var31;
+varonce27 = var28;
+}
+if (varonce32) {
+var33 = varonce32;
 } 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;
+var34 = " /* var ";
+var35 = 8;
+var36 = string__NativeString__to_s_with_length(var34, var35);
+var33 = var36;
+varonce32 = var33;
+}
+if (varonce37) {
+var38 = varonce37;
 } 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;
+var39 = ": ";
+var40 = 2;
+var41 = string__NativeString__to_s_with_length(var39, var40);
+var38 = var41;
+varonce37 = var38;
+}
+if (varonce42) {
+var43 = varonce42;
 } 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>*/;
+var44 = " */;";
+var45 = 4;
+var46 = string__NativeString__to_s_with_length(var44, var45);
+var43 = var46;
+varonce42 = var43;
+}
+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]>*/;
+}
+}
+{
+var50 = ((val* (*)(val*))(var47->class->vft[COLOR_string__Object__to_s]))(var47) /* to_s on <var47:Array[Object]>*/;
+}
+{
+abstract_compiler__AbstractCompilerVisitor__add_decl(self, var50); /* Direct call abstract_compiler#AbstractCompilerVisitor#add_decl on <self:AbstractCompilerVisitor>*/
+}
+{
+{ /* 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", "src/abstract_compiler.nit", 1211);
+show_backtrace(1);
+}
+var51 = var53;
+RET_LABEL52:(void)0;
+}
+}
+{
+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;
-} 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;
 }
-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;
+RET_LABEL:;
+return var;
+}
+/* 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;
+}
+/* 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);
+}
+var_mtype = var1;
+if (varonce) {
+var2 = varonce;
 } else {
-var1330 = "nit_gcollect();";
-var1331 = 15;
-var1332 = string__NativeString__to_s_with_length(var1330, var1331);
-var1329 = var1332;
-varonce1328 = var1329;
+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]))(var_v, var1329) /* add on <var_v:AbstractCompilerVisitor>*/;
-goto RET_LABEL;
+{
+var6 = abstract_compiler__AbstractCompilerVisitor__get_name(self, var2);
+}
+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>*/
+}
+var_res = var7;
+{
+var8 = ((val* (*)(val*))(var_mtype->class->vft[COLOR_abstract_compiler__MType__ctype]))(var_mtype) /* ctype on <var_mtype:MType>*/;
+}
+if (varonce9) {
+var10 = varonce9;
 } else {
-if (varonce1333) {
-var1334 = varonce1333;
+var11 = " ";
+var12 = 1;
+var13 = string__NativeString__to_s_with_length(var11, var12);
+var10 = var13;
+varonce9 = var10;
+}
+if (varonce14) {
+var15 = varonce14;
 } else {
-var1335 = "native_argc";
-var1336 = 11;
-var1337 = string__NativeString__to_s_with_length(var1335, var1336);
-var1334 = var1337;
-varonce1333 = var1334;
+var16 = " /* : ";
+var17 = 6;
+var18 = string__NativeString__to_s_with_length(var16, var17);
+var15 = var18;
+varonce14 = var15;
 }
-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;
+if (varonce19) {
+var20 = varonce19;
 } else {
-var1341 = "glob_argc";
-var1342 = 9;
-var1343 = string__NativeString__to_s_with_length(var1341, var1342);
-var1340 = var1343;
-varonce1339 = var1340;
+var21 = " */;";
+var22 = 4;
+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]>*/;
 }
-if (var_ret == NULL) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "src/abstract_compiler.nit", 1574);
-exit(1);
+{
+abstract_compiler__AbstractCompilerVisitor__add_decl(self, var27); /* Direct call abstract_compiler#AbstractCompilerVisitor#add_decl on <self:AbstractCompilerVisitor>*/
 }
-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>*/;
+var = var_res;
 goto RET_LABEL;
+RET_LABEL:;
+return var;
+}
+/* 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#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* 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 */;
+static val* varonce13;
+val* var14 /* : String */;
+char* var15 /* : NativeString */;
+long var16 /* : Int */;
+val* var17 /* : FlatString */;
+val* var18 /* : Array[Object] */;
+long var19 /* : Int */;
+val* var20 /* : NativeArray[Object] */;
+val* var21 /* : String */;
+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) {
+var4 = varonce;
 } 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;
+var5 = " ";
+var6 = 1;
+var7 = string__NativeString__to_s_with_length(var5, var6);
+var4 = var7;
+varonce = var4;
+}
+if (varonce8) {
+var9 = varonce8;
 } else {
+var10 = " /* : ";
+var11 = 6;
+var12 = string__NativeString__to_s_with_length(var10, var11);
+var9 = var12;
+varonce8 = var9;
 }
+if (varonce13) {
+var14 = varonce13;
+} else {
+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 = 6;
+var20 = NEW_array__NativeArray(var19, &type_array__NativeArraykernel__Object);
+((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]>*/;
 }
 }
+{
+var21 = ((val* (*)(val*))(var18->class->vft[COLOR_string__Object__to_s]))(var18) /* to_s on <var18:Array[Object]>*/;
 }
+{
+abstract_compiler__AbstractCompilerVisitor__add_decl(self, var21); /* Direct call abstract_compiler#AbstractCompilerVisitor#add_decl on <self:AbstractCompilerVisitor>*/
 }
+var = var_res;
+goto RET_LABEL;
+RET_LABEL:;
+return var;
 }
+/* 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#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* 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", "src/abstract_compiler.nit", 1484);
+show_backtrace(1);
 }
+var = var2;
+RET_LABEL1:(void)0;
 }
 }
-if (varonce1368) {
-var1369 = varonce1368;
-} else {
-var1370 = "printf(\"NOT YET IMPLEMENTED ";
-var1371 = 28;
-var1372 = string__NativeString__to_s_with_length(var1370, var1371);
-var1369 = var1372;
-varonce1368 = var1369;
+{
+var3 = separate_compiler__SeparateCompilerVisitor__autobox(self, var_right, var);
 }
-var1373 = ((val* (*)(val*))(self->class->vft[COLOR_string__Object__class_name]))(self) /* class_name on <self:AInternMethPropdef>*/;
-if (varonce1374) {
-var1375 = varonce1374;
+var_right = var3;
+if (varonce) {
+var4 = varonce;
 } else {
-var1376 = ":";
-var1377 = 1;
-var1378 = string__NativeString__to_s_with_length(var1376, var1377);
-var1375 = var1378;
-varonce1374 = var1375;
+var5 = " = ";
+var6 = 3;
+var7 = string__NativeString__to_s_with_length(var5, var6);
+var4 = var7;
+varonce = var4;
 }
-if (varonce1379) {
-var1380 = varonce1379;
+if (varonce8) {
+var9 = varonce8;
 } else {
-var1381 = " at ";
-var1382 = 4;
-var1383 = string__NativeString__to_s_with_length(var1381, var1382);
-var1380 = var1383;
-varonce1379 = var1380;
+var10 = ";";
+var11 = 1;
+var12 = string__NativeString__to_s_with_length(var10, var11);
+var9 = var12;
+varonce8 = var9;
 }
-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;
+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]>*/;
 }
-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);
 }
-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;
+{
+var16 = ((val* (*)(val*))(var13->class->vft[COLOR_string__Object__to_s]))(var13) /* to_s on <var13:Array[Object]>*/;
 }
-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);
+{
+abstract_compiler__AbstractCompilerVisitor__add(self, var16); /* Direct call abstract_compiler#AbstractCompilerVisitor#add on <self:AbstractCompilerVisitor>*/
 }
-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>*/;
 RET_LABEL:;
 }
-/* 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#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#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 */;
-short int var2 /* : Bool */;
+/* 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* var3 /* : String */;
-char* var4 /* : NativeString */;
-long var5 /* : Int */;
-val* var6 /* : String */;
-static val* varonce7;
-val* var8 /* : String */;
-char* var9 /* : NativeString */;
-long var10 /* : Int */;
+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 */;
-val* var12 /* : Location */;
-val* var13 /* : String */;
-static val* varonce14;
-val* var15 /* : String */;
-char* var16 /* : NativeString */;
-long var17 /* : Int */;
-val* var18 /* : String */;
-val* var19 /* : Array[Object] */;
-long var20 /* : Int */;
-val* var21 /* : NativeArray[Object] */;
-val* var22 /* : String */;
-static val* varonce23;
+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 */;
-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 */
-} else {
-var2 = 0; /* arg is null but recv is not */
-}
-if (var2){
+var_value = p0;
 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 (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;
-}
-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>*/;
-goto RET_LABEL;
+var1 = varonce;
 } else {
+var2 = "Int";
+var3 = 3;
+var4 = string__NativeString__to_s_with_length(var2, var3);
+var1 = var4;
+varonce = var1;
 }
-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;
-}
-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 */
+{
+var5 = abstract_compiler__AbstractCompilerVisitor__get_class(self, var1);
 }
-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>*/;
+{
+{ /* 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", "src/model/model.nit", 417);
+show_backtrace(1);
 }
-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 {
+var6 = var8;
+RET_LABEL7:(void)0;
 }
-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);
-} 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 */
-} else {
-var48 = 1; /* arg is null and recv is not */
+{
+var9 = abstract_compiler__AbstractCompilerVisitor__new_var(self, var6);
 }
-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;
+var_res = var9;
+if (varonce10) {
+var11 = varonce10;
 } else {
+var12 = " = ";
+var13 = 3;
+var14 = string__NativeString__to_s_with_length(var12, var13);
+var11 = var14;
+varonce10 = 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>*/;
-var52 = NULL;
-if (var_res == NULL) {
-var53 = 1; /* is null */
+if (varonce15) {
+var16 = varonce15;
 } else {
-var53 = 0; /* arg is null but recv is not */
+var17 = ";";
+var18 = 1;
+var19 = string__NativeString__to_s_with_length(var17, var18);
+var16 = var19;
+varonce15 = var16;
 }
-if (var53){
-if (varonce54) {
-var55 = varonce54;
-} else {
-var56 = "(";
-var57 = 1;
-var58 = string__NativeString__to_s_with_length(var56, var57);
-var55 = var58;
-varonce54 = var55;
+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]>*/;
 }
-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*))(var20->class->vft[COLOR_string__Object__to_s]))(var20) /* to_s on <var20:Array[Object]>*/;
 }
-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>*/;
+{
+abstract_compiler__AbstractCompilerVisitor__add(self, var24); /* Direct call abstract_compiler#AbstractCompilerVisitor#add on <self:AbstractCompilerVisitor>*/
 }
+var = var_res;
+goto RET_LABEL;
 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#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#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#string_instance for (self: AbstractCompilerVisitor, String): RuntimeVariable */
+val* abstract_compiler__AbstractCompilerVisitor__string_instance(val* self, val* p0) {
+val* var /* : RuntimeVariable */;
+val* var_string /* var string: String */;
 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;
-val* var15 /* : String */;
-char* var16 /* : NativeString */;
-long var17 /* : Int */;
-val* var18 /* : String */;
-val* var19 /* : Array[Object] */;
-long var20 /* : Int */;
-val* var21 /* : NativeArray[Object] */;
+val* var1 /* : String */;
+char* var2 /* : NativeString */;
+long var3 /* : Int */;
+val* var4 /* : FlatString */;
+val* var5 /* : MClass */;
+val* var6 /* : MClassType */;
+val* var8 /* : MClassType */;
+val* var_mtype /* var mtype: MClassType */;
+static val* varonce9;
+val* var10 /* : String */;
+char* var11 /* : NativeString */;
+long var12 /* : Int */;
+val* var13 /* : FlatString */;
+val* var14 /* : String */;
+val* var_name /* var name: String */;
+static val* varonce15;
+val* var16 /* : String */;
+char* var17 /* : NativeString */;
+long var18 /* : Int */;
+val* var19 /* : FlatString */;
+val* var20 /* : String */;
+static val* varonce21;
 val* var22 /* : String */;
-static val* varonce23;
-val* var24 /* : String */;
-char* var25 /* : NativeString */;
-long var26 /* : Int */;
+char* var23 /* : NativeString */;
+long var24 /* : Int */;
+val* var25 /* : FlatString */;
+static val* varonce26;
 val* var27 /* : String */;
-val* var28 /* : String */;
+char* var28 /* : NativeString */;
 long var29 /* : Int */;
-val* var30 /* : String */;
-long var31 /* : Int */;
+val* var30 /* : FlatString */;
+val* var31 /* : Array[Object] */;
 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 /* : nullable Object */;
-val* var45 /* : MType */;
-val* var_ret /* var ret: MType */;
-val* var46 /* : RuntimeVariable */;
+val* var33 /* : NativeArray[Object] */;
+val* var34 /* : String */;
+val* var35 /* : RuntimeVariable */;
 val* var_res /* var res: RuntimeVariable */;
-val* var47 /* : nullable Object */;
-static val* varonce48;
+static val* varonce36;
+val* var37 /* : String */;
+char* var38 /* : NativeString */;
+long var39 /* : Int */;
+val* var40 /* : FlatString */;
+static val* varonce41;
+val* var42 /* : String */;
+char* var43 /* : NativeString */;
+long var44 /* : Int */;
+val* var45 /* : FlatString */;
+val* var46 /* : Array[Object] */;
+long var47 /* : Int */;
+val* var48 /* : NativeArray[Object] */;
 val* var49 /* : String */;
-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 */;
+static val* varonce50;
+val* var51 /* : String */;
+char* var52 /* : NativeString */;
+long var53 /* : Int */;
+val* var54 /* : FlatString */;
+static val* varonce55;
+val* var56 /* : String */;
+char* var57 /* : NativeString */;
+long var58 /* : Int */;
+val* var59 /* : FlatString */;
+val* var60 /* : Array[Object] */;
 long var61 /* : Int */;
-val* var62 /* : String */;
+val* var62 /* : NativeArray[Object] */;
 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 */
-}
-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 (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: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>*/;
-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;
-}
-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;
-}
-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;
+val* var68 /* : FlatString */;
+static val* varonce69;
+val* var70 /* : String */;
+char* var71 /* : NativeString */;
+long var72 /* : Int */;
+val* var73 /* : FlatString */;
+val* var74 /* : MClass */;
+val* var75 /* : MClassType */;
+val* var77 /* : MClassType */;
+val* var_native_mtype /* var native_mtype: MClassType */;
+val* var78 /* : RuntimeVariable */;
+val* var_nat /* var nat: RuntimeVariable */;
+static val* varonce79;
+val* var80 /* : String */;
+char* var81 /* : NativeString */;
+long var82 /* : Int */;
+val* var83 /* : FlatString */;
+val* var84 /* : String */;
+static val* varonce85;
+val* var86 /* : String */;
+char* var87 /* : NativeString */;
+long var88 /* : Int */;
+val* var89 /* : FlatString */;
+val* var90 /* : Array[Object] */;
+long var91 /* : Int */;
+val* var92 /* : NativeArray[Object] */;
+val* var93 /* : String */;
+long var94 /* : Int */;
+long var96 /* : Int */;
+val* var97 /* : RuntimeVariable */;
+val* var_length /* var length: RuntimeVariable */;
+static val* varonce98;
+val* var99 /* : String */;
+char* var100 /* : NativeString */;
+long var101 /* : Int */;
+val* var102 /* : FlatString */;
+static val* varonce103;
+val* var104 /* : String */;
+char* var105 /* : NativeString */;
+long var106 /* : Int */;
+val* var107 /* : FlatString */;
+val* var108 /* : MMethod */;
+val* var109 /* : Array[RuntimeVariable] */;
+long var110 /* : Int */;
+val* var_ /* var : Array[RuntimeVariable] */;
+val* var111 /* : nullable RuntimeVariable */;
+static val* varonce112;
+val* var113 /* : String */;
+char* var114 /* : NativeString */;
+long var115 /* : Int */;
+val* var116 /* : FlatString */;
+val* var117 /* : Array[Object] */;
+long var118 /* : Int */;
+val* var119 /* : NativeArray[Object] */;
+val* var120 /* : String */;
+static val* varonce121;
+val* var122 /* : String */;
+char* var123 /* : NativeString */;
+long var124 /* : Int */;
+val* var125 /* : FlatString */;
+static val* varonce126;
+val* var127 /* : String */;
+char* var128 /* : NativeString */;
+long var129 /* : Int */;
+val* var130 /* : FlatString */;
+val* var131 /* : Array[Object] */;
+long var132 /* : Int */;
+val* var133 /* : NativeArray[Object] */;
+val* var134 /* : String */;
+static val* varonce135;
+val* var136 /* : String */;
+char* var137 /* : NativeString */;
+long var138 /* : Int */;
+val* var139 /* : FlatString */;
+var_string = p0;
+if (varonce) {
+var1 = varonce;
 } 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:;
-}
-/* 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:;
+var2 = "String";
+var3 = 6;
+var4 = string__NativeString__to_s_with_length(var2, var3);
+var1 = var4;
+varonce = var1;
 }
-/* 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;
+{
+var5 = abstract_compiler__AbstractCompilerVisitor__get_class(self, var1);
 }
-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)>*/;
+{
+{ /* 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", "src/model/model.nit", 417);
+show_backtrace(1);
 }
-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>*/;
+var6 = var8;
+RET_LABEL7:(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);
+var_mtype = var6;
+if (varonce9) {
+var10 = varonce9;
 } else {
-var12 = ((val* (*)(val*))(var11->class->vft[COLOR_model__MPropDef__mproperty]))(var11) /* mproperty on <var11:nullable MPropDef(nullable MAttributeDef)>*/;
+var11 = "varonce";
+var12 = 7;
+var13 = string__NativeString__to_s_with_length(var11, var12);
+var10 = var13;
+varonce9 = var10;
 }
-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>*/;
+{
+var14 = abstract_compiler__AbstractCompilerVisitor__get_name(self, var10);
 }
-RET_LABEL:;
-}
-/* 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:;
-}
-/* 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 */
+var_name = var14;
+if (varonce15) {
+var16 = varonce15;
 } else {
-var2 = 1; /* arg is null and recv is not */
+var17 = "static ";
+var18 = 7;
+var19 = string__NativeString__to_s_with_length(var17, var18);
+var16 = var19;
+varonce15 = var16;
 }
-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);
+{
+var20 = abstract_compiler__MClassType__ctype(var_mtype);
 }
-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 (varonce21) {
+var22 = varonce21;
 } else {
-var8 = var7->type->type_table[cltype] == idtype;
-}
-if (!var8) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "src/abstract_compiler.nit", 1661);
-exit(1);
+var23 = " ";
+var24 = 1;
+var25 = string__NativeString__to_s_with_length(var23, var24);
+var22 = var25;
+varonce21 = var22;
 }
-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);
+if (varonce26) {
+var27 = varonce26;
 } else {
-var12 = ((val* (*)(val*))(var11->class->vft[COLOR_model__MAttributeDef__static_mtype]))(var11) /* static_mtype on <var11:nullable MPropDef(nullable MAttributeDef)>*/;
+var28 = ";";
+var29 = 1;
+var30 = string__NativeString__to_s_with_length(var28, var29);
+var27 = var30;
+varonce26 = var27;
 }
-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)>*/;
+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*) var16;
+((struct instance_array__NativeArray*)var33)->values[1] = (val*) var20;
+((struct instance_array__NativeArray*)var33)->values[2] = (val*) var22;
+((struct instance_array__NativeArray*)var33)->values[3] = (val*) var_name;
+((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]>*/;
 }
-((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>*/;
-} else {
 }
-RET_LABEL:;
+{
+var34 = ((val* (*)(val*))(var31->class->vft[COLOR_string__Object__to_s]))(var31) /* to_s on <var31: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:;
+{
+abstract_compiler__AbstractCompilerVisitor__add_decl(self, var34); /* Direct call abstract_compiler#AbstractCompilerVisitor#add_decl on <self:AbstractCompilerVisitor>*/
 }
-/* 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 */
+{
+var35 = abstract_compiler__AbstractCompilerVisitor__new_var(self, var_mtype);
 }
-if (var2){
-goto RET_LABEL;
+var_res = var35;
+if (varonce36) {
+var37 = varonce36;
 } else {
+var38 = "if (";
+var39 = 4;
+var40 = string__NativeString__to_s_with_length(var38, var39);
+var37 = var40;
+varonce36 = var37;
 }
-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);
-}
-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 (varonce41) {
+var42 = varonce41;
 } else {
-var8 = var7->type->type_table[cltype] == idtype;
-}
-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:;
-}
-/* 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:;
+var43 = ") {";
+var44 = 3;
+var45 = string__NativeString__to_s_with_length(var43, var44);
+var42 = var45;
+varonce41 = var42;
 }
-/* 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 */
+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*) var37;
+((struct instance_array__NativeArray*)var48)->values[1] = (val*) var_name;
+((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]>*/;
 }
-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;
 }
-if (!var7) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Assert failed", "src/abstract_compiler.nit", 1693);
-exit(1);
+{
+var49 = ((val* (*)(val*))(var46->class->vft[COLOR_string__Object__to_s]))(var46) /* to_s on <var46:Array[Object]>*/;
 }
-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]>*/;
+{
+abstract_compiler__AbstractCompilerVisitor__add(self, var49); /* Direct call abstract_compiler#AbstractCompilerVisitor#add on <self:AbstractCompilerVisitor>*/
 }
-BREAK_label: (void)0;
-goto RET_LABEL;
+if (varonce50) {
+var51 = varonce50;
 } else {
+var52 = " = ";
+var53 = 3;
+var54 = string__NativeString__to_s_with_length(var52, var53);
+var51 = var54;
+varonce50 = var51;
 }
-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;
+if (varonce55) {
+var56 = varonce55;
 } else {
-var21 = var_npropdef->type->type_table[cltype] == idtype;
+var57 = ";";
+var58 = 1;
+var59 = string__NativeString__to_s_with_length(var57, var58);
+var56 = var59;
+varonce55 = var56;
 }
-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 */
-} else {
-var24 = 0; /* arg is null but recv is not */
+var60 = NEW_array__Array(&type_array__Arraykernel__Object);
+{ /* var60 = array_instance Array[Object] */
+var61 = 4;
+var62 = NEW_array__NativeArray(var61, &type_array__NativeArraykernel__Object);
+((struct instance_array__NativeArray*)var62)->values[0] = (val*) var_res;
+((struct instance_array__NativeArray*)var62)->values[1] = (val*) var51;
+((struct instance_array__NativeArray*)var62)->values[2] = (val*) var_name;
+((struct instance_array__NativeArray*)var62)->values[3] = (val*) var56;
+{
+((void (*)(val*, val*, long))(var60->class->vft[COLOR_array__Array__with_native]))(var60, var62, var61) /* with_native on <var60:Array[Object]>*/;
 }
-var20 = var24;
-} else {
-var20 = var_;
 }
-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);
-} else {
-var26 = ((val* (*)(val*))(var25->class->vft[COLOR_model__MPropDef__mproperty]))(var25) /* mproperty on <var25:nullable MPropDef(nullable MAttributeDef)>*/;
+{
+var63 = ((val* (*)(val*))(var60->class->vft[COLOR_string__Object__to_s]))(var60) /* to_s on <var60:Array[Object]>*/;
 }
-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;
+{
+abstract_compiler__AbstractCompilerVisitor__add(self, var63); /* Direct call abstract_compiler#AbstractCompilerVisitor#add on <self:AbstractCompilerVisitor>*/
 }
-var_i = var29;
+if (varonce64) {
+var65 = varonce64;
 } else {
+var66 = "} else {";
+var67 = 8;
+var68 = string__NativeString__to_s_with_length(var66, var67);
+var65 = var68;
+varonce64 = var65;
 }
-CONTINUE_label32: (void)0;
-((void (*)(val*))(var17->class->vft[COLOR_abstract_collection__Iterator__next]))(var17) /* next on <var17:Iterator[nullable Object]>*/;
+{
+abstract_compiler__AbstractCompilerVisitor__add(self, var65); /* Direct call abstract_compiler#AbstractCompilerVisitor#add on <self:AbstractCompilerVisitor>*/
 }
-BREAK_label32: (void)0;
+if (varonce69) {
+var70 = varonce69;
 } else {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Aborted", "src/abstract_compiler.nit", 1709);
-exit(1);
+var71 = "NativeString";
+var72 = 12;
+var73 = string__NativeString__to_s_with_length(var71, var72);
+var70 = var73;
+varonce69 = var70;
 }
-RET_LABEL:;
-}
-/* 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);
-RET_LABEL:;
-}
-/* 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] */;
-static val* varonce;
-val* var /* : String */;
-char* var1 /* : NativeString */;
-long var2 /* : Int */;
-val* var3 /* : String */;
-var_v = p0;
-var_mpropdef = p1;
-var_arguments = p2;
-if (varonce) {
-var = varonce;
-} else {
-var1 = "Deferred method called";
-var2 = 22;
-var3 = string__NativeString__to_s_with_length(var1, var2);
-var = var3;
-varonce = var;
+{
+var74 = abstract_compiler__AbstractCompilerVisitor__get_class(self, var70);
 }
-((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add_abort]))(var_v, var) /* add_abort on <var_v:AbstractCompilerVisitor>*/;
-RET_LABEL:;
+{
+{ /* Inline model#MClass#mclass_type (var74) on <var74:MClass> */
+var77 = var74->attrs[COLOR_model__MClass___mclass_type].val; /* _mclass_type on <var74:MClass> */
+if (unlikely(var77 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _mclass_type");
+PRINT_ERROR(" (%s:%d)\n", "src/model/model.nit", 417);
+show_backtrace(1);
 }
-/* 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:;
+var75 = var77;
+RET_LABEL76:(void)0;
 }
-/* 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;
-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);
-var = var1;
-RET_LABEL:;
-return var;
+var_native_mtype = var75;
+{
+var78 = abstract_compiler__AbstractCompilerVisitor__new_var(self, var_native_mtype);
 }
-/* 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 */;
-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 */;
-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 */;
-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;
-if (varonce) {
-var1 = varonce;
+var_nat = var78;
+if (varonce79) {
+var80 = varonce79;
 } else {
-var2 = "printf(\"NOT YET IMPLEMENTED ";
-var3 = 28;
-var4 = string__NativeString__to_s_with_length(var2, var3);
-var1 = var4;
-varonce = var1;
+var81 = " = \"";
+var82 = 4;
+var83 = string__NativeString__to_s_with_length(var81, var82);
+var80 = var83;
+varonce79 = var80;
 }
-var5 = ((val* (*)(val*))(self->class->vft[COLOR_string__Object__class_name]))(self) /* class_name on <self:AExpr>*/;
-if (varonce6) {
-var7 = varonce6;
-} else {
-var8 = ":";
-var9 = 1;
-var10 = string__NativeString__to_s_with_length(var8, var9);
-var7 = var10;
-varonce6 = var7;
+{
+var84 = string__Text__escape_to_c(var_string);
 }
-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;
+if (varonce85) {
+var86 = varonce85;
 } else {
-var15 = "\\n\");";
-var16 = 5;
-var17 = string__NativeString__to_s_with_length(var15, var16);
-var14 = var17;
-varonce13 = var14;
+var87 = "\";";
+var88 = 2;
+var89 = string__NativeString__to_s_with_length(var87, var88);
+var86 = var89;
+varonce85 = var86;
 }
-var18 = NEW_array__Array(&type_array__Arraykernel__Object);
-{ /* var18 = array_instance Array[Object] */
-var19 = 5;
-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;
-((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);
+var90 = NEW_array__Array(&type_array__Arraykernel__Object);
+{ /* var90 = array_instance Array[Object] */
+var91 = 4;
+var92 = NEW_array__NativeArray(var91, &type_array__NativeArraykernel__Object);
+((struct instance_array__NativeArray*)var92)->values[0] = (val*) var_nat;
+((struct instance_array__NativeArray*)var92)->values[1] = (val*) var80;
+((struct instance_array__NativeArray*)var92)->values[2] = (val*) var84;
+((struct instance_array__NativeArray*)var92)->values[3] = (val*) var86;
+{
+((void (*)(val*, val*, long))(var90->class->vft[COLOR_array__Array__with_native]))(var90, var92, var91) /* with_native on <var90: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>*/;
-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;
+}
+{
+var93 = ((val* (*)(val*))(var90->class->vft[COLOR_string__Object__to_s]))(var90) /* to_s on <var90:Array[Object]>*/;
+}
+{
+abstract_compiler__AbstractCompilerVisitor__add(self, var93); /* Direct call abstract_compiler#AbstractCompilerVisitor#add on <self:AbstractCompilerVisitor>*/
+}
+{
+{ /* Inline string#FlatText#length (var_string) on <var_string:String> */
+var96 = var_string->attrs[COLOR_string__FlatText___length].l; /* _length on <var_string:String> */
+var94 = var96;
+RET_LABEL95:(void)0;
+}
+}
+{
+var97 = abstract_compiler__AbstractCompilerVisitor__int_instance(self, var94);
+}
+var_length = var97;
+if (varonce98) {
+var99 = varonce98;
 } else {
-var29 = "/* ";
-var30 = 3;
-var31 = string__NativeString__to_s_with_length(var29, var30);
-var28 = var31;
-varonce27 = var28;
+var100 = " = ";
+var101 = 3;
+var102 = string__NativeString__to_s_with_length(var100, var101);
+var99 = var102;
+varonce98 = var99;
 }
-if (varonce32) {
-var33 = varonce32;
+if (varonce103) {
+var104 = varonce103;
 } else {
-var34 = " = NOT YET ";
-var35 = 11;
-var36 = string__NativeString__to_s_with_length(var34, var35);
-var33 = var36;
-varonce32 = var33;
+var105 = "to_s_with_length";
+var106 = 16;
+var107 = string__NativeString__to_s_with_length(var105, var106);
+var104 = var107;
+varonce103 = var104;
 }
-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;
+{
+var108 = abstract_compiler__AbstractCompilerVisitor__get_property(self, var104, var_native_mtype);
 }
-RET_LABEL:;
-return var;
+var109 = NEW_array__Array(&type_array__Arrayabstract_compiler__RuntimeVariable);
+var110 = 2;
+{
+array__Array__with_capacity(var109, var110); /* Direct call array#Array#with_capacity on <var109:Array[RuntimeVariable]>*/
 }
-/* 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);
-var = var1;
-RET_LABEL:;
-return var;
+var_ = var109;
+{
+array__AbstractArray__push(var_, var_nat); /* Direct call array#AbstractArray#push on <var_:Array[RuntimeVariable]>*/
 }
-/* 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 */;
-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 */
+{
+array__AbstractArray__push(var_, var_length); /* Direct call array#AbstractArray#push on <var_:Array[RuntimeVariable]>*/
 }
-if (var2){
-if (varonce) {
-var3 = varonce;
+{
+var111 = separate_compiler__SeparateCompilerVisitor__send(self, var108, var_);
+}
+if (unlikely(var111 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Cast failed");
+PRINT_ERROR(" (%s:%d)\n", "src/abstract_compiler.nit", 1283);
+show_backtrace(1);
+}
+if (varonce112) {
+var113 = varonce112;
 } else {
-var4 = ";";
-var5 = 1;
-var6 = string__NativeString__to_s_with_length(var4, var5);
-var3 = var6;
-varonce = var3;
+var114 = ";";
+var115 = 1;
+var116 = string__NativeString__to_s_with_length(var114, var115);
+var113 = var116;
+varonce112 = var113;
 }
-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);
+var117 = NEW_array__Array(&type_array__Arraykernel__Object);
+{ /* var117 = array_instance Array[Object] */
+var118 = 4;
+var119 = NEW_array__NativeArray(var118, &type_array__NativeArraykernel__Object);
+((struct instance_array__NativeArray*)var119)->values[0] = (val*) var_res;
+((struct instance_array__NativeArray*)var119)->values[1] = (val*) var99;
+((struct instance_array__NativeArray*)var119)->values[2] = (val*) var111;
+((struct instance_array__NativeArray*)var119)->values[3] = (val*) var113;
+{
+((void (*)(val*, val*, long))(var117->class->vft[COLOR_array__Array__with_native]))(var117, var119, var118) /* with_native on <var117:Array[Object]>*/;
+}
+}
+{
+var120 = ((val* (*)(val*))(var117->class->vft[COLOR_string__Object__to_s]))(var117) /* to_s on <var117:Array[Object]>*/;
+}
+{
+abstract_compiler__AbstractCompilerVisitor__add(self, var120); /* Direct call abstract_compiler#AbstractCompilerVisitor#add on <self:AbstractCompilerVisitor>*/
 }
-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>*/;
+if (varonce121) {
+var122 = varonce121;
 } else {
+var123 = " = ";
+var124 = 3;
+var125 = string__NativeString__to_s_with_length(var123, var124);
+var122 = var125;
+varonce121 = var122;
 }
-RET_LABEL:;
+if (varonce126) {
+var127 = varonce126;
+} else {
+var128 = ";";
+var129 = 1;
+var130 = string__NativeString__to_s_with_length(var128, var129);
+var127 = var130;
+varonce126 = var127;
 }
-/* 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:;
+var131 = NEW_array__Array(&type_array__Arraykernel__Object);
+{ /* var131 = array_instance Array[Object] */
+var132 = 4;
+var133 = NEW_array__NativeArray(var132, &type_array__NativeArraykernel__Object);
+((struct instance_array__NativeArray*)var133)->values[0] = (val*) var_name;
+((struct instance_array__NativeArray*)var133)->values[1] = (val*) var122;
+((struct instance_array__NativeArray*)var133)->values[2] = (val*) var_res;
+((struct instance_array__NativeArray*)var133)->values[3] = (val*) var127;
+{
+((void (*)(val*, val*, long))(var131->class->vft[COLOR_array__Array__with_native]))(var131, var133, var132) /* with_native on <var131:Array[Object]>*/;
 }
-/* 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:;
+{
+var134 = ((val* (*)(val*))(var131->class->vft[COLOR_string__Object__to_s]))(var131) /* to_s on <var131:Array[Object]>*/;
 }
-/* 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:;
+{
+abstract_compiler__AbstractCompilerVisitor__add(self, var134); /* Direct call abstract_compiler#AbstractCompilerVisitor#add on <self:AbstractCompilerVisitor>*/
 }
-/* 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 (varonce135) {
+var136 = varonce135;
 } else {
+var137 = "}";
+var138 = 1;
+var139 = string__NativeString__to_s_with_length(var137, var138);
+var136 = var139;
+varonce135 = var136;
 }
-((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]>*/;
+{
+abstract_compiler__AbstractCompilerVisitor__add(self, var136); /* Direct call abstract_compiler#AbstractCompilerVisitor#add on <self:AbstractCompilerVisitor>*/
 }
-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;
+var = var_res;
 goto RET_LABEL;
 RET_LABEL:;
 return var;
 }
-/* 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);
+/* method abstract_compiler#AbstractCompilerVisitor#string_instance for (self: Object, String): RuntimeVariable */
+val* VIRTUAL_abstract_compiler__AbstractCompilerVisitor__string_instance(val* self, val* p0) {
+val* var /* : RuntimeVariable */;
+val* var1 /* : RuntimeVariable */;
+var1 = abstract_compiler__AbstractCompilerVisitor__string_instance(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);
+/* method abstract_compiler#AbstractCompilerVisitor#add for (self: AbstractCompilerVisitor, String) */
+void abstract_compiler__AbstractCompilerVisitor__add(val* self, val* p0) {
+val* var_s /* var s: String */;
+val* var /* : CodeWriter */;
+val* var2 /* : CodeWriter */;
+val* var3 /* : List[String] */;
+val* var5 /* : List[String] */;
+var_s = p0;
+{
+{ /* Inline abstract_compiler#AbstractCompilerVisitor#writer (self) on <self:AbstractCompilerVisitor> */
+var2 = self->attrs[COLOR_abstract_compiler__AbstractCompilerVisitor___writer].val; /* _writer on <self:AbstractCompilerVisitor> */
+if (unlikely(var2 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _writer");
+PRINT_ERROR(" (%s:%d)\n", "src/abstract_compiler.nit", 999);
+show_backtrace(1);
 }
-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 */
+var = var2;
+RET_LABEL1:(void)0;
 }
-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:;
+{
+{ /* Inline abstract_compiler#CodeWriter#lines (var) on <var:CodeWriter> */
+var5 = var->attrs[COLOR_abstract_compiler__CodeWriter___lines].val; /* _lines on <var:CodeWriter> */
+if (unlikely(var5 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _lines");
+PRINT_ERROR(" (%s:%d)\n", "src/abstract_compiler.nit", 962);
+show_backtrace(1);
 }
-/* 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);
-RET_LABEL:;
+var3 = var5;
+RET_LABEL4:(void)0;
 }
-/* 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 */;
-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);
+{
+abstract_collection__Sequence__add(var3, var_s); /* Direct call abstract_collection#Sequence#add on <var3:List[String]>*/
 }
-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;
 }
-/* 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;
+/* method abstract_compiler#AbstractCompilerVisitor#add for (self: Object, String) */
+void VIRTUAL_abstract_compiler__AbstractCompilerVisitor__add(val* self, val* p0) {
+abstract_compiler__AbstractCompilerVisitor__add(self, p0); /* Direct call abstract_compiler#AbstractCompilerVisitor#add on <self:Object(AbstractCompilerVisitor)>*/
 RET_LABEL:;
-return var;
 }
-/* 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:;
+/* method abstract_compiler#AbstractCompilerVisitor#add_decl for (self: AbstractCompilerVisitor, String) */
+void abstract_compiler__AbstractCompilerVisitor__add_decl(val* self, val* p0) {
+val* var_s /* var s: String */;
+val* var /* : CodeWriter */;
+val* var2 /* : CodeWriter */;
+val* var3 /* : List[String] */;
+val* var5 /* : List[String] */;
+var_s = p0;
+{
+{ /* Inline abstract_compiler#AbstractCompilerVisitor#writer (self) on <self:AbstractCompilerVisitor> */
+var2 = self->attrs[COLOR_abstract_compiler__AbstractCompilerVisitor___writer].val; /* _writer on <self:AbstractCompilerVisitor> */
+if (unlikely(var2 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _writer");
+PRINT_ERROR(" (%s:%d)\n", "src/abstract_compiler.nit", 999);
+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:;
+var = var2;
+RET_LABEL1:(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;
+{
+{ /* Inline abstract_compiler#CodeWriter#decl_lines (var) on <var:CodeWriter> */
+var5 = var->attrs[COLOR_abstract_compiler__CodeWriter___decl_lines].val; /* _decl_lines on <var:CodeWriter> */
+if (unlikely(var5 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _decl_lines");
+PRINT_ERROR(" (%s:%d)\n", "src/abstract_compiler.nit", 963);
+show_backtrace(1);
 }
-/* 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 */
-} else {
-var11 = 1; /* arg is null and recv is not */
+var3 = var5;
+RET_LABEL4:(void)0;
 }
-if (!var11) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Assert failed", "src/abstract_compiler.nit", 1804);
-exit(1);
 }
-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>*/;
+{
+abstract_collection__Sequence__add(var3, var_s); /* Direct call abstract_collection#Sequence#add on <var3:List[String]>*/
+}
 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);
+/* method abstract_compiler#AbstractCompilerVisitor#add_decl for (self: Object, String) */
+void VIRTUAL_abstract_compiler__AbstractCompilerVisitor__add_decl(val* self, val* p0) {
+abstract_compiler__AbstractCompilerVisitor__add_decl(self, p0); /* Direct call abstract_compiler#AbstractCompilerVisitor#add_decl on <self:Object(AbstractCompilerVisitor)>*/
 RET_LABEL:;
 }
-/* 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>*/;
+/* method abstract_compiler#AbstractCompilerVisitor#require_declaration for (self: AbstractCompilerVisitor, String) */
+void abstract_compiler__AbstractCompilerVisitor__require_declaration(val* self, val* p0) {
+val* var_key /* var key: String */;
+val* var /* : CodeWriter */;
+val* var2 /* : CodeWriter */;
+val* var3 /* : CodeFile */;
+val* var5 /* : CodeFile */;
+val* var6 /* : HashSet[String] */;
+val* var8 /* : HashSet[String] */;
+val* var_reqs /* var reqs: HashSet[String] */;
+short int var9 /* : Bool */;
+val* var10 /* : nullable ANode */;
+val* var12 /* : nullable ANode */;
+val* var_node /* var node: nullable ANode */;
+val* var13 /* : null */;
+short int var14 /* : Bool */;
+short int var15 /* : Bool */;
+val* var_other /* var other: nullable Object */;
+short int var17 /* : Bool */;
+short int var18 /* : Bool */;
+short int var19 /* : Bool */;
+val* var20 /* : AbstractCompiler */;
+val* var22 /* : AbstractCompiler */;
+val* var23 /* : HashMap[String, ANode] */;
+val* var25 /* : HashMap[String, ANode] */;
+var_key = p0;
+{
+{ /* Inline abstract_compiler#AbstractCompilerVisitor#writer (self) on <self:AbstractCompilerVisitor> */
+var2 = self->attrs[COLOR_abstract_compiler__AbstractCompilerVisitor___writer].val; /* _writer on <self:AbstractCompilerVisitor> */
+if (unlikely(var2 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _writer");
+PRINT_ERROR(" (%s:%d)\n", "src/abstract_compiler.nit", 999);
+show_backtrace(1);
+}
+var = var2;
+RET_LABEL1:(void)0;
+}
+}
+{
+{ /* Inline abstract_compiler#CodeWriter#file (var) on <var:CodeWriter> */
+var5 = var->attrs[COLOR_abstract_compiler__CodeWriter___file].val; /* _file on <var:CodeWriter> */
+if (unlikely(var5 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _file");
+PRINT_ERROR(" (%s:%d)\n", "src/abstract_compiler.nit", 961);
+show_backtrace(1);
+}
+var3 = var5;
+RET_LABEL4:(void)0;
+}
+}
+{
+{ /* Inline abstract_compiler#CodeFile#required_declarations (var3) on <var3:CodeFile> */
+var8 = var3->attrs[COLOR_abstract_compiler__CodeFile___required_declarations].val; /* _required_declarations on <var3:CodeFile> */
+if (unlikely(var8 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _required_declarations");
+PRINT_ERROR(" (%s:%d)\n", "src/abstract_compiler.nit", 956);
+show_backtrace(1);
+}
+var6 = var8;
+RET_LABEL7:(void)0;
+}
+}
+var_reqs = var6;
+{
+var9 = hash_collection__HashSet__has(var_reqs, var_key);
 }
-var3 = ((val* (*)(val*))(var2->class->vft[COLOR_abstract_collection__Collection__first]))(var2) /* first on <var2:Array[RuntimeVariable]>*/;
-var = var3;
+if (var9){
 goto RET_LABEL;
-RET_LABEL:;
-return var;
+} else {
 }
-/* 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);
-var = var1;
-RET_LABEL:;
-return var;
+{
+hash_collection__HashSet__add(var_reqs, var_key); /* Direct call hash_collection#HashSet#add on <var_reqs:HashSet[String]>*/
 }
-/* method abstract_compiler#AContinueExpr#stmt for (self: AContinueExpr, AbstractCompilerVisitor) */
-void abstract_compiler__AContinueExpr__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 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:;
+{
+{ /* Inline abstract_compiler#AbstractCompilerVisitor#current_node (self) on <self:AbstractCompilerVisitor> */
+var12 = self->attrs[COLOR_abstract_compiler__AbstractCompilerVisitor___current_node].val; /* _current_node on <self:AbstractCompilerVisitor> */
+var10 = var12;
+RET_LABEL11:(void)0;
 }
-/* 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:;
 }
-/* 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;
+var_node = var10;
+var13 = NULL;
+if (var_node == NULL) {
+var14 = 0; /* is null */
 } 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:;
+var14 = 1; /* arg is null and recv is not */
 }
-/* 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:;
+if (0) {
+{ /* Inline kernel#Object#!= (var_node,var13) on <var_node:nullable ANode> */
+var_other = var13;
+{
+var18 = ((short int (*)(val*, val*))(var_node->class->vft[COLOR_kernel__Object___61d_61d]))(var_node, var_other) /* == on <var_node:nullable ANode(ANode)>*/;
+var17 = var18;
 }
-/* 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 */
+var19 = !var17;
+var15 = var19;
+goto RET_LABEL16;
+RET_LABEL16:(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>*/;
+var14 = var15;
 }
-if (var4 == NULL) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "src/abstract_compiler.nit", 1826);
-exit(1);
+if (var14){
+{
+{ /* Inline abstract_compiler#AbstractCompilerVisitor#compiler (self) on <self:AbstractCompilerVisitor> */
+var22 = self->attrs[COLOR_abstract_compiler__AbstractCompilerVisitor___compiler].val; /* _compiler on <self:AbstractCompilerVisitor> */
+if (unlikely(var22 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _compiler");
+PRINT_ERROR(" (%s:%d)\n", "src/abstract_compiler.nit", 984);
+show_backtrace(1);
 }
-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>*/;
-} else {
+var20 = var22;
+RET_LABEL21:(void)0;
 }
-if (varonce) {
-var7 = varonce;
-} else {
-var8 = "goto ";
-var9 = 5;
-var10 = string__NativeString__to_s_with_length(var8, var9);
-var7 = var10;
-varonce = var7;
 }
-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>*/;
+{
+{ /* Inline abstract_compiler#AbstractCompiler#requirers_of_declarations (var20) on <var20:AbstractCompiler> */
+var25 = var20->attrs[COLOR_abstract_compiler__AbstractCompiler___requirers_of_declarations].val; /* _requirers_of_declarations on <var20:AbstractCompiler> */
+if (unlikely(var25 == NULL)) {
+PRINT_ERROR("Runtime error: %s", "Uninitialized attribute _requirers_of_declarations");
+PRINT_ERROR(" (%s:%d)\n", "src/abstract_compiler.nit", 486);
+show_backtrace(1);
 }
-if (var12 == NULL) {
-fprintf(stderr, "Runtime error: %s (%s:%d)\n", "Cast failed", "src/abstract_compiler.nit", 1830);
-exit(1);
+var23 = var25;
+RET_LABEL24:(void)0;
 }
-if (varonce13) {
-var14 = varonce13;
-} else {
-var15 = ";";
-var16 = 1;
-var17 = string__NativeString__to_s_with_length(var15, var16);
-var14 = var17;
-varonce13 = var14;
 }
-var18 = NEW_array__Array(&type_array__Arraykernel__Object);
-{ /* var18 = array_instance Array[Object] */
-var19 = 3;
-var20 = NEW_array__NativeArray(var19, &type_array__NativeArraykernel__Object);
-((struct instance_array__NativeArray*)var20)->values[0] = (val*) 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);
+{
+hash_collection__HashMap___91d_93d_61d(var23, var_key, var_node); /* Direct call hash_collection#HashMap#[]= on <var23:HashMap[String, ANode]>*/
+}
+} else {
 }
-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);
+/* method abstract_compiler#AbstractCompilerVisitor#require_declaration for (self: Object, String) */
+void VIRTUAL_abstract_compiler__AbstractCompilerVisitor__require_declaration(val* self, val* p0) {
+abstract_compiler__AbstractCompilerVisitor__require_declaration(self, p0); /* Direct call abstract_compiler#AbstractCompilerVisitor#require_declaration on <self:Object(AbstractCompilerVisitor)>*/
 RET_LABEL:;
 }
-/* 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;
+/* method abstract_compiler#AbstractCompilerVisitor#declare_once for (self: AbstractCompilerVisitor, String) */
+void abstract_compiler__AbstractCompilerVisitor__declare_once(val* self, val* p0) {
+val* var_s /* var s: String */;
+val* var /* : AbstractCompiler */;
+val* var2 /* : AbstractCompiler */;
+var_s = 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", "src/abstract_compiler.nit", 984);
+show_backtrace(1);
+}
+var = var2;
+RET_LABEL1:(void)0;
+}
+}
+{
+abstract_compiler__AbstractCompiler__provide_declaration(var, var_s, var_s); /* Direct call abstract_compiler#AbstractCompiler#provide_declaration on <var:AbstractCompiler>*/
+}
+{
+abstract_compiler__AbstractCompilerVisitor__require_declaration(self, var_s); /* Direct call abstract_compiler#AbstractCompilerVisitor#require_declaration on <self:AbstractCompilerVisitor>*/
 }
-((void (*)(val*, val*))(var_v->class->vft[COLOR_abstract_compiler__AbstractCompilerVisitor__add_abort]))(var_v, var) /* add_abort on <var_v:AbstractCompilerVisitor>*/;
 RET_LABEL:;
 }
-/* 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#declare_once for (self: Object, String) */
+void VIRTUAL_abstract_compiler__AbstractCompilerVisitor__declare_once(val* self, val* p0) {
+abstract_compiler__AbstractCompilerVisitor__declare_once(self, p0); /* Direct call abstract_compiler#AbstractCompilerVisitor#declare_once on <self:Object(AbstractCompilerVisitor)>*/
 RET_LABEL:;
 }