#!/usr/bin/env node import { Runtime } from "./runtime.js"; const runtime = new Runtime({ filename: "compile.phi" }); let _is_phi_compiler14 = { type: "bool", value: true }; function _dbg15(_msg27) { runtime.pushCall("dbg"); if (runtime.truthy(_is_phi_compiler14)) { (runtime.setLine(4), ((...args) => runtime.builtinPrintln(...args))(({ type: "string", value: "dbg: %" }), _msg27)); }; ; runtime.popCall(); return { type: "null" }; }; function _Emitter16(_ast28, _filename29) { runtime.pushCall("Emitter"); const r_0 = ({ type: "list", values: [] }); let _output44 = r_0; const r_1 = (runtime.setLine(11), _Syms18()); const r_2 = r_1.values[0] ?? { type: "null"}; let _enter_scope45 = r_2; const r_3 = r_1.values[1] ?? { type: "null"}; let _leave_scope46 = r_3; const r_4 = r_1.values[2] ?? { type: "null"}; let _define_sym47 = r_4; const r_5 = r_1.values[3] ?? { type: "null"}; let _get_sym48 = r_5; const r_6 = r_1.values[4] ?? { type: "null"}; let _print_syms49 = r_6; const r_7 = (runtime.setLine(13), _Counter17()); const r_8 = r_7.values[0] ?? { type: "null"}; let _let_node_reg_count50 = r_8; const r_9 = r_7.values[1] ?? { type: "null"}; let _let_node_reg_increment51 = r_9; const r_10 = (runtime.setLine(14), _Counter17()); const r_11 = r_10.values[0] ?? { type: "null"}; let _sym_id_count52 = r_11; const r_12 = r_10.values[1] ?? { type: "null"}; let _sym_id_increment53 = r_12; const r_13 = ({ type: "list", values: [({ type: "list", values: [({ type: "string", value: "format" }), ({ type: "string", value: "builtinFormat" })] }), ({ type: "list", values: [({ type: "string", value: "print" }), ({ type: "string", value: "builtinPrint" })] }), ({ type: "list", values: [({ type: "string", value: "println" }), ({ type: "string", value: "builtinPrintln" })] }), ({ type: "list", values: [({ type: "string", value: "panic" }), ({ type: "string", value: "builtinPanic" })] }), ({ type: "list", values: [({ type: "string", value: "read_text_file" }), ({ type: "string", value: "builtinReadTextFile" })] }), ({ type: "list", values: [({ type: "string", value: "write_text_file" }), ({ type: "string", value: "builtinWriteTextFile" })] }), ({ type: "list", values: [({ type: "string", value: "push" }), ({ type: "string", value: "builtinPush" })] }), ({ type: "list", values: [({ type: "string", value: "at" }), ({ type: "string", value: "builtinAt" })] }), ({ type: "list", values: [({ type: "string", value: "set" }), ({ type: "string", value: "builtinSet" })] }), ({ type: "list", values: [({ type: "string", value: "len" }), ({ type: "string", value: "builtinLen" })] }), ({ type: "list", values: [({ type: "string", value: "string_to_int" }), ({ type: "string", value: "builtinStringToInt" })] }), ({ type: "list", values: [({ type: "string", value: "char_code" }), ({ type: "string", value: "builtinCharCode" })] }), ({ type: "list", values: [({ type: "string", value: "strings_join" }), ({ type: "string", value: "builtinStringsJoin" })] }), ({ type: "list", values: [({ type: "string", value: "get_args" }), ({ type: "string", value: "builtinGetArgs" })] })] }); let _builtin_syms54 = r_13; function _generate30() { runtime.pushCall("generate"); (runtime.setLine(34), _emit39(({ type: "string", value: "#!/usr/bin/env node\n" }))); (runtime.setLine(35), _emit39(({ type: "string", value: "import { Runtime } from \"./runtime.js\";\n" }))); (runtime.setLine(36), _emit39(({ type: "string", value: "const runtime = new Runtime({ filename: \"" }))); (runtime.setLine(37), _emit39(_filename29)); (runtime.setLine(38), _emit39(({ type: "string", value: "\" });\n" }))); for (const r_14 of _builtin_syms54.values) {; const r_15 = r_14.values[0] ?? { type: "null"}; let _ident55 = r_15; const r_16 = r_14.values[1] ?? { type: "null"}; let _builtin_id56 = r_16; (runtime.setLine(41), _define_builtin40(_ident55, _builtin_id56)); }; const r_17 = (runtime.setLine(44), _define_let43(({ type: "string", value: "is_phi_compiler" }), ({ type: "int", value: 0 }))); let _is_phi_compiler_sym_id57 = r_17; (runtime.setLine(45), _emit39((runtime.setLine(45), ((...args) => runtime.builtinFormat(...args))(({ type: "string", value: "let _is_phi_compiler% = { type: \"bool\", value: true };\n" }), _is_phi_compiler_sym_id57)))); (runtime.setLine(50), _discover_syms32(_ast28)); (runtime.setLine(51), _emit_exprs31(_ast28)); runtime.popCall(); return (runtime.setLine(52), ((...args) => runtime.builtinStringsJoin(...args))(_output44)); ; runtime.popCall(); return { type: "null" }; }; function _emit_exprs31(_exprs58) { runtime.pushCall("emit_exprs"); for (const r_18 of _exprs58.values) {; let _expr59 = r_18; (runtime.setLine(57), _emit_expr33(_expr59)); (runtime.setLine(58), _emit39(({ type: "string", value: ";\n" }))); }; ; runtime.popCall(); return { type: "null" }; }; function _discover_syms32(_exprs60) { runtime.pushCall("discover_syms"); for (const r_19 of _exprs60.values) {; let _expr61 = r_19; const r_20 = _expr61; const r_21 = r_20.values[0] ?? { type: "null"}; let _ty62 = r_21; const r_22 = r_20.values[1] ?? { type: "null"}; let _line63 = r_22; if (runtime.truthy(runtime.opNe(_ty62, ({ type: "string", value: "list" })))) { runtime.popCall(); return { type: "null" }}; const r_23 = _expr61; const r_24 = r_23.values[0] ?? { type: "null"}; const r_25 = r_23.values[1] ?? { type: "null"}; const r_26 = r_23.values[2] ?? { type: "null"}; let _s64 = r_26; if (runtime.truthy(runtime.opEq((runtime.setLine(67), ((...args) => runtime.builtinLen(...args))(_s64)), ({ type: "int", value: 0 })))) { runtime.popCall(); return { type: "null" }}; const r_27 = _s64; const r_28 = r_27.values[0] ?? { type: "null"}; const r_29 = r_28.values[0] ?? { type: "null"}; const r_30 = r_28.values[1] ?? { type: "null"}; const r_31 = r_28.values[2] ?? { type: "null"}; let _id65 = r_31; if (runtime.truthy(runtime.opEq(_id65, ({ type: "string", value: "fn" })))) { const r_32 = _s64; const r_33 = r_32.values[0] ?? { type: "null"}; const r_34 = r_32.values[1] ?? { type: "null"}; const r_35 = r_34.values[0] ?? { type: "null"}; const r_36 = r_34.values[1] ?? { type: "null"}; const r_37 = r_34.values[2] ?? { type: "null"}; let _ident66 = r_37; const r_38 = r_32.values[2] ?? { type: "null"}; const r_39 = r_38.values[0] ?? { type: "null"}; const r_40 = r_38.values[1] ?? { type: "null"}; const r_41 = r_38.values[2] ?? { type: "null"}; let _params67 = r_41; const r_42 = r_32.values[3] ?? { type: "null"}; let _body68 = r_42; (runtime.setLine(71), _define_fn41(_ident66, _line63)); }; }; ; runtime.popCall(); return { type: "null" }; }; function _emit_expr33(_expr69) { runtime.pushCall("emit_expr"); const r_43 = _expr69; const r_44 = r_43.values[0] ?? { type: "null"}; let _ty70 = r_44; const r_45 = r_43.values[1] ?? { type: "null"}; let _line71 = r_45; if (runtime.truthy(runtime.opEq(_ty70, ({ type: "string", value: "list" })))) { (runtime.setLine(79), _emit_list34(_expr69)); } else { if (runtime.truthy(runtime.opEq(_ty70, ({ type: "string", value: "int" })))) { const r_46 = _expr69; const r_47 = r_46.values[0] ?? { type: "null"}; const r_48 = r_46.values[1] ?? { type: "null"}; const r_49 = r_46.values[2] ?? { type: "null"}; let _value72 = r_49; (runtime.setLine(82), _emit39((runtime.setLine(82), ((...args) => runtime.builtinFormat(...args))(({ type: "string", value: "({ type: \"int\", value: % })" }), _value72)))); } else { if (runtime.truthy(runtime.opEq(_ty70, ({ type: "string", value: "string" })))) { const r_50 = _expr69; const r_51 = r_50.values[0] ?? { type: "null"}; const r_52 = r_50.values[1] ?? { type: "null"}; const r_53 = r_50.values[2] ?? { type: "null"}; let _value73 = r_53; (runtime.setLine(85), _emit39((runtime.setLine(85), ((...args) => runtime.builtinFormat(...args))(({ type: "string", value: "({ type: \"string\", value: \"%\" })" }), (runtime.setLine(85), _string_escape19(_value73)))))); } else { if (runtime.truthy(runtime.opEq(_ty70, ({ type: "string", value: "ident" })))) { const r_54 = _expr69; const r_55 = r_54.values[0] ?? { type: "null"}; const r_56 = r_54.values[1] ?? { type: "null"}; const r_57 = r_54.values[2] ?? { type: "null"}; let _value74 = r_57; if (runtime.truthy(runtime.opEq(_value74, ({ type: "string", value: "null" })))) { (runtime.setLine(90), _emit39(({ type: "string", value: "({ type: \"null\" })" }))); runtime.popCall(); return { type: "null" }; } else { if (runtime.truthy(runtime.opEq(_value74, ({ type: "string", value: "false" })))) { (runtime.setLine(93), _emit39(({ type: "string", value: "({ type: \"bool\", value: false })" }))); runtime.popCall(); return { type: "null" }; } else { if (runtime.truthy(runtime.opEq(_value74, ({ type: "string", value: "true" })))) { (runtime.setLine(96), _emit39(({ type: "string", value: "({ type: \"bool\", value: true })" }))); runtime.popCall(); return { type: "null" }; }}}; const r_58 = (runtime.setLine(100), _get_sym48(_value74)); let _sym75 = r_58; if (runtime.truthy(runtime.opEq(_sym75, ({ type: "null" })))) { (runtime.setLine(102), _print_syms49()); (runtime.setLine(103), ((...args) => runtime.builtinPanic(...args))(({ type: "string", value: "undefined symbol '%' on line %" }), _value74, _line71)); }; const r_59 = _sym75; const r_60 = r_59.values[0] ?? { type: "null"}; let _sym_id76 = r_60; const r_61 = r_59.values[1] ?? { type: "null"}; let _sym_ty77 = r_61; if (runtime.truthy(runtime.opEq(_sym_ty77, ({ type: "string", value: "builtin" })))) { const r_62 = _sym75; const r_63 = r_62.values[0] ?? { type: "null"}; const r_64 = r_62.values[1] ?? { type: "null"}; const r_65 = r_62.values[2] ?? { type: "null"}; let _id78 = r_65; (runtime.setLine(109), _emit39((runtime.setLine(109), ((...args) => runtime.builtinFormat(...args))(({ type: "string", value: "((...args) => runtime.%(...args))" }), _id78)))); } else { if (runtime.truthy(runtime.opEq(_sym_ty77, ({ type: "string", value: "fn" })))) { (runtime.setLine(111), _emit39((runtime.setLine(111), ((...args) => runtime.builtinFormat(...args))(({ type: "string", value: "_%%" }), _value74, _sym_id76)))); } else { if (runtime.truthy(runtime.opEq(_sym_ty77, ({ type: "string", value: "param" })))) { (runtime.setLine(113), _emit39((runtime.setLine(113), ((...args) => runtime.builtinFormat(...args))(({ type: "string", value: "_%%" }), _value74, _sym_id76)))); } else { if (runtime.truthy(runtime.opEq(_sym_ty77, ({ type: "string", value: "let" })))) { (runtime.setLine(115), _emit39((runtime.setLine(115), ((...args) => runtime.builtinFormat(...args))(({ type: "string", value: "_%%" }), _value74, _sym_id76)))); } else { (runtime.setLine(117), ((...args) => runtime.builtinPanic(...args))(({ type: "string", value: "not implemented '%'" }), _sym_ty77)); }}}}; } else { (runtime.setLine(120), ((...args) => runtime.builtinPanic(...args))(({ type: "string", value: "unknown expr type '%' on line %" }), _ty70, _line71)); }}}}; ; runtime.popCall(); return { type: "null" }; }; function _emit_list34(_expr79) { runtime.pushCall("emit_list"); const r_66 = _expr79; const r_67 = r_66.values[0] ?? { type: "null"}; let _ty80 = r_67; const r_68 = r_66.values[1] ?? { type: "null"}; let _line81 = r_68; const r_69 = r_66.values[2] ?? { type: "null"}; let _s82 = r_69; if (runtime.truthy(runtime.opEq((runtime.setLine(126), ((...args) => runtime.builtinLen(...args))(_s82)), ({ type: "int", value: 0 })))) { (runtime.setLine(127), _emit39(({ type: "string", value: "({ type: \"list\", values: [] })" }))); runtime.popCall(); return { type: "null" }; }; const r_70 = _s82; const r_71 = r_70.values[0] ?? { type: "null"}; const r_72 = r_71.values[0] ?? { type: "null"}; let _id_ty83 = r_72; const r_73 = r_71.values[1] ?? { type: "null"}; const r_74 = r_71.values[2] ?? { type: "null"}; let _id84 = r_74; if (runtime.truthy(runtime.opNe(_id_ty83, ({ type: "string", value: "ident" })))) { (runtime.setLine(132), _emit_list_literal35(_s82)); runtime.popCall(); return { type: "null" }; }; if (runtime.truthy(runtime.opEq(_id84, ({ type: "string", value: "fn" })))) { const r_75 = _s82; const r_76 = r_75.values[0] ?? { type: "null"}; const r_77 = r_75.values[1] ?? { type: "null"}; const r_78 = r_77.values[0] ?? { type: "null"}; const r_79 = r_77.values[1] ?? { type: "null"}; const r_80 = r_77.values[2] ?? { type: "null"}; let _ident85 = r_80; const r_81 = r_75.values[2] ?? { type: "null"}; const r_82 = r_81.values[0] ?? { type: "null"}; const r_83 = r_81.values[1] ?? { type: "null"}; const r_84 = r_81.values[2] ?? { type: "null"}; let _params86 = r_84; const r_85 = r_75.values[3] ?? { type: "null"}; let _body87 = r_85; const r_86 = (runtime.setLine(138), _get_sym48(_ident85)); let _sym88 = r_86; const r_87 = _sym88; const r_88 = r_87.values[0] ?? { type: "null"}; let _sym_id89 = r_88; (runtime.setLine(141), _emit39((runtime.setLine(141), ((...args) => runtime.builtinFormat(...args))(({ type: "string", value: "function _%%(" }), _ident85, _sym_id89)))); (runtime.setLine(143), _enter_scope45()); const r_89 = ({ type: "bool", value: true }); let _first90 = r_89; for (const r_90 of _params86.values) {; const r_91 = r_90.values[0] ?? { type: "null"}; const r_92 = r_90.values[1] ?? { type: "null"}; const r_93 = r_90.values[2] ?? { type: "null"}; let _ident91 = r_93; if (runtime.truthy(runtime.opNot(_first90))) { (runtime.setLine(148), _emit39(({ type: "string", value: ", " }))); }; (_first90 = ({ type: "bool", value: false })); const r_94 = (runtime.setLine(152), _define_param42(_ident91, _line81)); let _sym_id92 = r_94; (runtime.setLine(153), _emit39((runtime.setLine(153), ((...args) => runtime.builtinFormat(...args))(({ type: "string", value: "_%%" }), _ident91, _sym_id92)))); }; (runtime.setLine(157), _emit39(({ type: "string", value: ") {\n" }))); (runtime.setLine(158), _emit39((runtime.setLine(158), ((...args) => runtime.builtinFormat(...args))(({ type: "string", value: "runtime.pushCall(\"%\");\n" }), _ident85)))); (runtime.setLine(160), _emit_expr33(_body87)); (runtime.setLine(161), _emit39(({ type: "string", value: ";\nruntime.popCall();\nreturn { type: \"null\" };\n}" }))); (runtime.setLine(163), _leave_scope46()); } else { if (runtime.truthy(runtime.opEq(_id84, ({ type: "string", value: "let" })))) { const r_95 = _s82; const r_96 = r_95.values[0] ?? { type: "null"}; const r_97 = r_95.values[1] ?? { type: "null"}; let _pat93 = r_97; const r_98 = r_95.values[2] ?? { type: "null"}; let _expr94 = r_98; const r_99 = (runtime.setLine(166), _let_node_reg_count50()); let _reg95 = r_99; (runtime.setLine(167), _let_node_reg_increment51()); (runtime.setLine(168), _emit39((runtime.setLine(168), ((...args) => runtime.builtinFormat(...args))(({ type: "string", value: "const r_% = " }), _reg95)))); (runtime.setLine(169), _emit_expr33(_expr94)); (runtime.setLine(170), _emit_let_node36(_pat93, _reg95)); } else { if (runtime.truthy(runtime.opEq(_id84, ({ type: "string", value: "do" })))) { (runtime.setLine(172), _enter_scope45()); (runtime.setLine(173), _discover_syms32((runtime.setLine(173), _slice26(_s82, ({ type: "int", value: 1 }))))); (runtime.setLine(174), _emit_exprs31((runtime.setLine(174), _slice26(_s82, ({ type: "int", value: 1 }))))); (runtime.setLine(175), _leave_scope46()); } else { if (runtime.truthy(runtime.opEq(_id84, ({ type: "string", value: "for" })))) { const r_100 = _s82; const r_101 = r_100.values[0] ?? { type: "null"}; const r_102 = r_100.values[1] ?? { type: "null"}; let _pat96 = r_102; const r_103 = r_100.values[2] ?? { type: "null"}; let _expr97 = r_103; const r_104 = r_100.values[3] ?? { type: "null"}; let _body98 = r_104; const r_105 = (runtime.setLine(179), _let_node_reg_count50()); let _reg99 = r_105; (runtime.setLine(180), _let_node_reg_increment51()); (runtime.setLine(181), _emit39((runtime.setLine(181), ((...args) => runtime.builtinFormat(...args))(({ type: "string", value: "for (const r_% of " }), _reg99)))); (runtime.setLine(182), _emit_expr33(_expr97)); (runtime.setLine(183), _emit39(({ type: "string", value: ".values) {" }))); (runtime.setLine(185), _enter_scope45()); (runtime.setLine(186), _emit_let_node36(_pat96, _reg99)); (runtime.setLine(187), _enter_scope45()); (runtime.setLine(189), _emit39(({ type: "string", value: ";\n" }))); (runtime.setLine(190), _emit_expr33(_body98)); (runtime.setLine(191), _emit39(({ type: "string", value: "}" }))); (runtime.setLine(193), _leave_scope46()); (runtime.setLine(194), _leave_scope46()); } else { if (runtime.truthy(runtime.opEq(_id84, ({ type: "string", value: "loop" })))) { const r_106 = _s82; const r_107 = r_106.values[0] ?? { type: "null"}; const r_108 = r_106.values[1] ?? { type: "null"}; let _body100 = r_108; (runtime.setLine(197), _emit39(({ type: "string", value: "while (true) {\n" }))); (runtime.setLine(198), _emit_expr33(_body100)); (runtime.setLine(199), _emit39(({ type: "string", value: "}" }))); } else { if (runtime.truthy(runtime.opEq(_id84, ({ type: "string", value: "if" })))) { const r_109 = _s82; const r_110 = r_109.values[0] ?? { type: "null"}; const r_111 = r_109.values[1] ?? { type: "null"}; let _cond101 = r_111; const r_112 = r_109.values[2] ?? { type: "null"}; let _truthy102 = r_112; const r_113 = r_109.values[3] ?? { type: "null"}; let _falsy103 = r_113; (runtime.setLine(202), _emit39(({ type: "string", value: "if (runtime.truthy(" }))); (runtime.setLine(203), _emit_expr33(_cond101)); (runtime.setLine(204), _emit39(({ type: "string", value: ")) {\n" }))); (runtime.setLine(205), _emit_expr33(_truthy102)); (runtime.setLine(206), _emit39(({ type: "string", value: "}" }))); if (runtime.truthy(runtime.opNe(_falsy103, ({ type: "null" })))) { (runtime.setLine(208), _emit39(({ type: "string", value: " else {\n" }))); (runtime.setLine(209), _emit_expr33(_falsy103)); (runtime.setLine(210), _emit39(({ type: "string", value: "}" }))); }; } else { if (runtime.truthy(runtime.opEq(_id84, ({ type: "string", value: "return" })))) { const r_114 = _s82; const r_115 = r_114.values[0] ?? { type: "null"}; const r_116 = r_114.values[1] ?? { type: "null"}; let _value104 = r_116; (runtime.setLine(214), _emit39(({ type: "string", value: "runtime.popCall();\n" }))); (runtime.setLine(215), _emit39(({ type: "string", value: "return " }))); if (runtime.truthy(runtime.opNe(_value104, ({ type: "null" })))) { (runtime.setLine(217), _emit_expr33(_value104)); } else { (runtime.setLine(219), _emit39(({ type: "string", value: "{ type: \"null\" }" }))); }; } else { if (runtime.truthy(runtime.opEq(_id84, ({ type: "string", value: "break" })))) { const r_117 = _s82; const r_118 = r_117.values[0] ?? { type: "null"}; const r_119 = r_117.values[1] ?? { type: "null"}; let _value105 = r_119; (runtime.setLine(223), _emit39(({ type: "string", value: "break" }))); if (runtime.truthy(runtime.opNe(_value105, ({ type: "null" })))) { (runtime.setLine(225), ((...args) => runtime.builtinPanic(...args))(({ type: "string", value: "not implemented" }))); }; } else { if (runtime.truthy(runtime.opEq(_id84, ({ type: "string", value: "call" })))) { const r_120 = _s82; const r_121 = r_120.values[0] ?? { type: "null"}; const r_122 = r_120.values[1] ?? { type: "null"}; let _callee106 = r_122; const r_123 = (runtime.setLine(229), _slice26(_s82, ({ type: "int", value: 2 }))); let _args107 = r_123; (runtime.setLine(230), _emit39((runtime.setLine(230), ((...args) => runtime.builtinFormat(...args))(({ type: "string", value: "(runtime.setLine(%), " }), _line81)))); (runtime.setLine(231), _emit_expr33(_callee106)); (runtime.setLine(232), _emit39(({ type: "string", value: "(" }))); const r_124 = ({ type: "bool", value: true }); let _first108 = r_124; for (const r_125 of _args107.values) {; let _arg109 = r_125; if (runtime.truthy(runtime.opNot(_first108))) { (runtime.setLine(237), _emit39(({ type: "string", value: ", " }))); }; (_first108 = ({ type: "bool", value: false })); (runtime.setLine(241), _emit_expr33(_arg109)); }; (runtime.setLine(244), _emit39(({ type: "string", value: "))" }))); } else { if (runtime.truthy(runtime.opEq(_id84, ({ type: "string", value: "=" })))) { (runtime.setLine(246), _emit_assign_expr38(_s82, _line81, ({ type: "string", value: "=" }))); } else { if (runtime.truthy(runtime.opEq(_id84, ({ type: "string", value: "+=" })))) { (runtime.setLine(248), _emit_assign_expr38(_s82, _line81, ({ type: "string", value: "+" }))); } else { if (runtime.truthy(runtime.opEq(_id84, ({ type: "string", value: "-=" })))) { (runtime.setLine(250), _emit_assign_expr38(_s82, _line81, ({ type: "string", value: "-" }))); } else { if (runtime.truthy(runtime.opEq(_id84, ({ type: "string", value: "or" })))) { const r_126 = _s82; const r_127 = r_126.values[0] ?? { type: "null"}; const r_128 = r_126.values[1] ?? { type: "null"}; let _left110 = r_128; const r_129 = r_126.values[2] ?? { type: "null"}; let _right111 = r_129; (runtime.setLine(253), _emit39((runtime.setLine(253), ((...args) => runtime.builtinFormat(...args))(({ type: "string", value: "(runtime.setLine(%)" }), _line81)))); (runtime.setLine(254), _emit39(({ type: "string", value: ", { type: \"bool\", value: runtime.truthy(" }))); (runtime.setLine(255), _emit_expr33(_left110)); (runtime.setLine(256), _emit39(({ type: "string", value: ") || runtime.truthy(" }))); (runtime.setLine(257), _emit_expr33(_right111)); (runtime.setLine(258), _emit39(({ type: "string", value: ") })" }))); } else { if (runtime.truthy(runtime.opEq(_id84, ({ type: "string", value: "and" })))) { const r_130 = _s82; const r_131 = r_130.values[0] ?? { type: "null"}; const r_132 = r_130.values[1] ?? { type: "null"}; let _left112 = r_132; const r_133 = r_130.values[2] ?? { type: "null"}; let _right113 = r_133; (runtime.setLine(261), _emit39((runtime.setLine(261), ((...args) => runtime.builtinFormat(...args))(({ type: "string", value: "(runtime.setLine(%)" }), _line81)))); (runtime.setLine(262), _emit39(({ type: "string", value: ", { type: \"bool\", value: runtime.truthy(" }))); (runtime.setLine(263), _emit_expr33(_left112)); (runtime.setLine(264), _emit39(({ type: "string", value: ") && runtime.truthy(" }))); (runtime.setLine(265), _emit_expr33(_right113)); (runtime.setLine(266), _emit39(({ type: "string", value: ") })" }))); } else { if (runtime.truthy(runtime.opEq(_id84, ({ type: "string", value: "==" })))) { (runtime.setLine(268), _emit_binary_op37(_s82, ({ type: "string", value: "opEq" }))); } else { if (runtime.truthy(runtime.opEq(_id84, ({ type: "string", value: "!=" })))) { (runtime.setLine(270), _emit_binary_op37(_s82, ({ type: "string", value: "opNe" }))); } else { if (runtime.truthy(runtime.opEq(_id84, ({ type: "string", value: "<" })))) { (runtime.setLine(272), _emit_binary_op37(_s82, ({ type: "string", value: "opLt" }))); } else { if (runtime.truthy(runtime.opEq(_id84, ({ type: "string", value: ">" })))) { (runtime.setLine(274), _emit_binary_op37(_s82, ({ type: "string", value: "opGt" }))); } else { if (runtime.truthy(runtime.opEq(_id84, ({ type: "string", value: "<=" })))) { (runtime.setLine(276), _emit_binary_op37(_s82, ({ type: "string", value: "opLte" }))); } else { if (runtime.truthy(runtime.opEq(_id84, ({ type: "string", value: ">=" })))) { (runtime.setLine(278), _emit_binary_op37(_s82, ({ type: "string", value: "opGte" }))); } else { if (runtime.truthy(runtime.opEq(_id84, ({ type: "string", value: "+" })))) { (runtime.setLine(280), _emit_binary_op37(_s82, ({ type: "string", value: "opAdd" }))); } else { if (runtime.truthy(runtime.opEq(_id84, ({ type: "string", value: "-" })))) { (runtime.setLine(282), _emit_binary_op37(_s82, ({ type: "string", value: "opSub" }))); } else { if (runtime.truthy(runtime.opEq(_id84, ({ type: "string", value: "not" })))) { const r_134 = _s82; const r_135 = r_134.values[0] ?? { type: "null"}; const r_136 = r_134.values[1] ?? { type: "null"}; let _expr114 = r_136; (runtime.setLine(285), _emit39(({ type: "string", value: "runtime.opNot(" }))); (runtime.setLine(286), _emit_expr33(_expr114)); (runtime.setLine(287), _emit39(({ type: "string", value: ")" }))); } else { (runtime.setLine(289), _emit_list_literal35(_s82)); }}}}}}}}}}}}}}}}}}}}}}}; ; runtime.popCall(); return { type: "null" }; }; function _emit_list_literal35(_s115) { runtime.pushCall("emit_list_literal"); (runtime.setLine(294), _emit39(({ type: "string", value: "({ type: \"list\", values: [" }))); const r_137 = ({ type: "bool", value: true }); let _first116 = r_137; for (const r_138 of _s115.values) {; let _e117 = r_138; if (runtime.truthy(runtime.opNot(_first116))) { (runtime.setLine(298), _emit39(({ type: "string", value: ", " }))); }; (_first116 = ({ type: "bool", value: false })); (runtime.setLine(302), _emit_expr33(_e117)); }; (runtime.setLine(304), _emit39(({ type: "string", value: "] })" }))); ; runtime.popCall(); return { type: "null" }; }; function _emit_let_node36(_pat118, _base_reg119) { runtime.pushCall("emit_let_node"); const r_139 = _pat118; const r_140 = r_139.values[0] ?? { type: "null"}; let _pat_ty120 = r_140; const r_141 = r_139.values[1] ?? { type: "null"}; let _line121 = r_141; if (runtime.truthy(runtime.opEq(_pat_ty120, ({ type: "string", value: "ident" })))) { const r_142 = _pat118; const r_143 = r_142.values[0] ?? { type: "null"}; const r_144 = r_142.values[1] ?? { type: "null"}; const r_145 = r_142.values[2] ?? { type: "null"}; let _ident122 = r_145; if (runtime.truthy(runtime.opEq(_ident122, ({ type: "string", value: "_" })))) { runtime.popCall(); return { type: "null" }}; const r_146 = (runtime.setLine(314), _define_let43(_ident122, _line121)); let _sym_id123 = r_146; (runtime.setLine(315), _emit39((runtime.setLine(315), ((...args) => runtime.builtinFormat(...args))(({ type: "string", value: ";\nlet _%% = r_%" }), _ident122, _sym_id123, _base_reg119)))); } else { if (runtime.truthy(runtime.opEq(_pat_ty120, ({ type: "string", value: "list" })))) { const r_147 = _pat118; const r_148 = r_147.values[0] ?? { type: "null"}; const r_149 = r_147.values[1] ?? { type: "null"}; const r_150 = r_147.values[2] ?? { type: "null"}; let _pats124 = r_150; const r_151 = ({ type: "int", value: 0 }); let _i125 = r_151; for (const r_152 of _pats124.values) {; let _pat126 = r_152; const r_153 = (runtime.setLine(337), _let_node_reg_count50()); let _reg127 = r_153; (runtime.setLine(338), _let_node_reg_increment51()); (runtime.setLine(339), _emit39((runtime.setLine(339), ((...args) => runtime.builtinFormat(...args))(({ type: "string", value: ";\nconst r_% = r_%.values[%] ?? { type: \"null\"}" }), _reg127, _base_reg119, _i125)))); (runtime.setLine(343), _emit_let_node36(_pat126, _reg127)); (_i125 = runtime.opAdd(_i125, ({ type: "int", value: 1 }))); }; } else { (runtime.setLine(347), ((...args) => runtime.builtinPanic(...args))(({ type: "string", value: "malformed pattern on line %" }), _line121)); }}; ; runtime.popCall(); return { type: "null" }; }; function _emit_binary_op37(_s128, _id129) { runtime.pushCall("emit_binary_op"); const r_154 = _s128; const r_155 = r_154.values[0] ?? { type: "null"}; const r_156 = r_154.values[1] ?? { type: "null"}; let _left130 = r_156; const r_157 = r_154.values[2] ?? { type: "null"}; let _right131 = r_157; (runtime.setLine(353), _emit39((runtime.setLine(353), ((...args) => runtime.builtinFormat(...args))(({ type: "string", value: "runtime.%(" }), _id129)))); (runtime.setLine(354), _emit_expr33(_left130)); (runtime.setLine(355), _emit39(({ type: "string", value: ", " }))); (runtime.setLine(356), _emit_expr33(_right131)); (runtime.setLine(357), _emit39(({ type: "string", value: ")" }))); ; runtime.popCall(); return { type: "null" }; }; function _emit_assign_expr38(_s132, _line133, _id134) { runtime.pushCall("emit_assign_expr"); const r_158 = _s132; const r_159 = r_158.values[0] ?? { type: "null"}; const r_160 = r_158.values[1] ?? { type: "null"}; const r_161 = r_160.values[0] ?? { type: "null"}; let _target_type135 = r_161; const r_162 = r_158.values[2] ?? { type: "null"}; let _expr136 = r_162; if (runtime.truthy(runtime.opNe(_target_type135, ({ type: "string", value: "ident" })))) { (runtime.setLine(363), ((...args) => runtime.builtinPanic(...args))(({ type: "string", value: "cannot assign to expression on line %" }), _line133)); }; const r_163 = _s132; const r_164 = r_163.values[0] ?? { type: "null"}; const r_165 = r_163.values[1] ?? { type: "null"}; const r_166 = r_165.values[0] ?? { type: "null"}; const r_167 = r_165.values[1] ?? { type: "null"}; const r_168 = r_165.values[2] ?? { type: "null"}; let _ident137 = r_168; const r_169 = (runtime.setLine(366), _get_sym48(_ident137)); let _sym138 = r_169; if (runtime.truthy(runtime.opEq(_sym138, ({ type: "null" })))) { (runtime.setLine(368), ((...args) => runtime.builtinPanic(...args))(({ type: "string", value: "could not find symbol '%' on line %" }), _ident137, _line133)); }; const r_170 = _sym138; const r_171 = r_170.values[0] ?? { type: "null"}; let _sym_id139 = r_171; const r_172 = r_170.values[1] ?? { type: "null"}; let _sym_type140 = r_172; const r_173 = r_170.values[2] ?? { type: "null"}; let _sym_ident141 = r_173; const r_174 = r_170.values[3] ?? { type: "null"}; if (runtime.truthy(runtime.opEq(_sym_type140, ({ type: "string", value: "let" })))) { (runtime.setLine(372), _emit39((runtime.setLine(372), ((...args) => runtime.builtinFormat(...args))(({ type: "string", value: "(_%% = " }), _sym_ident141, _sym_id139)))); if (runtime.truthy(runtime.opEq(_id134, ({ type: "string", value: "=" })))) { (runtime.setLine(374), _emit_expr33(_expr136)); } else { if (runtime.truthy(runtime.opEq(_id134, ({ type: "string", value: "+" })))) { (runtime.setLine(376), _emit39((runtime.setLine(376), ((...args) => runtime.builtinFormat(...args))(({ type: "string", value: "runtime.opAdd(_%%, " }), _sym_ident141, _sym_id139)))); (runtime.setLine(377), _emit_expr33(_expr136)); (runtime.setLine(378), _emit39(({ type: "string", value: ")" }))); } else { if (runtime.truthy(runtime.opEq(_id134, ({ type: "string", value: "-" })))) { (runtime.setLine(380), _emit39((runtime.setLine(380), ((...args) => runtime.builtinFormat(...args))(({ type: "string", value: "runtime.opSub(_%%, " }), _sym_ident141, _sym_id139)))); (runtime.setLine(381), _emit_expr33(_expr136)); (runtime.setLine(382), _emit39(({ type: "string", value: ")" }))); } else { (runtime.setLine(384), ((...args) => runtime.builtinPanic(...args))(({ type: "string", value: "not implemented" }))); }}}; (runtime.setLine(386), _emit39(({ type: "string", value: ")" }))); } else { (runtime.setLine(388), ((...args) => runtime.builtinPanic(...args))(({ type: "string", value: "cannot assign to symbol '%' on line %" }), _sym_ident141, _line133)); }; ; runtime.popCall(); return { type: "null" }; }; function _emit39(_str142) { runtime.pushCall("emit"); (runtime.setLine(393), ((...args) => runtime.builtinPush(...args))(_output44, _str142)); ; runtime.popCall(); return { type: "null" }; }; function _define_builtin40(_ident143, _builtin_id144) { runtime.pushCall("define_builtin"); const r_175 = (runtime.setLine(397), _sym_id_count52()); let _sym_id145 = r_175; (runtime.setLine(398), _sym_id_increment53()); (runtime.setLine(400), _define_sym47(_ident143, ({ type: "list", values: [_sym_id145, ({ type: "string", value: "builtin" }), _builtin_id144] }))); runtime.popCall(); return _sym_id145; ; runtime.popCall(); return { type: "null" }; }; function _define_fn41(_ident146, _line147) { runtime.pushCall("define_fn"); const r_176 = (runtime.setLine(405), _sym_id_count52()); let _sym_id148 = r_176; (runtime.setLine(406), _sym_id_increment53()); (runtime.setLine(408), _define_sym47(_ident146, ({ type: "list", values: [_sym_id148, ({ type: "string", value: "fn" }), _ident146, _line147] }))); runtime.popCall(); return _sym_id148; ; runtime.popCall(); return { type: "null" }; }; function _define_param42(_ident149, _line150) { runtime.pushCall("define_param"); const r_177 = (runtime.setLine(413), _sym_id_count52()); let _sym_id151 = r_177; (runtime.setLine(414), _sym_id_increment53()); (runtime.setLine(416), _define_sym47(_ident149, ({ type: "list", values: [_sym_id151, ({ type: "string", value: "param" }), _ident149, _line150] }))); runtime.popCall(); return _sym_id151; ; runtime.popCall(); return { type: "null" }; }; function _define_let43(_ident152, _line153) { runtime.pushCall("define_let"); const r_178 = (runtime.setLine(421), _sym_id_count52()); let _sym_id154 = r_178; (runtime.setLine(422), _sym_id_increment53()); (runtime.setLine(424), _define_sym47(_ident152, ({ type: "list", values: [_sym_id154, ({ type: "string", value: "let" }), _ident152, _line153] }))); runtime.popCall(); return _sym_id154; ; runtime.popCall(); return { type: "null" }; }; runtime.popCall(); return ({ type: "list", values: [_generate30] }); ; runtime.popCall(); return { type: "null" }; }; function _Counter17() { runtime.pushCall("Counter"); const r_179 = ({ type: "int", value: 0 }); let _counter157 = r_179; function _count155() { runtime.pushCall("count"); runtime.popCall(); return _counter157; ; runtime.popCall(); return { type: "null" }; }; function _increment156() { runtime.pushCall("increment"); (_counter157 = runtime.opAdd(_counter157, ({ type: "int", value: 1 }))); ; runtime.popCall(); return { type: "null" }; }; runtime.popCall(); return ({ type: "list", values: [_count155, _increment156] }); ; runtime.popCall(); return { type: "null" }; }; function _Syms18() { runtime.pushCall("Syms"); const r_180 = ({ type: "list", values: [({ type: "null" }), ({ type: "list", values: [] })] }); let _syms165 = r_180; function _enter_scope158() { runtime.pushCall("enter_scope"); (_syms165 = ({ type: "list", values: [_syms165, ({ type: "list", values: [] })] })); ; runtime.popCall(); return { type: "null" }; }; function _leave_scope159() { runtime.pushCall("leave_scope"); const r_181 = _syms165; const r_182 = r_181.values[0] ?? { type: "null"}; let _parent166 = r_182; const r_183 = r_181.values[1] ?? { type: "null"}; (_syms165 = _parent166); ; runtime.popCall(); return { type: "null" }; }; function _define160(_ident167, _sym168) { runtime.pushCall("define"); const r_184 = _syms165; const r_185 = r_184.values[0] ?? { type: "null"}; const r_186 = r_184.values[1] ?? { type: "null"}; let _map169 = r_186; const r_187 = ({ type: "int", value: 0 }); let _i170 = r_187; while (true) { if (runtime.truthy(runtime.opGte(_i170, (runtime.setLine(461), ((...args) => runtime.builtinLen(...args))(_map169))))) { break}; const r_188 = (runtime.setLine(462), ((...args) => runtime.builtinAt(...args))(_map169, _i170)); const r_189 = r_188.values[0] ?? { type: "null"}; let _s_ident171 = r_189; const r_190 = r_188.values[1] ?? { type: "null"}; if (runtime.truthy(runtime.opEq(_ident167, _s_ident171))) { (runtime.setLine(464), ((...args) => runtime.builtinSet(...args))(_map169, _i170, ({ type: "list", values: [_ident167, _sym168] }))); runtime.popCall(); return { type: "null" }; }; (_i170 = runtime.opAdd(_i170, ({ type: "int", value: 1 }))); }; (runtime.setLine(469), ((...args) => runtime.builtinPush(...args))(_map169, ({ type: "list", values: [_ident167, _sym168] }))); ; runtime.popCall(); return { type: "null" }; }; function _find_sym161(_syms172, _ident173) { runtime.pushCall("find_sym"); const r_191 = _syms172; const r_192 = r_191.values[0] ?? { type: "null"}; let _parent174 = r_192; const r_193 = r_191.values[1] ?? { type: "null"}; let _map175 = r_193; const r_194 = ({ type: "int", value: 0 }); let _i176 = r_194; while (true) { if (runtime.truthy(runtime.opGte(_i176, (runtime.setLine(476), ((...args) => runtime.builtinLen(...args))(_map175))))) { break}; const r_195 = (runtime.setLine(477), ((...args) => runtime.builtinAt(...args))(_map175, _i176)); const r_196 = r_195.values[0] ?? { type: "null"}; let _s_ident177 = r_196; const r_197 = r_195.values[1] ?? { type: "null"}; let _s_sym178 = r_197; if (runtime.truthy(runtime.opEq(_ident173, _s_ident177))) { runtime.popCall(); return _s_sym178; }; (_i176 = runtime.opAdd(_i176, ({ type: "int", value: 1 }))); }; if (runtime.truthy(runtime.opNe(_parent174, ({ type: "null" })))) { runtime.popCall(); return (runtime.setLine(484), _find_sym161(_parent174, _ident173)); }; runtime.popCall(); return ({ type: "null" }); ; runtime.popCall(); return { type: "null" }; }; function _get162(_ident179) { runtime.pushCall("get"); runtime.popCall(); return (runtime.setLine(490), _find_sym161(_syms165, _ident179)); ; runtime.popCall(); return { type: "null" }; }; function _print_syms_node163(_syms180, _depth181) { runtime.pushCall("print_syms_node"); const r_198 = _syms180; const r_199 = r_198.values[0] ?? { type: "null"}; let _parent182 = r_199; const r_200 = r_198.values[1] ?? { type: "null"}; let _map183 = r_200; for (const r_201 of _map183.values) {; const r_202 = r_201.values[0] ?? { type: "null"}; let _ident184 = r_202; const r_203 = r_201.values[1] ?? { type: "null"}; let _sym185 = r_203; (runtime.setLine(496), ((...args) => runtime.builtinPrintln(...args))(({ type: "string", value: "%- %: %" }), (runtime.setLine(496), _indent25(_depth181)), _ident184, _sym185)); }; if (runtime.truthy(runtime.opNe(_parent182, ({ type: "null" })))) { (runtime.setLine(499), _print_syms_node163(_parent182, runtime.opAdd(_depth181, ({ type: "int", value: 1 })))); }; ; runtime.popCall(); return { type: "null" }; }; function _print_syms164() { runtime.pushCall("print_syms"); (runtime.setLine(504), _print_syms_node163(_syms165, ({ type: "int", value: 0 }))); ; runtime.popCall(); return { type: "null" }; }; runtime.popCall(); return ({ type: "list", values: [_enter_scope158, _leave_scope159, _define160, _get162, _print_syms164] }); ; runtime.popCall(); return { type: "null" }; }; function _string_escape19(_str186) { runtime.pushCall("string_escape"); const r_204 = (runtime.setLine(518), ((...args) => runtime.builtinLen(...args))(_str186)); let _str_len187 = r_204; const r_205 = ({ type: "int", value: 0 }); let _i188 = r_205; const r_206 = ({ type: "string", value: "" }); let _result189 = r_206; while (true) { if (runtime.truthy(runtime.opGte(_i188, _str_len187))) { break}; const r_207 = (runtime.setLine(523), ((...args) => runtime.builtinAt(...args))(_str186, _i188)); let _ch190 = r_207; if (runtime.truthy(runtime.opEq(_ch190, ({ type: "string", value: "\\" })))) { (_result189 = runtime.opAdd(_result189, ({ type: "string", value: "\\\\" }))); } else { if (runtime.truthy(runtime.opEq(_ch190, ({ type: "string", value: "\"" })))) { (_result189 = runtime.opAdd(_result189, ({ type: "string", value: "\\\"" }))); } else { if (runtime.truthy(runtime.opEq(_ch190, ({ type: "string", value: "\t" })))) { (_result189 = runtime.opAdd(_result189, ({ type: "string", value: "\\t" }))); } else { if (runtime.truthy(runtime.opEq(_ch190, ({ type: "string", value: "\r" })))) { (_result189 = runtime.opAdd(_result189, ({ type: "string", value: "\\r" }))); } else { if (runtime.truthy(runtime.opEq(_ch190, ({ type: "string", value: "\n" })))) { (_result189 = runtime.opAdd(_result189, ({ type: "string", value: "\\n" }))); } else { if (runtime.truthy(runtime.opEq(_ch190, ({ type: "string", value: "\n" })))) { (_result189 = runtime.opAdd(_result189, ({ type: "string", value: "\\0" }))); } else { (_result189 = runtime.opAdd(_result189, _ch190)); }}}}}}; (_i188 = runtime.opAdd(_i188, ({ type: "int", value: 1 }))); }; runtime.popCall(); return _result189; ; runtime.popCall(); return { type: "null" }; }; function _Parser20(_tokens191) { runtime.pushCall("Parser"); const r_208 = ({ type: "int", value: 0 }); let _i198 = r_208; const r_209 = (runtime.setLine(546), ((...args) => runtime.builtinAt(...args))(_tokens191, _i198)); let _tok199 = r_209; function _parse192() { runtime.pushCall("parse"); const r_210 = ({ type: "list", values: [] }); let _exprs200 = r_210; while (true) { if (runtime.truthy((runtime.setLine(551), _done197()))) { break}; (runtime.setLine(552), ((...args) => runtime.builtinPush(...args))(_exprs200, (runtime.setLine(552), _parse_expr193()))); }; runtime.popCall(); return _exprs200; ; runtime.popCall(); return { type: "null" }; }; function _parse_expr193() { runtime.pushCall("parse_expr"); const r_211 = _tok199; const r_212 = r_211.values[0] ?? { type: "null"}; let _ty201 = r_212; const r_213 = r_211.values[1] ?? { type: "null"}; let _line202 = r_213; const r_214 = r_211.values[2] ?? { type: "null"}; let _value203 = r_214; if (runtime.truthy((runtime.setLine(559), _eat194(({ type: "string", value: "(" }))))) { const r_215 = ({ type: "list", values: [] }); let _values204 = r_215; while (true) { if (runtime.truthy((runtime.setLine(562), _test196(({ type: "string", value: ")" }))))) { break}; (runtime.setLine(563), ((...args) => runtime.builtinPush(...args))(_values204, (runtime.setLine(563), _parse_expr193()))); }; if (runtime.truthy(runtime.opNot((runtime.setLine(565), _eat194(({ type: "string", value: ")" })))))) { (runtime.setLine(566), ((...args) => runtime.builtinPanic(...args))(({ type: "string", value: "expected ')' on line %" }), (runtime.setLine(566), ((...args) => runtime.builtinAt(...args))(_tok199, ({ type: "int", value: 1 }))))); }; runtime.popCall(); return ({ type: "list", values: [({ type: "string", value: "list" }), _line202, _values204] }); } else { if (runtime.truthy((runtime.setLine(569), _eat194(({ type: "string", value: "string" }))))) { runtime.popCall(); return ({ type: "list", values: [({ type: "string", value: "string" }), _line202, _value203] }); } else { if (runtime.truthy((runtime.setLine(571), _eat194(({ type: "string", value: "int" }))))) { runtime.popCall(); return ({ type: "list", values: [({ type: "string", value: "int" }), _line202, (runtime.setLine(572), ((...args) => runtime.builtinStringToInt(...args))(_value203))] }); } else { if (runtime.truthy((runtime.setLine(573), _eat194(({ type: "string", value: "ident" }))))) { runtime.popCall(); return ({ type: "list", values: [({ type: "string", value: "ident" }), _line202, _value203] }); } else { (runtime.setLine(576), ((...args) => runtime.builtinPanic(...args))(({ type: "string", value: "expected expression, got '%' on line %" }), _ty201, _line202)); }}}}; ; runtime.popCall(); return { type: "null" }; }; function _eat194(_pat205) { runtime.pushCall("eat"); if (runtime.truthy(runtime.opNot((runtime.setLine(581), _test196(_pat205))))) { runtime.popCall(); return ({ type: "bool", value: false })}; (runtime.setLine(582), _step195()); runtime.popCall(); return ({ type: "bool", value: true }); ; runtime.popCall(); return { type: "null" }; }; function _step195() { runtime.pushCall("step"); (_i198 = runtime.opAdd(_i198, ({ type: "int", value: 1 }))); if (runtime.truthy(runtime.opNot((runtime.setLine(588), _done197())))) { const r_216 = (runtime.setLine(589), ((...args) => runtime.builtinAt(...args))(_tokens191, _i198)); let _new_tok206 = r_216; (_tok199 = _new_tok206); }; ; runtime.popCall(); return { type: "null" }; }; function _test196(_pat207) { runtime.pushCall("test"); if (runtime.truthy((runtime.setLine(595), _done197()))) { runtime.popCall(); return ({ type: "bool", value: false })}; const r_217 = _tok199; const r_218 = r_217.values[0] ?? { type: "null"}; let _ty208 = r_218; runtime.popCall(); return runtime.opEq(_pat207, _ty208); ; runtime.popCall(); return { type: "null" }; }; function _done197() { runtime.pushCall("done"); runtime.popCall(); return runtime.opGte(_i198, (runtime.setLine(601), ((...args) => runtime.builtinLen(...args))(_tokens191))); ; runtime.popCall(); return { type: "null" }; }; runtime.popCall(); return ({ type: "list", values: [_parse192] }); ; runtime.popCall(); return { type: "null" }; }; function _tokenize21(_text209) { runtime.pushCall("tokenize"); const r_219 = (runtime.setLine(608), ((...args) => runtime.builtinLen(...args))(_text209)); let _text_len210 = r_219; const r_220 = ({ type: "list", values: [] }); let _tokens211 = r_220; const r_221 = ({ type: "int", value: 0 }); let _i212 = r_221; const r_222 = ({ type: "int", value: 1 }); let _line213 = r_222; const r_223 = runtime.opAdd(({ type: "string", value: "abcdefghijklmnopqrstuvwxyz" }), ({ type: "string", value: "ABCDEFGHIJKLMNOPQRSTUVWXYZ1234567890+-*/%&|=?!<>'_" })); let _ident_chars214 = r_223; while (true) { if (runtime.truthy(runtime.opGte(_i212, _text_len210))) { break}; const r_224 = (runtime.setLine(620), ((...args) => runtime.builtinAt(...args))(_text209, _i212)); let _ch215 = r_224; if (runtime.truthy((runtime.setLine(622), _contains22(({ type: "string", value: " \t\r\n" }), _ch215)))) { if (runtime.truthy(runtime.opEq(_ch215, ({ type: "string", value: "\n" })))) { (_line213 = runtime.opAdd(_line213, ({ type: "int", value: 1 }))); }; (_i212 = runtime.opAdd(_i212, ({ type: "int", value: 1 }))); } else { if (runtime.truthy((runtime.setLine(627), _slice_eq23(_text209, _i212, ({ type: "string", value: "//" }))))) { while (true) { if (runtime.truthy((runtime.setLine(629), { type: "bool", value: runtime.truthy(runtime.opGte(_i212, _text_len210)) || runtime.truthy(runtime.opEq((runtime.setLine(629), ((...args) => runtime.builtinAt(...args))(_text209, _i212)), ({ type: "string", value: "\n" }))) }))) { break; }; (_i212 = runtime.opAdd(_i212, ({ type: "int", value: 1 }))); }; } else { if (runtime.truthy((runtime.setLine(634), _contains22(({ type: "string", value: "()" }), _ch215)))) { (runtime.setLine(635), ((...args) => runtime.builtinPush(...args))(_tokens211, ({ type: "list", values: [_ch215, _line213] }))); (_i212 = runtime.opAdd(_i212, ({ type: "int", value: 1 }))); } else { if (runtime.truthy(runtime.opEq(_ch215, ({ type: "string", value: "\"" })))) { const r_225 = ({ type: "string", value: "" }); let _value216 = r_225; (_i212 = runtime.opAdd(_i212, ({ type: "int", value: 1 }))); (_ch215 = (runtime.setLine(640), ((...args) => runtime.builtinAt(...args))(_text209, _i212))); while (true) { if (runtime.truthy((runtime.setLine(642), { type: "bool", value: runtime.truthy(runtime.opGte(_i212, _text_len210)) || runtime.truthy(runtime.opEq(_ch215, ({ type: "string", value: "\"" }))) }))) { break; }; if (runtime.truthy(runtime.opEq(_ch215, ({ type: "string", value: "\\" })))) { (_i212 = runtime.opAdd(_i212, ({ type: "int", value: 1 }))); if (runtime.truthy(runtime.opGte(_i212, _text_len210))) { break; }; (_ch215 = (runtime.setLine(650), ((...args) => runtime.builtinAt(...args))(_text209, _i212))); if (runtime.truthy(runtime.opEq(_ch215, ({ type: "string", value: "t" })))) { (_value216 = runtime.opAdd(_value216, ({ type: "string", value: "\t" }))); } else { if (runtime.truthy(runtime.opEq(_ch215, ({ type: "string", value: "r" })))) { (_value216 = runtime.opAdd(_value216, ({ type: "string", value: "\r" }))); } else { if (runtime.truthy(runtime.opEq(_ch215, ({ type: "string", value: "n" })))) { (_value216 = runtime.opAdd(_value216, ({ type: "string", value: "\n" }))); } else { if (runtime.truthy(runtime.opEq(_ch215, ({ type: "string", value: "0" })))) { (_value216 = runtime.opAdd(_value216, ({ type: "string", value: "\n" }))); } else { (_value216 = runtime.opAdd(_value216, _ch215)); }}}}; } else { (_value216 = runtime.opAdd(_value216, _ch215)); }; (_i212 = runtime.opAdd(_i212, ({ type: "int", value: 1 }))); (_ch215 = (runtime.setLine(666), ((...args) => runtime.builtinAt(...args))(_text209, _i212))); }; if (runtime.truthy((runtime.setLine(668), { type: "bool", value: runtime.truthy(runtime.opGte(_i212, _text_len210)) || runtime.truthy(runtime.opNe(_ch215, ({ type: "string", value: "\"" }))) }))) { (runtime.setLine(669), ((...args) => runtime.builtinPanic(...args))(({ type: "string", value: "expected '\"' on line %" }), _line213)); }; (_i212 = runtime.opAdd(_i212, ({ type: "int", value: 1 }))); (runtime.setLine(672), ((...args) => runtime.builtinPush(...args))(_tokens211, ({ type: "list", values: [({ type: "string", value: "string" }), _line213, _value216] }))); } else { if (runtime.truthy((runtime.setLine(673), _contains22(({ type: "string", value: "0123456789" }), _ch215)))) { const r_226 = ({ type: "string", value: "" }); let _value217 = r_226; while (true) { (_ch215 = (runtime.setLine(676), ((...args) => runtime.builtinAt(...args))(_text209, _i212))); if (runtime.truthy((runtime.setLine(677), { type: "bool", value: runtime.truthy(runtime.opGte(_i212, _text_len210)) || runtime.truthy(runtime.opNot((runtime.setLine(677), _contains22(({ type: "string", value: "0123456789" }), _ch215)))) }))) { break; }; (_value217 = runtime.opAdd(_value217, _ch215)); (_i212 = runtime.opAdd(_i212, ({ type: "int", value: 1 }))); }; (runtime.setLine(683), ((...args) => runtime.builtinPush(...args))(_tokens211, ({ type: "list", values: [({ type: "string", value: "int" }), _line213, _value217] }))); } else { if (runtime.truthy((runtime.setLine(684), _contains22(_ident_chars214, _ch215)))) { const r_227 = ({ type: "string", value: "" }); let _value218 = r_227; while (true) { (_ch215 = (runtime.setLine(687), ((...args) => runtime.builtinAt(...args))(_text209, _i212))); if (runtime.truthy((runtime.setLine(688), { type: "bool", value: runtime.truthy(runtime.opGte(_i212, _text_len210)) || runtime.truthy(runtime.opNot((runtime.setLine(688), _contains22(_ident_chars214, _ch215)))) }))) { break; }; (_value218 = runtime.opAdd(_value218, _ch215)); (_i212 = runtime.opAdd(_i212, ({ type: "int", value: 1 }))); }; (runtime.setLine(694), ((...args) => runtime.builtinPush(...args))(_tokens211, ({ type: "list", values: [({ type: "string", value: "ident" }), _line213, _value218] }))); } else { (runtime.setLine(696), ((...args) => runtime.builtinPrintln(...args))(({ type: "string", value: "illegal char '%'" }), _ch215)); (_i212 = runtime.opAdd(_i212, ({ type: "int", value: 1 }))); }}}}}}; }; runtime.popCall(); return _tokens211; ; runtime.popCall(); return { type: "null" }; }; function _contains22(_text219, _ch220) { runtime.pushCall("contains"); const r_228 = (runtime.setLine(704), ((...args) => runtime.builtinLen(...args))(_text219)); let _text_len221 = r_228; const r_229 = ({ type: "int", value: 0 }); let _i222 = r_229; while (true) { if (runtime.truthy(runtime.opGte(_i222, _text_len221))) { break}; if (runtime.truthy(runtime.opEq((runtime.setLine(708), ((...args) => runtime.builtinAt(...args))(_text219, _i222)), _ch220))) { runtime.popCall(); return ({ type: "bool", value: true }); }; (_i222 = runtime.opAdd(_i222, ({ type: "int", value: 1 }))); }; runtime.popCall(); return ({ type: "bool", value: false }); ; runtime.popCall(); return { type: "null" }; }; function _slice_eq23(_str223, _slice_idx224, _substr225) { runtime.pushCall("slice_eq"); const r_230 = (runtime.setLine(717), ((...args) => runtime.builtinLen(...args))(_str223)); let _str_len226 = r_230; const r_231 = (runtime.setLine(718), ((...args) => runtime.builtinLen(...args))(_substr225)); let _substr_len227 = r_231; const r_232 = ({ type: "int", value: 0 }); let _i228 = r_232; while (true) { if (runtime.truthy(runtime.opGte(_i228, _substr_len227))) { runtime.popCall(); return ({ type: "bool", value: true })}; if (runtime.truthy(runtime.opGte(runtime.opAdd(_slice_idx224, _i228), _str_len226))) { runtime.popCall(); return ({ type: "bool", value: false })}; if (runtime.truthy(runtime.opNe((runtime.setLine(725), ((...args) => runtime.builtinAt(...args))(_str223, runtime.opAdd(_slice_idx224, _i228))), (runtime.setLine(725), ((...args) => runtime.builtinAt(...args))(_substr225, _i228))))) { runtime.popCall(); return ({ type: "bool", value: false })}; (_i228 = runtime.opAdd(_i228, ({ type: "int", value: 1 }))); }; runtime.popCall(); return ({ type: "bool", value: true }); ; runtime.popCall(); return { type: "null" }; }; function _print_expr24(_expr229, _depth230) { runtime.pushCall("print_expr"); const r_233 = _expr229; const r_234 = r_233.values[0] ?? { type: "null"}; let _ty231 = r_234; const r_235 = r_233.values[1] ?? { type: "null"}; let _line232 = r_235; const r_236 = r_233.values[2] ?? { type: "null"}; let _value233 = r_236; if (runtime.truthy(runtime.opEq(_ty231, ({ type: "string", value: "list" })))) { (runtime.setLine(735), ((...args) => runtime.builtinPrintln(...args))(({ type: "string", value: "%(% %" }), (runtime.setLine(735), _indent25(_depth230)), _ty231, _line232)); for (const r_237 of _value233.values) {; let _e234 = r_237; (runtime.setLine(737), _print_expr24(_e234, runtime.opAdd(_depth230, ({ type: "int", value: 1 })))); }; (runtime.setLine(739), ((...args) => runtime.builtinPrintln(...args))(({ type: "string", value: "%)" }), (runtime.setLine(739), _indent25(_depth230)))); } else { (runtime.setLine(741), ((...args) => runtime.builtinPrintln(...args))(({ type: "string", value: "%%" }), (runtime.setLine(741), _indent25(_depth230)), _expr229)); }; ; runtime.popCall(); return { type: "null" }; }; function _indent25(_depth235) { runtime.pushCall("indent"); const r_238 = ({ type: "string", value: "" }); let _space236 = r_238; const r_239 = ({ type: "int", value: 0 }); let _i237 = r_239; while (true) { if (runtime.truthy(runtime.opGte(_i237, _depth235))) { break}; (_space236 = runtime.opAdd(_space236, ({ type: "string", value: " " }))); (_i237 = runtime.opAdd(_i237, ({ type: "int", value: 1 }))); }; runtime.popCall(); return _space236; ; runtime.popCall(); return { type: "null" }; }; function _slice26(_list238, _idx239) { runtime.pushCall("slice"); const r_240 = (runtime.setLine(757), ((...args) => runtime.builtinLen(...args))(_list238)); let _list_len240 = r_240; const r_241 = ({ type: "list", values: [] }); let _elems241 = r_241; const r_242 = _idx239; let _i242 = r_242; while (true) { if (runtime.truthy(runtime.opGte(_i242, _list_len240))) { break}; (runtime.setLine(762), ((...args) => runtime.builtinPush(...args))(_elems241, (runtime.setLine(762), ((...args) => runtime.builtinAt(...args))(_list238, _i242)))); (_i242 = runtime.opAdd(_i242, ({ type: "int", value: 1 }))); }; runtime.popCall(); return _elems241; ; runtime.popCall(); return { type: "null" }; }; const r_243 = ({ type: "bool", value: false }); let _silent243 = r_243; const r_244 = (runtime.setLine(770), ((...args) => runtime.builtinGetArgs(...args))()); const r_245 = r_244.values[0] ?? { type: "null"}; let _input_filename244 = r_245; const r_246 = r_244.values[1] ?? { type: "null"}; let _output_filename245 = r_246; if (runtime.truthy(runtime.opNot(_silent243))) { (runtime.setLine(772), ((...args) => runtime.builtinPrintln(...args))(({ type: "string", value: "reading file '%'..." }), _input_filename244))}; const r_247 = (runtime.setLine(773), ((...args) => runtime.builtinReadTextFile(...args))(_input_filename244)); let _text246 = r_247; if (runtime.truthy(runtime.opNot(_silent243))) { (runtime.setLine(779), ((...args) => runtime.builtinPrintln(...args))(({ type: "string", value: "tokenizing..." })))}; const r_248 = (runtime.setLine(780), _tokenize21(_text246)); let _tokens247 = r_248; if (runtime.truthy(runtime.opNot(_silent243))) { (runtime.setLine(793), ((...args) => runtime.builtinPrintln(...args))(({ type: "string", value: "parsing..." })))}; const r_249 = (runtime.setLine(794), _Parser20(_tokens247)); let _parser248 = r_249; const r_250 = _parser248; const r_251 = r_250.values[0] ?? { type: "null"}; let _parse249 = r_251; const r_252 = (runtime.setLine(796), _parse249()); let _ast250 = r_252; if (runtime.truthy(runtime.opNot(_silent243))) { (runtime.setLine(803), ((...args) => runtime.builtinPrintln(...args))(({ type: "string", value: "emitting..." })))}; const r_253 = (runtime.setLine(804), _Emitter16(_ast250, _input_filename244)); let _emitter251 = r_253; const r_254 = _emitter251; const r_255 = r_254.values[0] ?? { type: "null"}; let _emit252 = r_255; const r_256 = (runtime.setLine(806), _emit252()); let _js_code253 = r_256; if (runtime.truthy(runtime.opNot(_silent243))) { (runtime.setLine(811), ((...args) => runtime.builtinPrintln(...args))(({ type: "string", value: "writing file '%'..." }), _output_filename245))}; (runtime.setLine(812), ((...args) => runtime.builtinWriteTextFile(...args))(_output_filename245, _js_code253));