procedure Num.19 (#Attr.2, #Attr.3): let Num.258 : I64 = lowlevel NumAdd #Attr.2 #Attr.3; ret Num.258; procedure Num.21 (#Attr.2, #Attr.3): let Num.257 : I64 = lowlevel NumMul #Attr.2 #Attr.3; ret Num.257; procedure Test.6 (Test.8, #Attr.12): let Test.4 : I64 = UnionAtIndex (Id 0) (Index 0) #Attr.12; let Test.22 : I64 = CallByName Num.19 Test.8 Test.4; ret Test.22; procedure Test.7 (Test.9, #Attr.12): let Test.5 : I64 = UnionAtIndex (Id 1) (Index 0) #Attr.12; let Test.20 : I64 = CallByName Num.21 Test.9 Test.5; ret Test.20; procedure Test.0 (): let Test.4 : I64 = 1i64; let Test.5 : I64 = 2i64; let Test.12 : I64 = 42i64; joinpoint Test.19 Test.13: let Test.14 : U8 = GetTagId Test.13; joinpoint Test.15 Test.11: ret Test.11; in switch Test.14: case 0: let Test.16 : I64 = CallByName Test.6 Test.12 Test.13; jump Test.15 Test.16; default: let Test.17 : I64 = CallByName Test.7 Test.12 Test.13; jump Test.15 Test.17; in let Test.21 : Int1 = true; if Test.21 then let Test.6 : [C I64, C I64] = TagId(0) Test.4; jump Test.19 Test.6; else let Test.7 : [C I64, C I64] = TagId(1) Test.5; jump Test.19 Test.7;