procedure Bool.11 (#Attr.2, #Attr.3): let Bool.23 : Int1 = lowlevel Eq #Attr.2 #Attr.3; ret Bool.23; procedure Encode.23 (Encode.98): ret Encode.98; procedure Encode.24 (Encode.99, Encode.107, Encode.101): let Encode.111 : List U8 = CallByName TotallyNotJson.182 Encode.99 Encode.101 Encode.107; ret Encode.111; procedure Encode.26 (Encode.105, Encode.106): let Encode.109 : List U8 = Array []; let Encode.110 : Str = CallByName TotallyNotJson.25 Encode.105; let Encode.108 : List U8 = CallByName Encode.24 Encode.109 Encode.110 Encode.106; ret Encode.108; procedure List.18 (List.145, List.146, List.147): let List.549 : U64 = 0i64; let List.550 : U64 = CallByName List.6 List.145; let List.548 : List U8 = CallByName List.86 List.145 List.146 List.147 List.549 List.550; ret List.548; procedure List.26 (List.172, List.173, List.174): let List.575 : [C {U64, Int1}, C {U64, Int1}] = CallByName List.96 List.172 List.173 List.174; let List.578 : U8 = 1i64; let List.579 : U8 = GetTagId List.575; let List.580 : Int1 = lowlevel Eq List.578 List.579; if List.580 then let List.175 : {U64, Int1} = UnionAtIndex (Id 1) (Index 0) List.575; ret List.175; else let List.176 : {U64, Int1} = UnionAtIndex (Id 0) (Index 0) List.575; ret List.176; procedure List.49 (List.390, List.391): let List.567 : U64 = StructAtIndex 0 List.391; let List.568 : U64 = 0i64; let List.565 : Int1 = CallByName Bool.11 List.567 List.568; if List.565 then dec List.390; let List.566 : List U8 = Array []; ret List.566; else let List.562 : U64 = StructAtIndex 1 List.391; let List.563 : U64 = StructAtIndex 0 List.391; let List.561 : List U8 = CallByName List.72 List.390 List.562 List.563; ret List.561; procedure List.52 (List.405, List.406): let List.407 : U64 = CallByName List.6 List.405; joinpoint List.573 List.408: let List.571 : U64 = 0i64; let List.570 : {U64, U64} = Struct {List.408, List.571}; inc List.405; let List.409 : List U8 = CallByName List.49 List.405 List.570; let List.569 : U64 = CallByName Num.75 List.407 List.408; let List.560 : {U64, U64} = Struct {List.569, List.408}; let List.410 : List U8 = CallByName List.49 List.405 List.560; let List.559 : {List U8, List U8} = Struct {List.409, List.410}; ret List.559; in let List.574 : Int1 = CallByName Num.24 List.407 List.406; if List.574 then jump List.573 List.406; else jump List.573 List.407; procedure List.6 (#Attr.2): let List.547 : U64 = lowlevel ListLen #Attr.2; ret List.547; procedure List.66 (#Attr.2, #Attr.3): let List.558 : U8 = lowlevel ListGetUnsafe #Attr.2 #Attr.3; ret List.558; procedure List.68 (#Attr.2): let List.545 : List U8 = lowlevel ListWithCapacity #Attr.2; ret List.545; procedure List.72 (#Attr.2, #Attr.3, #Attr.4): let List.564 : List U8 = lowlevel ListSublist #Attr.2 #Attr.3 #Attr.4; ret List.564; procedure List.8 (#Attr.2, #Attr.3): let List.543 : List U8 = lowlevel ListConcat #Attr.2 #Attr.3; ret List.543; procedure List.80 (#Derived_gen.8, #Derived_gen.9, #Derived_gen.10, #Derived_gen.11, #Derived_gen.12): joinpoint List.584 List.453 List.454 List.455 List.456 List.457: let List.586 : Int1 = CallByName Num.22 List.456 List.457; if List.586 then let List.595 : U8 = CallByName List.66 List.453 List.456; let List.587 : [C {U64, Int1}, C {U64, Int1}] = CallByName TotallyNotJson.189 List.454 List.595; let List.592 : U8 = 1i64; let List.593 : U8 = GetTagId List.587; let List.594 : Int1 = lowlevel Eq List.592 List.593; if List.594 then let List.458 : {U64, Int1} = UnionAtIndex (Id 1) (Index 0) List.587; let List.590 : U64 = 1i64; let List.589 : U64 = CallByName Num.51 List.456 List.590; jump List.584 List.453 List.458 List.455 List.589 List.457; else dec List.453; let List.459 : {U64, Int1} = UnionAtIndex (Id 0) (Index 0) List.587; let List.591 : [C {U64, Int1}, C {U64, Int1}] = TagId(0) List.459; ret List.591; else dec List.453; let List.585 : [C {U64, Int1}, C {U64, Int1}] = TagId(1) List.454; ret List.585; in jump List.584 #Derived_gen.8 #Derived_gen.9 #Derived_gen.10 #Derived_gen.11 #Derived_gen.12; procedure List.86 (#Derived_gen.3, #Derived_gen.4, #Derived_gen.5, #Derived_gen.6, #Derived_gen.7): joinpoint List.551 List.148 List.149 List.150 List.151 List.152: let List.553 : Int1 = CallByName Num.22 List.151 List.152; if List.553 then let List.557 : U8 = CallByName List.66 List.148 List.151; let List.153 : List U8 = CallByName TotallyNotJson.215 List.149 List.557; let List.556 : U64 = 1i64; let List.555 : U64 = CallByName Num.51 List.151 List.556; jump List.551 List.148 List.153 List.150 List.555 List.152; else dec List.148; ret List.149; in jump List.551 #Derived_gen.3 #Derived_gen.4 #Derived_gen.5 #Derived_gen.6 #Derived_gen.7; procedure List.96 (List.450, List.451, List.452): let List.582 : U64 = 0i64; let List.583 : U64 = CallByName List.6 List.450; let List.581 : [C {U64, Int1}, C {U64, Int1}] = CallByName List.80 List.450 List.451 List.452 List.582 List.583; ret List.581; procedure Num.19 (#Attr.2, #Attr.3): let Num.293 : U64 = lowlevel NumAdd #Attr.2 #Attr.3; ret Num.293; procedure Num.21 (#Attr.2, #Attr.3): let Num.295 : U64 = lowlevel NumMul #Attr.2 #Attr.3; ret Num.295; procedure Num.22 (#Attr.2, #Attr.3): let Num.299 : Int1 = lowlevel NumLt #Attr.2 #Attr.3; ret Num.299; procedure Num.24 (#Attr.2, #Attr.3): let Num.301 : Int1 = lowlevel NumGt #Attr.2 #Attr.3; ret Num.301; procedure Num.51 (#Attr.2, #Attr.3): let Num.297 : U64 = lowlevel NumAddWrap #Attr.2 #Attr.3; ret Num.297; procedure Num.75 (#Attr.2, #Attr.3): let Num.300 : U64 = lowlevel NumSubWrap #Attr.2 #Attr.3; ret Num.300; procedure Num.94 (#Attr.2, #Attr.3): let Num.294 : U64 = lowlevel NumDivCeilUnchecked #Attr.2 #Attr.3; ret Num.294; procedure Str.12 (#Attr.2): let Str.299 : List U8 = lowlevel StrToUtf8 #Attr.2; ret Str.299; procedure Str.48 (#Attr.2, #Attr.3, #Attr.4): let Str.298 : {U64, Str, Int1, U8} = lowlevel StrFromUtf8Range #Attr.2 #Attr.3 #Attr.4; ret Str.298; procedure Str.9 (Str.79): let Str.296 : U64 = 0i64; let Str.297 : U64 = CallByName List.6 Str.79; let Str.80 : {U64, Str, Int1, U8} = CallByName Str.48 Str.79 Str.296 Str.297; let Str.293 : Int1 = StructAtIndex 2 Str.80; if Str.293 then let Str.295 : Str = StructAtIndex 1 Str.80; let Str.294 : [C {U64, U8}, C Str] = TagId(1) Str.295; ret Str.294; else let Str.291 : U8 = StructAtIndex 3 Str.80; let Str.292 : U64 = StructAtIndex 0 Str.80; let #Derived_gen.13 : Str = StructAtIndex 1 Str.80; dec #Derived_gen.13; let Str.290 : {U64, U8} = Struct {Str.292, Str.291}; let Str.289 : [C {U64, U8}, C Str] = TagId(0) Str.290; ret Str.289; procedure TotallyNotJson.182 (TotallyNotJson.183, TotallyNotJson.1175, TotallyNotJson.181): let TotallyNotJson.1178 : List U8 = CallByName TotallyNotJson.26 TotallyNotJson.181; let TotallyNotJson.1177 : List U8 = CallByName List.8 TotallyNotJson.183 TotallyNotJson.1178; ret TotallyNotJson.1177; procedure TotallyNotJson.189 (TotallyNotJson.1226, TotallyNotJson.192): let TotallyNotJson.190 : U64 = StructAtIndex 0 TotallyNotJson.1226; let TotallyNotJson.191 : Int1 = StructAtIndex 1 TotallyNotJson.1226; switch TotallyNotJson.192: case 34: let TotallyNotJson.1229 : Int1 = false; let TotallyNotJson.1228 : {U64, Int1} = Struct {TotallyNotJson.190, TotallyNotJson.1229}; let TotallyNotJson.1227 : [C {U64, Int1}, C {U64, Int1}] = TagId(0) TotallyNotJson.1228; ret TotallyNotJson.1227; case 92: let TotallyNotJson.1232 : Int1 = false; let TotallyNotJson.1231 : {U64, Int1} = Struct {TotallyNotJson.190, TotallyNotJson.1232}; let TotallyNotJson.1230 : [C {U64, Int1}, C {U64, Int1}] = TagId(0) TotallyNotJson.1231; ret TotallyNotJson.1230; case 47: let TotallyNotJson.1235 : Int1 = false; let TotallyNotJson.1234 : {U64, Int1} = Struct {TotallyNotJson.190, TotallyNotJson.1235}; let TotallyNotJson.1233 : [C {U64, Int1}, C {U64, Int1}] = TagId(0) TotallyNotJson.1234; ret TotallyNotJson.1233; case 8: let TotallyNotJson.1238 : Int1 = false; let TotallyNotJson.1237 : {U64, Int1} = Struct {TotallyNotJson.190, TotallyNotJson.1238}; let TotallyNotJson.1236 : [C {U64, Int1}, C {U64, Int1}] = TagId(0) TotallyNotJson.1237; ret TotallyNotJson.1236; case 12: let TotallyNotJson.1241 : Int1 = false; let TotallyNotJson.1240 : {U64, Int1} = Struct {TotallyNotJson.190, TotallyNotJson.1241}; let TotallyNotJson.1239 : [C {U64, Int1}, C {U64, Int1}] = TagId(0) TotallyNotJson.1240; ret TotallyNotJson.1239; case 10: let TotallyNotJson.1244 : Int1 = false; let TotallyNotJson.1243 : {U64, Int1} = Struct {TotallyNotJson.190, TotallyNotJson.1244}; let TotallyNotJson.1242 : [C {U64, Int1}, C {U64, Int1}] = TagId(0) TotallyNotJson.1243; ret TotallyNotJson.1242; case 13: let TotallyNotJson.1247 : Int1 = false; let TotallyNotJson.1246 : {U64, Int1} = Struct {TotallyNotJson.190, TotallyNotJson.1247}; let TotallyNotJson.1245 : [C {U64, Int1}, C {U64, Int1}] = TagId(0) TotallyNotJson.1246; ret TotallyNotJson.1245; case 9: let TotallyNotJson.1250 : Int1 = false; let TotallyNotJson.1249 : {U64, Int1} = Struct {TotallyNotJson.190, TotallyNotJson.1250}; let TotallyNotJson.1248 : [C {U64, Int1}, C {U64, Int1}] = TagId(0) TotallyNotJson.1249; ret TotallyNotJson.1248; default: let TotallyNotJson.1254 : U64 = 1i64; let TotallyNotJson.1253 : U64 = CallByName Num.19 TotallyNotJson.190 TotallyNotJson.1254; let TotallyNotJson.1252 : {U64, Int1} = Struct {TotallyNotJson.1253, TotallyNotJson.191}; let TotallyNotJson.1251 : [C {U64, Int1}, C {U64, Int1}] = TagId(1) TotallyNotJson.1252; ret TotallyNotJson.1251; procedure TotallyNotJson.2 (): let TotallyNotJson.1172 : [C , C [], C , C , C , C ] = TagId(2) ; ret TotallyNotJson.1172; procedure TotallyNotJson.215 (TotallyNotJson.216, TotallyNotJson.217): let TotallyNotJson.1197 : List U8 = CallByName TotallyNotJson.27 TotallyNotJson.217; let TotallyNotJson.1196 : List U8 = CallByName List.8 TotallyNotJson.216 TotallyNotJson.1197; ret TotallyNotJson.1196; procedure TotallyNotJson.25 (TotallyNotJson.181): let TotallyNotJson.1173 : Str = CallByName Encode.23 TotallyNotJson.181; ret TotallyNotJson.1173; procedure TotallyNotJson.26 (TotallyNotJson.184): let TotallyNotJson.185 : List U8 = CallByName Str.12 TotallyNotJson.184; let TotallyNotJson.1255 : U64 = 0i64; let TotallyNotJson.1256 : Int1 = true; let TotallyNotJson.186 : {U64, Int1} = Struct {TotallyNotJson.1255, TotallyNotJson.1256}; let TotallyNotJson.1225 : {} = Struct {}; inc TotallyNotJson.185; let TotallyNotJson.187 : {U64, Int1} = CallByName List.26 TotallyNotJson.185 TotallyNotJson.186 TotallyNotJson.1225; let TotallyNotJson.1179 : Int1 = StructAtIndex 1 TotallyNotJson.187; let TotallyNotJson.1223 : Int1 = true; let TotallyNotJson.1224 : Int1 = lowlevel Eq TotallyNotJson.1223 TotallyNotJson.1179; if TotallyNotJson.1224 then let TotallyNotJson.1189 : U64 = CallByName List.6 TotallyNotJson.185; let TotallyNotJson.1190 : U64 = 2i64; let TotallyNotJson.1188 : U64 = CallByName Num.19 TotallyNotJson.1189 TotallyNotJson.1190; let TotallyNotJson.1185 : List U8 = CallByName List.68 TotallyNotJson.1188; let TotallyNotJson.1187 : U8 = 34i64; let TotallyNotJson.1186 : List U8 = Array [TotallyNotJson.1187]; let TotallyNotJson.1184 : List U8 = CallByName List.8 TotallyNotJson.1185 TotallyNotJson.1186; let TotallyNotJson.1181 : List U8 = CallByName List.8 TotallyNotJson.1184 TotallyNotJson.185; let TotallyNotJson.1183 : U8 = 34i64; let TotallyNotJson.1182 : List U8 = Array [TotallyNotJson.1183]; let TotallyNotJson.1180 : List U8 = CallByName List.8 TotallyNotJson.1181 TotallyNotJson.1182; ret TotallyNotJson.1180; else inc TotallyNotJson.185; let TotallyNotJson.1222 : U64 = StructAtIndex 0 TotallyNotJson.187; let TotallyNotJson.1221 : {List U8, List U8} = CallByName List.52 TotallyNotJson.185 TotallyNotJson.1222; let TotallyNotJson.211 : List U8 = StructAtIndex 0 TotallyNotJson.1221; let TotallyNotJson.213 : List U8 = StructAtIndex 1 TotallyNotJson.1221; let TotallyNotJson.1219 : U64 = CallByName List.6 TotallyNotJson.185; dec TotallyNotJson.185; let TotallyNotJson.1220 : U64 = 120i64; let TotallyNotJson.1217 : U64 = CallByName Num.21 TotallyNotJson.1219 TotallyNotJson.1220; let TotallyNotJson.1218 : U64 = 100i64; let TotallyNotJson.1216 : U64 = CallByName Num.94 TotallyNotJson.1217 TotallyNotJson.1218; let TotallyNotJson.1213 : List U8 = CallByName List.68 TotallyNotJson.1216; let TotallyNotJson.1215 : U8 = 34i64; let TotallyNotJson.1214 : List U8 = Array [TotallyNotJson.1215]; let TotallyNotJson.1212 : List U8 = CallByName List.8 TotallyNotJson.1213 TotallyNotJson.1214; let TotallyNotJson.214 : List U8 = CallByName List.8 TotallyNotJson.1212 TotallyNotJson.211; let TotallyNotJson.1195 : {} = Struct {}; let TotallyNotJson.1192 : List U8 = CallByName List.18 TotallyNotJson.213 TotallyNotJson.214 TotallyNotJson.1195; let TotallyNotJson.1194 : U8 = 34i64; let TotallyNotJson.1193 : List U8 = Array [TotallyNotJson.1194]; let TotallyNotJson.1191 : List U8 = CallByName List.8 TotallyNotJson.1192 TotallyNotJson.1193; ret TotallyNotJson.1191; procedure TotallyNotJson.27 (TotallyNotJson.218): switch TotallyNotJson.218: case 34: let TotallyNotJson.1198 : List U8 = Array [92i64, 34i64]; ret TotallyNotJson.1198; case 92: let TotallyNotJson.1199 : List U8 = Array [92i64, 92i64]; ret TotallyNotJson.1199; case 47: let TotallyNotJson.1200 : List U8 = Array [92i64, 47i64]; ret TotallyNotJson.1200; case 8: let TotallyNotJson.1202 : U8 = 98i64; let TotallyNotJson.1201 : List U8 = Array [92i64, TotallyNotJson.1202]; ret TotallyNotJson.1201; case 12: let TotallyNotJson.1204 : U8 = 102i64; let TotallyNotJson.1203 : List U8 = Array [92i64, TotallyNotJson.1204]; ret TotallyNotJson.1203; case 10: let TotallyNotJson.1206 : U8 = 110i64; let TotallyNotJson.1205 : List U8 = Array [92i64, TotallyNotJson.1206]; ret TotallyNotJson.1205; case 13: let TotallyNotJson.1208 : U8 = 114i64; let TotallyNotJson.1207 : List U8 = Array [92i64, TotallyNotJson.1208]; ret TotallyNotJson.1207; case 9: let TotallyNotJson.1210 : U8 = 114i64; let TotallyNotJson.1209 : List U8 = Array [92i64, TotallyNotJson.1210]; ret TotallyNotJson.1209; default: let TotallyNotJson.1211 : List U8 = Array [TotallyNotJson.218]; ret TotallyNotJson.1211; procedure Test.0 (): let Test.9 : Str = "abc"; let Test.10 : [C , C [], C , C , C , C ] = CallByName TotallyNotJson.2; let Test.8 : List U8 = CallByName Encode.26 Test.9 Test.10; let Test.1 : [C {U64, U8}, C Str] = CallByName Str.9 Test.8; let Test.5 : U8 = 1i64; let Test.6 : U8 = GetTagId Test.1; let Test.7 : Int1 = lowlevel Eq Test.5 Test.6; if Test.7 then let Test.2 : Str = UnionAtIndex (Id 1) (Index 0) Test.1; ret Test.2; else dec Test.1; let Test.4 : Str = ""; ret Test.4;