From ce77867566ef367cd0bcba77123f8e67f7a0974d Mon Sep 17 00:00:00 2001 From: agra Date: Thu, 28 May 2026 07:51:44 +0300 Subject: [PATCH] =?UTF-8?q?ffi=20any=5Fto=5Fstring=20handles=20optionals?= =?UTF-8?q?=20=E2=80=94=20make-green?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Closes the optional-through-Any gap that test 178 pinned. Stdlib (`library/modules/std.sx`): - New `optional_to_string :: (o: $T) -> string` returns `"null"` when the optional is None, otherwise recurses through `any_to_string` on the unwrapped inner value. Per-shape monomorphisation re-emits this for each concrete `?T`. - `any_to_string` grows a `case optional:` arm that dispatches through `cast(type) val` (same shape as `case struct:` etc.). The cast picks up the dynamic optional type from the Any tag. Compiler (`src/ir/lower.zig`): - `resolveTypeCategoryTags` recognises "optional" as a dynamic category, scanning the TypeTable for `info == .optional`. The type-switch dispatch then routes any ?T tag into the optional arm. IR snapshots regenerated where the optional addition shifted constant pool / string numbering: 142, ffi-objc-call-06, ffi-objc-dsl-07. 218/218 (test 178 included). The variadic auto-unwrap in `packVariadicCallArgs` stays in place — direct `print(opt)` calls still flow through it. The new arm closes the gap for struct fields, slice elements, and any other path that boxes an optional before stringifying. --- library/modules/std.sx | 6 + src/ir/lower.zig | 5 +- .../142-objc-class-method-lowering.ir | 2 - .../expected/ffi-objc-call-06-sret-return.ir | 1039 +++++++++-------- .../ffi-objc-dsl-07-mangling-table.ir | 2 - 5 files changed, 530 insertions(+), 524 deletions(-) diff --git a/library/modules/std.sx b/library/modules/std.sx index 4a0a08b..bc92328 100644 --- a/library/modules/std.sx +++ b/library/modules/std.sx @@ -298,6 +298,11 @@ enum_to_string :: (u: $T) -> string { result; } +optional_to_string :: (o: $T) -> string { + if o == null { return "null"; } + return any_to_string(o!); +} + any_to_string :: (val: Any) -> string { result := ""; type := type_of(val); @@ -313,6 +318,7 @@ any_to_string :: (val: Any) -> string { case array: result = array_to_string(cast(type) val); case slice: result = slice_to_string(cast(type) val); case pointer: result = pointer_to_string(cast(type) val); + case optional: result = optional_to_string(cast(type) val); case type: { s : string = xx val; result = s; } } result; diff --git a/src/ir/lower.zig b/src/ir/lower.zig index a59b9ad..2f267f4 100644 --- a/src/ir/lower.zig +++ b/src/ir/lower.zig @@ -9491,7 +9491,7 @@ pub const Lowering = struct { } // Dynamic categories: scan TypeTable for matching types - const Category = enum { @"struct", @"enum", @"union", slice, array, pointer, vector }; + const Category = enum { @"struct", @"enum", @"union", slice, array, pointer, vector, optional }; const cat: ?Category = if (std.mem.eql(u8, name, "struct")) .@"struct" else if (std.mem.eql(u8, name, "enum") or std.mem.eql(u8, name, "union")) @@ -9504,6 +9504,8 @@ pub const Lowering = struct { .pointer else if (std.mem.eql(u8, name, "vector")) .vector + else if (std.mem.eql(u8, name, "optional")) + .optional else null; @@ -9517,6 +9519,7 @@ pub const Lowering = struct { .array => info == .array, .pointer => info == .pointer or info == .many_pointer, .vector => info == .vector, + .optional => info == .optional, }; if (matches) { tags.append(self.alloc, @intCast(idx)) catch {}; diff --git a/tests/expected/142-objc-class-method-lowering.ir b/tests/expected/142-objc-class-method-lowering.ir index 5bfdafc..5153b1b 100644 --- a/tests/expected/142-objc-class-method-lowering.ir +++ b/tests/expected/142-objc-class-method-lowering.ir @@ -892,5 +892,3 @@ declare ptr @object_getClass(ptr) declare ptr @objc_getProtocol(ptr) declare i8 @class_addProtocol(ptr, ptr) - - diff --git a/tests/expected/ffi-objc-call-06-sret-return.ir b/tests/expected/ffi-objc-call-06-sret-return.ir index eddaff3..550ffae 100644 --- a/tests/expected/ffi-objc-call-06-sret-return.ir +++ b/tests/expected/ffi-objc-call-06-sret-return.ir @@ -428,16 +428,16 @@ entry: %alloca = alloca i1, align 1 store i1 %1, ptr %alloca, align 1 %load = load i1, ptr %alloca, align 1 - br i1 %load, label %if.then.52, label %if.else.53 + br i1 %load, label %if.then.53, label %if.else.54 -if.then.52: ; preds = %entry - br label %if.merge.54 +if.then.53: ; preds = %entry + br label %if.merge.55 -if.else.53: ; preds = %entry - br label %if.merge.54 +if.else.54: ; preds = %entry + br label %if.merge.55 -if.merge.54: ; preds = %if.else.53, %if.then.52 - %bp = phi { ptr, i64 } [ { ptr @str.1, i64 4 }, %if.then.52 ], [ { ptr @str.2, i64 5 }, %if.else.53 ] +if.merge.55: ; preds = %if.else.54, %if.then.53 + %bp = phi { ptr, i64 } [ { ptr @str.1, i64 4 }, %if.then.53 ], [ { ptr @str.2, i64 5 }, %if.else.54 ] ret { ptr, i64 } %bp } @@ -451,19 +451,19 @@ entry: %allocaN = alloca i1, align 1 store i1 %fcmp, ptr %allocaN, align 1 %loadN = load i1, ptr %allocaN, align 1 - br i1 %loadN, label %if.then.58, label %if.else.59 + br i1 %loadN, label %if.then.59, label %if.else.60 -if.then.58: ; preds = %entry +if.then.59: ; preds = %entry %loadN = load double, ptr %alloca, align 8 %fsub = fsub double 0.000000e+00, %loadN - br label %if.merge.60 + br label %if.merge.61 -if.else.59: ; preds = %entry +if.else.60: ; preds = %entry %loadN = load double, ptr %alloca, align 8 - br label %if.merge.60 + br label %if.merge.61 -if.merge.60: ; preds = %if.else.59, %if.then.58 - %bp = phi double [ %fsub, %if.then.58 ], [ %loadN, %if.else.59 ] +if.merge.61: ; preds = %if.else.60, %if.then.59 + %bp = phi double [ %fsub, %if.then.59 ], [ %loadN, %if.else.60 ] %allocaN = alloca double, align 8 store double %bp, ptr %allocaN, align 8 %loadN = load double, ptr %allocaN, align 8 @@ -480,15 +480,15 @@ if.merge.60: ; preds = %if.else.59, %if.the store i64 %fptosiN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %icmp = icmp slt i64 %loadN, 0 - br i1 %icmp, label %if.then.61, label %if.merge.62 + br i1 %icmp, label %if.then.62, label %if.merge.63 -if.then.61: ; preds = %if.merge.60 +if.then.62: ; preds = %if.merge.61 %loadN = load i64, ptr %allocaN, align 8 %sub = sub i64 0, %loadN store i64 %sub, ptr %allocaN, align 8 - br label %if.merge.62 + br label %if.merge.63 -if.merge.62: ; preds = %if.then.61, %if.merge.60 +if.merge.63: ; preds = %if.then.62, %if.merge.61 %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_string(ptr %0, i64 %loadN) %allocaN = alloca { ptr, i64 }, align 8 @@ -506,16 +506,16 @@ if.merge.62: ; preds = %if.then.61, %if.mer %allocaN = alloca i64, align 8 store i64 %lenN, ptr %allocaN, align 8 %loadN = load i1, ptr %allocaN, align 1 - br i1 %loadN, label %if.then.63, label %if.else.64 + br i1 %loadN, label %if.then.64, label %if.else.65 -if.then.63: ; preds = %if.merge.62 - br label %if.merge.65 +if.then.64: ; preds = %if.merge.63 + br label %if.merge.66 -if.else.64: ; preds = %if.merge.62 - br label %if.merge.65 +if.else.65: ; preds = %if.merge.63 + br label %if.merge.66 -if.merge.65: ; preds = %if.else.64, %if.then.63 - %bpN = phi i64 [ 1, %if.then.63 ], [ 0, %if.else.64 ] +if.merge.66: ; preds = %if.else.65, %if.then.64 + %bpN = phi i64 [ 1, %if.then.64 ], [ 0, %if.else.65 ] %allocaN = alloca i64, align 8 store i64 %bpN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -532,17 +532,17 @@ if.merge.65: ; preds = %if.else.64, %if.the %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 %loadN = load i1, ptr %allocaN, align 1 - br i1 %loadN, label %if.then.66, label %if.merge.67 + br i1 %loadN, label %if.then.67, label %if.merge.68 -if.then.66: ; preds = %if.merge.65 +if.then.67: ; preds = %if.merge.66 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %igp.data = extractvalue { ptr, i64 } %loadN, 0 %igp.ptr = getelementptr i8, ptr %igp.data, i64 0 store i8 45, ptr %igp.ptr, align 1 store i64 1, ptr %allocaN, align 8 - br label %if.merge.67 + br label %if.merge.68 -if.merge.67: ; preds = %if.then.66, %if.merge.65 +if.merge.68: ; preds = %if.then.67, %if.merge.66 %loadN = load i64, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %igp.data41 = extractvalue { ptr, i64 } %loadN, 0 @@ -605,39 +605,39 @@ entry: %loadN = load i64, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 %loadN, ptr %allocaN, align 8 - br label %while.hdr.200 + br label %while.hdr.201 -while.hdr.200: ; preds = %if.merge.205, %entry +while.hdr.201: ; preds = %if.merge.206, %entry %loadN = load i64, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %icmp = icmp sge i64 %loadN, %loadN - br i1 %icmp, label %while.body.201, label %while.exit.202 + br i1 %icmp, label %while.body.202, label %while.exit.203 -while.body.201: ; preds = %while.hdr.200 +while.body.202: ; preds = %while.hdr.201 %loadN = load i64, ptr %allocaN, align 8 %srem = srem i64 %loadN, 16 %allocaN = alloca i64, align 8 store i64 %srem, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %icmpN = icmp slt i64 %loadN, 10 - br i1 %icmpN, label %if.then.203, label %if.else.204 + br i1 %icmpN, label %if.then.204, label %if.else.205 -while.exit.202: ; preds = %while.hdr.200 +while.exit.203: ; preds = %while.hdr.201 ret void -if.then.203: ; preds = %while.body.201 +if.then.204: ; preds = %while.body.202 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 48 - br label %if.merge.205 + br label %if.merge.206 -if.else.204: ; preds = %while.body.201 +if.else.205: ; preds = %while.body.202 %loadN = load i64, ptr %allocaN, align 8 %sub = sub i64 %loadN, 10 %addN = add i64 %sub, 97 - br label %if.merge.205 + br label %if.merge.206 -if.merge.205: ; preds = %if.else.204, %if.then.203 - %bp = phi i64 [ %addN, %if.then.203 ], [ %addN, %if.else.204 ] +if.merge.206: ; preds = %if.else.205, %if.then.204 + %bp = phi i64 [ %addN, %if.then.204 ], [ %addN, %if.else.205 ] %loadN = load i64, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %alloca, align 8 %igp.data = extractvalue { ptr, i64 } %loadN, 0 @@ -650,7 +650,7 @@ if.merge.205: ; preds = %if.else.204, %if.th %loadN = load i64, ptr %allocaN, align 8 %subN = sub i64 %loadN, 1 store i64 %subN, ptr %allocaN, align 8 - br label %while.hdr.200 + br label %while.hdr.201 } ; Function Attrs: nounwind @@ -660,27 +660,27 @@ entry: store i64 %1, ptr %alloca, align 8 %load = load i64, ptr %alloca, align 8 %icmp = icmp eq i64 %load, 0 - br i1 %icmp, label %if.then.190, label %if.merge.191 + br i1 %icmp, label %if.then.191, label %if.merge.192 -if.then.190: ; preds = %entry +if.then.191: ; preds = %entry ret { ptr, i64 } { ptr @str.3, i64 1 } -if.merge.191: ; preds = %entry +if.merge.192: ; preds = %entry %loadN = load i64, ptr %alloca, align 8 %srem = srem i64 %loadN, 65536 %allocaN = alloca i64, align 8 store i64 %srem, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %icmpN = icmp slt i64 %loadN, 0 - br i1 %icmpN, label %if.then.192, label %if.merge.193 + br i1 %icmpN, label %if.then.193, label %if.merge.194 -if.then.192: ; preds = %if.merge.191 +if.then.193: ; preds = %if.merge.192 %loadN = load i64, ptr %allocaN, align 8 %add = add i64 %loadN, 65536 store i64 %add, ptr %allocaN, align 8 - br label %if.merge.193 + br label %if.merge.194 -if.merge.193: ; preds = %if.then.192, %if.merge.191 +if.merge.194: ; preds = %if.then.193, %if.merge.192 %loadN = load i64, ptr %alloca, align 8 %loadN = load i64, ptr %allocaN, align 8 %sub = sub i64 %loadN, %loadN @@ -693,15 +693,15 @@ if.merge.193: ; preds = %if.then.192, %if.me store i64 %sremN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %icmpN = icmp slt i64 %loadN, 0 - br i1 %icmpN, label %if.then.194, label %if.merge.195 + br i1 %icmpN, label %if.then.195, label %if.merge.196 -if.then.194: ; preds = %if.merge.193 +if.then.195: ; preds = %if.merge.194 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 65536 store i64 %addN, ptr %allocaN, align 8 - br label %if.merge.195 + br label %if.merge.196 -if.merge.195: ; preds = %if.then.194, %if.merge.193 +if.merge.196: ; preds = %if.then.195, %if.merge.194 %loadN = load i64, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %subN = sub i64 %loadN, %loadN @@ -714,15 +714,15 @@ if.merge.195: ; preds = %if.then.194, %if.me store i64 %sremN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %icmpN = icmp slt i64 %loadN, 0 - br i1 %icmpN, label %if.then.196, label %if.merge.197 + br i1 %icmpN, label %if.then.197, label %if.merge.198 -if.then.196: ; preds = %if.merge.195 +if.then.197: ; preds = %if.merge.196 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 65536 store i64 %addN, ptr %allocaN, align 8 - br label %if.merge.197 + br label %if.merge.198 -if.merge.197: ; preds = %if.then.196, %if.merge.195 +if.merge.198: ; preds = %if.then.197, %if.merge.196 %loadN = load i64, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %subN = sub i64 %loadN, %loadN @@ -735,15 +735,15 @@ if.merge.197: ; preds = %if.then.196, %if.me store i64 %sremN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %icmpN = icmp slt i64 %loadN, 0 - br i1 %icmpN, label %if.then.198, label %if.merge.199 + br i1 %icmpN, label %if.then.199, label %if.merge.200 -if.then.198: ; preds = %if.merge.197 +if.then.199: ; preds = %if.merge.198 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 65536 store i64 %addN, ptr %allocaN, align 8 - br label %if.merge.199 + br label %if.merge.200 -if.merge.199: ; preds = %if.then.198, %if.merge.197 +if.merge.200: ; preds = %if.then.199, %if.merge.198 %call = call { ptr, i64 } @cstring(ptr %0, i64 16) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 @@ -761,14 +761,14 @@ if.merge.199: ; preds = %if.then.198, %if.me call void @hex_group(ptr %0, { ptr, i64 } %loadN, i64 12, i64 %loadN) %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 - br label %while.hdr.206 + br label %while.hdr.207 -while.hdr.206: ; preds = %if.merge.210, %if.merge.199 +while.hdr.207: ; preds = %if.merge.211, %if.merge.200 %loadN = load i64, ptr %allocaN, align 8 %icmpN = icmp slt i64 %loadN, 15 - br i1 %icmpN, label %while.body.207, label %while.exit.208 + br i1 %icmpN, label %while.body.208, label %while.exit.209 -while.body.207: ; preds = %while.hdr.206 +while.body.208: ; preds = %while.hdr.207 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %ig.data = extractvalue { ptr, i64 } %loadN, 0 @@ -776,9 +776,9 @@ while.body.207: ; preds = %while.hdr.206 %ig.val = load i8, ptr %ig.ptr, align 1 %cmp.ext = zext i8 %ig.val to i64 %icmpN = icmp ne i64 %cmp.ext, 48 - br i1 %icmpN, label %if.then.209, label %if.merge.210 + br i1 %icmpN, label %if.then.210, label %if.merge.211 -while.exit.208: ; preds = %if.then.209, %while.hdr.206 +while.exit.209: ; preds = %if.then.210, %while.hdr.207 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -786,14 +786,14 @@ while.exit.208: ; preds = %if.then.209, %while %callN = call { ptr, i64 } @substr(ptr %0, { ptr, i64 } %loadN, i64 %loadN, i64 %subN) ret { ptr, i64 } %callN -if.then.209: ; preds = %while.body.207 - br label %while.exit.208 +if.then.210: ; preds = %while.body.208 + br label %while.exit.209 -if.merge.210: ; preds = %while.body.207 +if.merge.211: ; preds = %while.body.208 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 1 store i64 %addN, ptr %allocaN, align 8 - br label %while.hdr.206 + br label %while.hdr.207 } ; Function Attrs: nounwind @@ -878,7 +878,7 @@ entry: %allocaN = alloca i64, align 8 store i64 %sg, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - switch i64 %loadN, label %match.unr.51 [ + switch i64 %loadN, label %match.unr.52 [ i64 0, label %match.arm.39 i64 2, label %match.arm.40 i64 3, label %match.arm.40 @@ -929,10 +929,10 @@ entry: i64 50, label %match.arm.49 i64 51, label %match.arm.49 i64 53, label %match.arm.49 - i64 13, label %match.arm.50 + i64 13, label %match.arm.51 ] -match.merge.38: ; preds = %dispatch.merge.166, %dispatch.merge.152, %dispatch.merge.138, %dispatch.merge.130, %dispatch.merge.68, %float.merge.57, %match.unr.51, %match.arm.50, %match.arm.42, %match.arm.41, %match.arm.40, %match.arm.39 +match.merge.38: ; preds = %dispatch.merge.167, %dispatch.merge.153, %dispatch.merge.139, %dispatch.merge.131, %dispatch.merge.69, %float.merge.58, %match.unr.52, %match.arm.51, %match.arm.42, %match.arm.41, %match.arm.40, %match.arm.39 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 ret { ptr, i64 } %loadN @@ -971,32 +971,32 @@ match.arm.43: ; preds = %entry, %entry %allocaN = alloca double, align 8 %sgN = extractvalue { i64, i64 } %loadN, 0 %icmp = icmp eq i64 %sgN, 10 - br i1 %icmp, label %fN.unbox.55, label %fN.unbox.56 + br i1 %icmp, label %fN.unbox.56, label %fN.unbox.57 match.arm.44: ; preds = %entry, %entry, %entry, %entry, %entry, %entry, %entry, %entry, %entry, %entry %loadN = load i64, ptr %allocaN, align 8 %loadN = load { i64, i64 }, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - switch i64 %loadN, label %dispatch.default.69 [ - i64 18, label %dispatch.case.70 - i64 19, label %dispatch.case.71 - i64 21, label %dispatch.case.72 - i64 23, label %dispatch.case.73 - i64 25, label %dispatch.case.74 - i64 28, label %dispatch.case.75 - i64 30, label %dispatch.case.76 - i64 32, label %dispatch.case.77 - i64 36, label %dispatch.case.78 - i64 39, label %dispatch.case.79 + switch i64 %loadN, label %dispatch.default.70 [ + i64 18, label %dispatch.case.71 + i64 19, label %dispatch.case.72 + i64 21, label %dispatch.case.73 + i64 23, label %dispatch.case.74 + i64 25, label %dispatch.case.75 + i64 28, label %dispatch.case.76 + i64 30, label %dispatch.case.77 + i64 32, label %dispatch.case.78 + i64 36, label %dispatch.case.79 + i64 39, label %dispatch.case.80 ] match.arm.45: ; preds = %entry, %entry %loadN = load i64, ptr %allocaN, align 8 %loadN = load { i64, i64 }, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - switch i64 %loadN, label %dispatch.default.131 [ - i64 34, label %dispatch.case.132 - i64 35, label %dispatch.case.133 + switch i64 %loadN, label %dispatch.default.132 [ + i64 34, label %dispatch.case.133 + i64 35, label %dispatch.case.134 ] match.arm.46: ; No predecessors! @@ -1006,47 +1006,50 @@ match.arm.47: ; preds = %entry, %entry %loadN = load i64, ptr %allocaN, align 8 %loadN = load { i64, i64 }, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - switch i64 %loadN, label %dispatch.default.139 [ - i64 45, label %dispatch.case.140 - i64 52, label %dispatch.case.141 + switch i64 %loadN, label %dispatch.default.140 [ + i64 45, label %dispatch.case.141 + i64 52, label %dispatch.case.142 ] match.arm.48: ; preds = %entry, %entry %loadN = load i64, ptr %allocaN, align 8 %loadN = load { i64, i64 }, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - switch i64 %loadN, label %dispatch.default.153 [ - i64 33, label %dispatch.case.154 - i64 44, label %dispatch.case.155 + switch i64 %loadN, label %dispatch.default.154 [ + i64 33, label %dispatch.case.155 + i64 44, label %dispatch.case.156 ] match.arm.49: ; preds = %entry, %entry, %entry, %entry, %entry, %entry, %entry, %entry, %entry, %entry, %entry, %entry, %entry, %entry, %entry, %entry, %entry, %entry, %entry %loadN = load i64, ptr %allocaN, align 8 %loadN = load { i64, i64 }, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - switch i64 %loadN, label %dispatch.default.167 [ - i64 17, label %dispatch.case.168 - i64 20, label %dispatch.case.169 - i64 22, label %dispatch.case.170 - i64 24, label %dispatch.case.171 - i64 26, label %dispatch.case.172 - i64 27, label %dispatch.case.173 - i64 29, label %dispatch.case.174 - i64 31, label %dispatch.case.175 - i64 40, label %dispatch.case.176 - i64 41, label %dispatch.case.177 - i64 42, label %dispatch.case.178 - i64 43, label %dispatch.case.179 - i64 46, label %dispatch.case.180 - i64 47, label %dispatch.case.181 - i64 48, label %dispatch.case.182 - i64 49, label %dispatch.case.183 - i64 50, label %dispatch.case.184 - i64 51, label %dispatch.case.185 - i64 53, label %dispatch.case.186 + switch i64 %loadN, label %dispatch.default.168 [ + i64 17, label %dispatch.case.169 + i64 20, label %dispatch.case.170 + i64 22, label %dispatch.case.171 + i64 24, label %dispatch.case.172 + i64 26, label %dispatch.case.173 + i64 27, label %dispatch.case.174 + i64 29, label %dispatch.case.175 + i64 31, label %dispatch.case.176 + i64 40, label %dispatch.case.177 + i64 41, label %dispatch.case.178 + i64 42, label %dispatch.case.179 + i64 43, label %dispatch.case.180 + i64 46, label %dispatch.case.181 + i64 47, label %dispatch.case.182 + i64 48, label %dispatch.case.183 + i64 49, label %dispatch.case.184 + i64 50, label %dispatch.case.185 + i64 51, label %dispatch.case.186 + i64 53, label %dispatch.case.187 ] -match.arm.50: ; preds = %entry +match.arm.50: ; No predecessors! + unreachable + +match.arm.51: ; preds = %entry %allocaN = alloca { ptr, i64 }, align 8 %loadN = load { i64, i64 }, ptr %alloca, align 8 %ua.raw33 = extractvalue { i64, i64 } %loadN, 1 @@ -1057,330 +1060,330 @@ match.arm.50: ; preds = %entry store { ptr, i64 } %loadN, ptr %allocaN, align 8 br label %match.merge.38 -match.unr.51: ; preds = %entry +match.unr.52: ; preds = %entry br label %match.merge.38 -f32.unbox.55: ; preds = %match.arm.43 +f32.unbox.56: ; preds = %match.arm.43 %ua.raw37 = extractvalue { i64, i64 } %loadN, 1 %trN = trunc i64 %ua.raw37 to i32 %iNf = bitcast i32 %trN to float %fpext = fpext float %iNf to double store double %fpext, ptr %allocaN, align 8 - br label %float.merge.57 + br label %float.merge.58 -f64.unbox.56: ; preds = %match.arm.43 +f64.unbox.57: ; preds = %match.arm.43 %ua.raw38 = extractvalue { i64, i64 } %loadN, 1 %iNd = bitcast i64 %ua.raw38 to double store double %iNd, ptr %allocaN, align 8 - br label %float.merge.57 + br label %float.merge.58 -float.merge.57: ; preds = %fN.unbox.56, %fN.unbox.55 +float.merge.58: ; preds = %fN.unbox.57, %fN.unbox.56 %loadN = load double, ptr %allocaN, align 8 %callN = call { ptr, i64 } @float_to_string(ptr %0, double %loadN) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %match.merge.38 -dispatch.merge.68: ; preds = %dispatch.case.79, %dispatch.case.78, %dispatch.case.77, %dispatch.case.76, %dispatch.case.75, %dispatch.case.74, %dispatch.case.73, %dispatch.case.72, %dispatch.case.71, %dispatch.case.70, %dispatch.default.69 +dispatch.merge.69: ; preds = %dispatch.case.80, %dispatch.case.79, %dispatch.case.78, %dispatch.case.77, %dispatch.case.76, %dispatch.case.75, %dispatch.case.74, %dispatch.case.73, %dispatch.case.72, %dispatch.case.71, %dispatch.default.70 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 store { ptr, i64 } %loadN, ptr %allocaN, align 8 br label %match.merge.38 -dispatch.default.69: ; preds = %match.arm.44 +dispatch.default.70: ; preds = %match.arm.44 store { ptr, i64 } { ptr @str.6, i64 0 }, ptr %allocaN, align 8 - br label %dispatch.merge.68 + br label %dispatch.merge.69 -dispatch.case.70: ; preds = %match.arm.44 +dispatch.case.71: ; preds = %match.arm.44 %ua.raw42 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr43 = inttoptr i64 %ua.raw42 to ptr %ua.load44 = load { ptr, ptr, ptr }, ptr %ua.ptr43, align 8 %callN = call { ptr, i64 } @struct_to_string__Allocator(ptr %0, { ptr, ptr, ptr } %ua.load44) store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %dispatch.merge.68 + br label %dispatch.merge.69 -dispatch.case.71: ; preds = %match.arm.44 +dispatch.case.72: ; preds = %match.arm.44 %ua.raw46 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr47 = inttoptr i64 %ua.raw46 to ptr %ua.load48 = load {}, ptr %ua.ptr47, align 1 %callN = call { ptr, i64 } @struct_to_string__CAllocator(ptr %0, {} %ua.load48) store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %dispatch.merge.68 + br label %dispatch.merge.69 -dispatch.case.72: ; preds = %match.arm.44 +dispatch.case.73: ; preds = %match.arm.44 %ua.raw50 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr51 = inttoptr i64 %ua.raw50 to ptr %ua.load52 = load { i64 }, ptr %ua.ptr51, align 8 %callN = call { ptr, i64 } @struct_to_string__GPA(ptr %0, { i64 } %ua.load52) store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %dispatch.merge.68 + br label %dispatch.merge.69 -dispatch.case.73: ; preds = %match.arm.44 +dispatch.case.74: ; preds = %match.arm.44 %ua.raw54 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr55 = inttoptr i64 %ua.raw54 to ptr %ua.load56 = load { ptr, i64 }, ptr %ua.ptr55, align 8 %callN = call { ptr, i64 } @struct_to_string__ArenaChunk(ptr %0, { ptr, i64 } %ua.load56) store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %dispatch.merge.68 + br label %dispatch.merge.69 -dispatch.case.74: ; preds = %match.arm.44 +dispatch.case.75: ; preds = %match.arm.44 %ua.raw58 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr59 = inttoptr i64 %ua.raw58 to ptr %ua.load60 = load { ptr, i64, { ptr, ptr, ptr } }, ptr %ua.ptr59, align 8 %callN = call { ptr, i64 } @struct_to_string__Arena(ptr %0, { ptr, i64, { ptr, ptr, ptr } } %ua.load60) store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %dispatch.merge.68 + br label %dispatch.merge.69 -dispatch.case.75: ; preds = %match.arm.44 +dispatch.case.76: ; preds = %match.arm.44 %ua.raw62 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr63 = inttoptr i64 %ua.raw62 to ptr %ua.load64 = load { ptr, i64, i64 }, ptr %ua.ptr63, align 8 %callN = call { ptr, i64 } @struct_to_string__BufAlloc(ptr %0, { ptr, i64, i64 } %ua.load64) store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %dispatch.merge.68 + br label %dispatch.merge.69 -dispatch.case.76: ; preds = %match.arm.44 +dispatch.case.77: ; preds = %match.arm.44 %ua.raw66 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr67 = inttoptr i64 %ua.raw66 to ptr %ua.load68 = load { { ptr, ptr, ptr }, i64, i64, i64 }, ptr %ua.ptr67, align 8 %callN = call { ptr, i64 } @struct_to_string__TrackingAllocator(ptr %0, { { ptr, ptr, ptr }, i64, i64, i64 } %ua.load68) store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %dispatch.merge.68 + br label %dispatch.merge.69 -dispatch.case.77: ; preds = %match.arm.44 +dispatch.case.78: ; preds = %match.arm.44 %ua.raw70 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr71 = inttoptr i64 %ua.raw70 to ptr %ua.load72 = load { { ptr, ptr, ptr }, ptr }, ptr %ua.ptr71, align 8 %callN = call { ptr, i64 } @struct_to_string__Context(ptr %0, { { ptr, ptr, ptr }, ptr } %ua.load72) store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %dispatch.merge.68 + br label %dispatch.merge.69 -dispatch.case.78: ; preds = %match.arm.44 +dispatch.case.79: ; preds = %match.arm.44 %ua.raw74 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr75 = inttoptr i64 %ua.raw74 to ptr %ua.load76 = load {}, ptr %ua.ptr75, align 1 %callN = call { ptr, i64 } @struct_to_string__BuildOptions(ptr %0, {} %ua.load76) store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %dispatch.merge.68 + br label %dispatch.merge.69 -dispatch.case.79: ; preds = %match.arm.44 +dispatch.case.80: ; preds = %match.arm.44 %ua.raw78 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr79 = inttoptr i64 %ua.raw78 to ptr %ua.load80 = load { i64, i64, i64 }, ptr %ua.ptr79, align 8 %callN = call { ptr, i64 } @struct_to_string__Triple(ptr %0, { i64, i64, i64 } %ua.load80) store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %dispatch.merge.68 + br label %dispatch.merge.69 -dispatch.merge.130: ; preds = %dispatch.case.133, %dispatch.case.132, %dispatch.default.131 +dispatch.merge.131: ; preds = %dispatch.case.134, %dispatch.case.133, %dispatch.default.132 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 store { ptr, i64 } %loadN, ptr %allocaN, align 8 br label %match.merge.38 -dispatch.default.131: ; preds = %match.arm.45 +dispatch.default.132: ; preds = %match.arm.45 store { ptr, i64 } { ptr @str.7, i64 0 }, ptr %allocaN, align 8 - br label %dispatch.merge.130 + br label %dispatch.merge.131 -dispatch.case.132: ; preds = %match.arm.45 +dispatch.case.133: ; preds = %match.arm.45 %ua.raw83 = extractvalue { i64, i64 } %loadN, 1 %callN = call { ptr, i64 } @enum_to_string__OperatingSystem(ptr %0, i64 %ua.raw83) store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %dispatch.merge.130 + br label %dispatch.merge.131 -dispatch.case.133: ; preds = %match.arm.45 +dispatch.case.134: ; preds = %match.arm.45 %ua.raw85 = extractvalue { i64, i64 } %loadN, 1 %callN = call { ptr, i64 } @enum_to_string__Architecture(ptr %0, i64 %ua.raw85) store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %dispatch.merge.130 + br label %dispatch.merge.131 -dispatch.merge.138: ; preds = %dispatch.case.141, %dispatch.case.140, %dispatch.default.139 +dispatch.merge.139: ; preds = %dispatch.case.142, %dispatch.case.141, %dispatch.default.140 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 store { ptr, i64 } %loadN, ptr %allocaN, align 8 br label %match.merge.38 -dispatch.default.139: ; preds = %match.arm.47 +dispatch.default.140: ; preds = %match.arm.47 store { ptr, i64 } { ptr @str.8, i64 0 }, ptr %allocaN, align 8 - br label %dispatch.merge.138 + br label %dispatch.merge.139 -dispatch.case.140: ; preds = %match.arm.47 +dispatch.case.141: ; preds = %match.arm.47 %ua.raw88 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr89 = inttoptr i64 %ua.raw88 to ptr %ua.load90 = load [1 x { i64, i64 }], ptr %ua.ptr89, align 8 %callN = call { ptr, i64 } @array_to_string__AR_1_Any(ptr %0, [1 x { i64, i64 }] %ua.load90) store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %dispatch.merge.138 + br label %dispatch.merge.139 -dispatch.case.141: ; preds = %match.arm.47 +dispatch.case.142: ; preds = %match.arm.47 %ua.raw92 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr93 = inttoptr i64 %ua.raw92 to ptr %ua.load94 = load [3 x { i64, i64 }], ptr %ua.ptr93, align 8 %callN = call { ptr, i64 } @array_to_string__AR_3_Any(ptr %0, [3 x { i64, i64 }] %ua.load94) store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %dispatch.merge.138 + br label %dispatch.merge.139 -dispatch.merge.152: ; preds = %dispatch.case.155, %dispatch.case.154, %dispatch.default.153 +dispatch.merge.153: ; preds = %dispatch.case.156, %dispatch.case.155, %dispatch.default.154 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 store { ptr, i64 } %loadN, ptr %allocaN, align 8 br label %match.merge.38 -dispatch.default.153: ; preds = %match.arm.48 +dispatch.default.154: ; preds = %match.arm.48 store { ptr, i64 } { ptr @str.9, i64 0 }, ptr %allocaN, align 8 - br label %dispatch.merge.152 + br label %dispatch.merge.153 -dispatch.case.154: ; preds = %match.arm.48 +dispatch.case.155: ; preds = %match.arm.48 %ua.raw97 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr98 = inttoptr i64 %ua.raw97 to ptr %ua.load99 = load { ptr, i64 }, ptr %ua.ptr98, align 8 %callN = call { ptr, i64 } @slice_to_string__string(ptr %0, { ptr, i64 } %ua.load99) store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %dispatch.merge.152 + br label %dispatch.merge.153 -dispatch.case.155: ; preds = %match.arm.48 +dispatch.case.156: ; preds = %match.arm.48 %ua.raw101 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr102 = inttoptr i64 %ua.raw101 to ptr %ua.load103 = load { ptr, i64 }, ptr %ua.ptr102, align 8 %callN = call { ptr, i64 } @slice_to_string__Any(ptr %0, { ptr, i64 } %ua.load103) store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %dispatch.merge.152 + br label %dispatch.merge.153 -dispatch.merge.166: ; preds = %dispatch.case.186, %dispatch.case.185, %dispatch.case.184, %dispatch.case.183, %dispatch.case.182, %dispatch.case.181, %dispatch.case.180, %dispatch.case.179, %dispatch.case.178, %dispatch.case.177, %dispatch.case.176, %dispatch.case.175, %dispatch.case.174, %dispatch.case.173, %dispatch.case.172, %dispatch.case.171, %dispatch.case.170, %dispatch.case.169, %dispatch.case.168, %dispatch.default.167 +dispatch.merge.167: ; preds = %dispatch.case.187, %dispatch.case.186, %dispatch.case.185, %dispatch.case.184, %dispatch.case.183, %dispatch.case.182, %dispatch.case.181, %dispatch.case.180, %dispatch.case.179, %dispatch.case.178, %dispatch.case.177, %dispatch.case.176, %dispatch.case.175, %dispatch.case.174, %dispatch.case.173, %dispatch.case.172, %dispatch.case.171, %dispatch.case.170, %dispatch.case.169, %dispatch.default.168 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 store { ptr, i64 } %loadN, ptr %allocaN, align 8 br label %match.merge.38 -dispatch.default.167: ; preds = %match.arm.49 +dispatch.default.168: ; preds = %match.arm.49 store { ptr, i64 } { ptr @str.10, i64 0 }, ptr %allocaN, align 8 - br label %dispatch.merge.166 + br label %dispatch.merge.167 -dispatch.case.168: ; preds = %match.arm.49 +dispatch.case.169: ; preds = %match.arm.49 %ua.raw106 = extractvalue { i64, i64 } %loadN, 1 %iNp = inttoptr i64 %ua.raw106 to ptr %callN = call { ptr, i64 } @pointer_to_string__ptr_void(ptr %0, ptr %iNp) store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %dispatch.merge.166 + br label %dispatch.merge.167 -dispatch.case.169: ; preds = %match.arm.49 +dispatch.case.170: ; preds = %match.arm.49 %ua.raw108 = extractvalue { i64, i64 } %loadN, 1 %iNp109 = inttoptr i64 %ua.raw108 to ptr %callN = call { ptr, i64 } @pointer_to_string__ptr_CAllocator(ptr %0, ptr %iNp109) store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %dispatch.merge.166 + br label %dispatch.merge.167 -dispatch.case.170: ; preds = %match.arm.49 +dispatch.case.171: ; preds = %match.arm.49 %ua.raw111 = extractvalue { i64, i64 } %loadN, 1 %iNp112 = inttoptr i64 %ua.raw111 to ptr %callN = call { ptr, i64 } @pointer_to_string__ptr_GPA(ptr %0, ptr %iNp112) store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %dispatch.merge.166 + br label %dispatch.merge.167 -dispatch.case.171: ; preds = %match.arm.49 +dispatch.case.172: ; preds = %match.arm.49 %ua.raw114 = extractvalue { i64, i64 } %loadN, 1 %iNp115 = inttoptr i64 %ua.raw114 to ptr %callN = call { ptr, i64 } @pointer_to_string__ptr_ArenaChunk(ptr %0, ptr %iNp115) store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %dispatch.merge.166 + br label %dispatch.merge.167 -dispatch.case.172: ; preds = %match.arm.49 +dispatch.case.173: ; preds = %match.arm.49 %ua.raw117 = extractvalue { i64, i64 } %loadN, 1 %iNp118 = inttoptr i64 %ua.raw117 to ptr %callN = call { ptr, i64 } @pointer_to_string__ptr_Arena(ptr %0, ptr %iNp118) store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %dispatch.merge.166 + br label %dispatch.merge.167 -dispatch.case.173: ; preds = %match.arm.49 +dispatch.case.174: ; preds = %match.arm.49 %ua.raw120 = extractvalue { i64, i64 } %loadN, 1 %iNp121 = inttoptr i64 %ua.raw120 to ptr %callN = call { ptr, i64 } @pointer_to_string__mptr_u8(ptr %0, ptr %iNp121) store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %dispatch.merge.166 + br label %dispatch.merge.167 -dispatch.case.174: ; preds = %match.arm.49 +dispatch.case.175: ; preds = %match.arm.49 %ua.raw123 = extractvalue { i64, i64 } %loadN, 1 %iNp124 = inttoptr i64 %ua.raw123 to ptr %callN = call { ptr, i64 } @pointer_to_string__ptr_BufAlloc(ptr %0, ptr %iNp124) store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %dispatch.merge.166 + br label %dispatch.merge.167 -dispatch.case.175: ; preds = %match.arm.49 +dispatch.case.176: ; preds = %match.arm.49 %ua.raw126 = extractvalue { i64, i64 } %loadN, 1 %iNp127 = inttoptr i64 %ua.raw126 to ptr %callN = call { ptr, i64 } @pointer_to_string__ptr_TrackingAllocator(ptr %0, ptr %iNp127) store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %dispatch.merge.166 + br label %dispatch.merge.167 -dispatch.case.176: ; preds = %match.arm.49 +dispatch.case.177: ; preds = %match.arm.49 %ua.raw129 = extractvalue { i64, i64 } %loadN, 1 %iNp130 = inttoptr i64 %ua.raw129 to ptr %callN = call { ptr, i64 } @pointer_to_string__ptr_ptr_CAllocator(ptr %0, ptr %iNp130) store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %dispatch.merge.166 + br label %dispatch.merge.167 -dispatch.case.177: ; preds = %match.arm.49 +dispatch.case.178: ; preds = %match.arm.49 %ua.raw132 = extractvalue { i64, i64 } %loadN, 1 %iNp133 = inttoptr i64 %ua.raw132 to ptr %callN = call { ptr, i64 } @pointer_to_string__ptr_s64(ptr %0, ptr %iNp133) store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %dispatch.merge.166 + br label %dispatch.merge.167 -dispatch.case.178: ; preds = %match.arm.49 +dispatch.case.179: ; preds = %match.arm.49 %ua.raw135 = extractvalue { i64, i64 } %loadN, 1 %iNp136 = inttoptr i64 %ua.raw135 to ptr %callN = call { ptr, i64 } @pointer_to_string__ptr_ptr_void(ptr %0, ptr %iNp136) store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %dispatch.merge.166 + br label %dispatch.merge.167 -dispatch.case.179: ; preds = %match.arm.49 +dispatch.case.180: ; preds = %match.arm.49 %ua.raw138 = extractvalue { i64, i64 } %loadN, 1 %iNp139 = inttoptr i64 %ua.raw138 to ptr %callN = call { ptr, i64 } @pointer_to_string__ptr_bool(ptr %0, ptr %iNp139) store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %dispatch.merge.166 + br label %dispatch.merge.167 -dispatch.case.180: ; preds = %match.arm.49 +dispatch.case.181: ; preds = %match.arm.49 %ua.raw141 = extractvalue { i64, i64 } %loadN, 1 %iNp142 = inttoptr i64 %ua.raw141 to ptr %callN = call { ptr, i64 } @pointer_to_string__ptr_AR_1_Any(ptr %0, ptr %iNp142) store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %dispatch.merge.166 + br label %dispatch.merge.167 -dispatch.case.181: ; preds = %match.arm.49 +dispatch.case.182: ; preds = %match.arm.49 %ua.raw144 = extractvalue { i64, i64 } %loadN, 1 %iNp145 = inttoptr i64 %ua.raw144 to ptr %callN = call { ptr, i64 } @pointer_to_string__ptr_Any(ptr %0, ptr %iNp145) store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %dispatch.merge.166 + br label %dispatch.merge.167 -dispatch.case.182: ; preds = %match.arm.49 +dispatch.case.183: ; preds = %match.arm.49 %ua.raw147 = extractvalue { i64, i64 } %loadN, 1 %iNp148 = inttoptr i64 %ua.raw147 to ptr %callN = call { ptr, i64 } @pointer_to_string__ptr_SL_Any(ptr %0, ptr %iNp148) store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %dispatch.merge.166 + br label %dispatch.merge.167 -dispatch.case.183: ; preds = %match.arm.49 +dispatch.case.184: ; preds = %match.arm.49 %ua.raw150 = extractvalue { i64, i64 } %loadN, 1 %iNp151 = inttoptr i64 %ua.raw150 to ptr %callN = call { ptr, i64 } @pointer_to_string__ptr_string(ptr %0, ptr %iNp151) store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %dispatch.merge.166 + br label %dispatch.merge.167 -dispatch.case.184: ; preds = %match.arm.49 +dispatch.case.185: ; preds = %match.arm.49 %ua.raw153 = extractvalue { i64, i64 } %loadN, 1 %iNp154 = inttoptr i64 %ua.raw153 to ptr %callN = call { ptr, i64 } @pointer_to_string__ptr_u8(ptr %0, ptr %iNp154) store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %dispatch.merge.166 + br label %dispatch.merge.167 -dispatch.case.185: ; preds = %match.arm.49 +dispatch.case.186: ; preds = %match.arm.49 %ua.raw156 = extractvalue { i64, i64 } %loadN, 1 %iNp157 = inttoptr i64 %ua.raw156 to ptr %callN = call { ptr, i64 } @pointer_to_string__ptr_Triple(ptr %0, ptr %iNp157) store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %dispatch.merge.166 + br label %dispatch.merge.167 -dispatch.case.186: ; preds = %match.arm.49 +dispatch.case.187: ; preds = %match.arm.49 %ua.raw159 = extractvalue { i64, i64 } %loadN, 1 %iNp160 = inttoptr i64 %ua.raw159 to ptr %callN = call { ptr, i64 } @pointer_to_string__ptr_AR_3_Any(ptr %0, ptr %iNp160) store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %dispatch.merge.166 + br label %dispatch.merge.167 } ; Function Attrs: nounwind @@ -2038,30 +2041,30 @@ entry: store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 - br label %while.hdr.80 + br label %while.hdr.81 -while.hdr.80: ; preds = %fv.merge, %entry +while.hdr.81: ; preds = %fv.merge, %entry %load = load i64, ptr %allocaN, align 8 %icmp = icmp slt i64 %load, 3 - br i1 %icmp, label %while.body.81, label %while.exit.82 + br i1 %icmp, label %while.body.82, label %while.exit.83 -while.body.81: ; preds = %while.hdr.80 +while.body.82: ; preds = %while.hdr.81 %loadN = load i64, ptr %allocaN, align 8 %icmpN = icmp sgt i64 %loadN, 0 - br i1 %icmpN, label %if.then.83, label %if.merge.84 + br i1 %icmpN, label %if.then.84, label %if.merge.85 -while.exit.82: ; preds = %while.hdr.80 +while.exit.83: ; preds = %while.hdr.81 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.38, i64 1 }) ret { ptr, i64 } %callN -if.then.83: ; preds = %while.body.81 +if.then.84: ; preds = %while.body.82 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.39, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %if.merge.84 + br label %if.merge.85 -if.merge.84: ; preds = %if.then.83, %while.body.81 +if.merge.85: ; preds = %if.then.84, %while.body.82 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names, i64 0, i64 %loadN @@ -2088,24 +2091,24 @@ fv.merge: ; preds = %fv.default, %fv.cas %loadN = load i64, ptr %allocaN, align 8 %add = add i64 %loadN, 1 store i64 %add, ptr %allocaN, align 8 - br label %while.hdr.80 + br label %while.hdr.81 -fv.default: ; preds = %if.merge.84 +fv.default: ; preds = %if.merge.85 br label %fv.merge -fv.case: ; preds = %if.merge.84 +fv.case: ; preds = %if.merge.85 %fv.field = extractvalue { ptr, ptr, ptr } %loadN, 0 %pNi = ptrtoint ptr %fv.field to i64 %fv.val = insertvalue { i64, i64 } { i64 17, i64 undef }, i64 %pNi, 1 br label %fv.merge -fv.case17: ; preds = %if.merge.84 +fv.case17: ; preds = %if.merge.85 %fv.field18 = extractvalue { ptr, ptr, ptr } %loadN, 1 %pNi19 = ptrtoint ptr %fv.field18 to i64 %fv.val20 = insertvalue { i64, i64 } { i64 17, i64 undef }, i64 %pNi19, 1 br label %fv.merge -fv.case21: ; preds = %if.merge.84 +fv.case21: ; preds = %if.merge.85 %fv.field22 = extractvalue { ptr, ptr, ptr } %loadN, 2 %pNi23 = ptrtoint ptr %fv.field22 to i64 %fv.val24 = insertvalue { i64, i64 } { i64 17, i64 undef }, i64 %pNi23, 1 @@ -2122,30 +2125,30 @@ entry: store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 - br label %while.hdr.85 + br label %while.hdr.86 -while.hdr.85: ; preds = %if.merge.89, %entry +while.hdr.86: ; preds = %if.merge.90, %entry %load = load i64, ptr %allocaN, align 8 %icmp = icmp slt i64 %load, 0 - br i1 %icmp, label %while.body.86, label %while.exit.87 + br i1 %icmp, label %while.body.87, label %while.exit.88 -while.body.86: ; preds = %while.hdr.85 +while.body.87: ; preds = %while.hdr.86 %loadN = load i64, ptr %allocaN, align 8 %icmpN = icmp sgt i64 %loadN, 0 - br i1 %icmpN, label %if.then.88, label %if.merge.89 + br i1 %icmpN, label %if.then.89, label %if.merge.90 -while.exit.87: ; preds = %while.hdr.85 +while.exit.88: ; preds = %while.hdr.86 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.45, i64 1 }) ret { ptr, i64 } %callN -if.then.88: ; preds = %while.body.86 +if.then.89: ; preds = %while.body.87 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.46, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %if.merge.89 + br label %if.merge.90 -if.merge.89: ; preds = %if.then.88, %while.body.86 +if.merge.90: ; preds = %if.then.89, %while.body.87 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %fn.gep = getelementptr inbounds [0 x { ptr, i64 }], ptr @field_names.47, i64 0, i64 %loadN @@ -2164,7 +2167,7 @@ if.merge.89: ; preds = %if.then.88, %while. %loadN = load i64, ptr %allocaN, align 8 %add = add i64 %loadN, 1 store i64 %add, ptr %allocaN, align 8 - br label %while.hdr.85 + br label %while.hdr.86 } ; Function Attrs: nounwind @@ -2177,30 +2180,30 @@ entry: store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 - br label %while.hdr.90 + br label %while.hdr.91 -while.hdr.90: ; preds = %fv.merge, %entry +while.hdr.91: ; preds = %fv.merge, %entry %load = load i64, ptr %allocaN, align 8 %icmp = icmp slt i64 %load, 1 - br i1 %icmp, label %while.body.91, label %while.exit.92 + br i1 %icmp, label %while.body.92, label %while.exit.93 -while.body.91: ; preds = %while.hdr.90 +while.body.92: ; preds = %while.hdr.91 %loadN = load i64, ptr %allocaN, align 8 %icmpN = icmp sgt i64 %loadN, 0 - br i1 %icmpN, label %if.then.93, label %if.merge.94 + br i1 %icmpN, label %if.then.94, label %if.merge.95 -while.exit.92: ; preds = %while.hdr.90 +while.exit.93: ; preds = %while.hdr.91 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.51, i64 1 }) ret { ptr, i64 } %callN -if.then.93: ; preds = %while.body.91 +if.then.94: ; preds = %while.body.92 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.52, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %if.merge.94 + br label %if.merge.95 -if.merge.94: ; preds = %if.then.93, %while.body.91 +if.merge.95: ; preds = %if.then.94, %while.body.92 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %fn.gep = getelementptr inbounds [1 x { ptr, i64 }], ptr @field_names.54, i64 0, i64 %loadN @@ -2225,12 +2228,12 @@ fv.merge: ; preds = %fv.default, %fv.cas %loadN = load i64, ptr %allocaN, align 8 %add = add i64 %loadN, 1 store i64 %add, ptr %allocaN, align 8 - br label %while.hdr.90 + br label %while.hdr.91 -fv.default: ; preds = %if.merge.94 +fv.default: ; preds = %if.merge.95 br label %fv.merge -fv.case: ; preds = %if.merge.94 +fv.case: ; preds = %if.merge.95 %fv.field = extractvalue { i64 } %loadN, 0 %fv.val = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field, 1 br label %fv.merge @@ -2246,30 +2249,30 @@ entry: store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 - br label %while.hdr.95 + br label %while.hdr.96 -while.hdr.95: ; preds = %fv.merge, %entry +while.hdr.96: ; preds = %fv.merge, %entry %load = load i64, ptr %allocaN, align 8 %icmp = icmp slt i64 %load, 2 - br i1 %icmp, label %while.body.96, label %while.exit.97 + br i1 %icmp, label %while.body.97, label %while.exit.98 -while.body.96: ; preds = %while.hdr.95 +while.body.97: ; preds = %while.hdr.96 %loadN = load i64, ptr %allocaN, align 8 %icmpN = icmp sgt i64 %loadN, 0 - br i1 %icmpN, label %if.then.98, label %if.merge.99 + br i1 %icmpN, label %if.then.99, label %if.merge.100 -while.exit.97: ; preds = %while.hdr.95 +while.exit.98: ; preds = %while.hdr.96 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.58, i64 1 }) ret { ptr, i64 } %callN -if.then.98: ; preds = %while.body.96 +if.then.99: ; preds = %while.body.97 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.59, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %if.merge.99 + br label %if.merge.100 -if.merge.99: ; preds = %if.then.98, %while.body.96 +if.merge.100: ; preds = %if.then.99, %while.body.97 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.62, i64 0, i64 %loadN @@ -2295,18 +2298,18 @@ fv.merge: ; preds = %fv.default, %fv.cas %loadN = load i64, ptr %allocaN, align 8 %add = add i64 %loadN, 1 store i64 %add, ptr %allocaN, align 8 - br label %while.hdr.95 + br label %while.hdr.96 -fv.default: ; preds = %if.merge.99 +fv.default: ; preds = %if.merge.100 br label %fv.merge -fv.case: ; preds = %if.merge.99 +fv.case: ; preds = %if.merge.100 %fv.field = extractvalue { ptr, i64 } %loadN, 0 %pNi = ptrtoint ptr %fv.field to i64 %fv.val = insertvalue { i64, i64 } { i64 24, i64 undef }, i64 %pNi, 1 br label %fv.merge -fv.case17: ; preds = %if.merge.99 +fv.case17: ; preds = %if.merge.100 %fv.field18 = extractvalue { ptr, i64 } %loadN, 1 %fv.val19 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field18, 1 br label %fv.merge @@ -2322,30 +2325,30 @@ entry: store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 - br label %while.hdr.100 + br label %while.hdr.101 -while.hdr.100: ; preds = %fv.merge, %entry +while.hdr.101: ; preds = %fv.merge, %entry %load = load i64, ptr %allocaN, align 8 %icmp = icmp slt i64 %load, 3 - br i1 %icmp, label %while.body.101, label %while.exit.102 + br i1 %icmp, label %while.body.102, label %while.exit.103 -while.body.101: ; preds = %while.hdr.100 +while.body.102: ; preds = %while.hdr.101 %loadN = load i64, ptr %allocaN, align 8 %icmpN = icmp sgt i64 %loadN, 0 - br i1 %icmpN, label %if.then.103, label %if.merge.104 + br i1 %icmpN, label %if.then.104, label %if.merge.105 -while.exit.102: ; preds = %while.hdr.100 +while.exit.103: ; preds = %while.hdr.101 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.66, i64 1 }) ret { ptr, i64 } %callN -if.then.103: ; preds = %while.body.101 +if.then.104: ; preds = %while.body.102 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.67, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %if.merge.104 + br label %if.merge.105 -if.merge.104: ; preds = %if.then.103, %while.body.101 +if.merge.105: ; preds = %if.then.104, %while.body.102 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.71, i64 0, i64 %loadN @@ -2372,23 +2375,23 @@ fv.merge: ; preds = %fv.default, %fv.cas %loadN = load i64, ptr %allocaN, align 8 %add = add i64 %loadN, 1 store i64 %add, ptr %allocaN, align 8 - br label %while.hdr.100 + br label %while.hdr.101 -fv.default: ; preds = %if.merge.104 +fv.default: ; preds = %if.merge.105 br label %fv.merge -fv.case: ; preds = %if.merge.104 +fv.case: ; preds = %if.merge.105 %fv.field = extractvalue { ptr, i64, { ptr, ptr, ptr } } %loadN, 0 %pNi = ptrtoint ptr %fv.field to i64 %fv.val = insertvalue { i64, i64 } { i64 24, i64 undef }, i64 %pNi, 1 br label %fv.merge -fv.case17: ; preds = %if.merge.104 +fv.case17: ; preds = %if.merge.105 %fv.field18 = extractvalue { ptr, i64, { ptr, ptr, ptr } } %loadN, 1 %fv.val19 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field18, 1 br label %fv.merge -fv.case20: ; preds = %if.merge.104 +fv.case20: ; preds = %if.merge.105 %fv.field21 = extractvalue { ptr, i64, { ptr, ptr, ptr } } %loadN, 2 %ba.tmp = alloca { ptr, ptr, ptr }, align 8 store { ptr, ptr, ptr } %fv.field21, ptr %ba.tmp, align 8 @@ -2407,30 +2410,30 @@ entry: store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 - br label %while.hdr.105 + br label %while.hdr.106 -while.hdr.105: ; preds = %fv.merge, %entry +while.hdr.106: ; preds = %fv.merge, %entry %load = load i64, ptr %allocaN, align 8 %icmp = icmp slt i64 %load, 3 - br i1 %icmp, label %while.body.106, label %while.exit.107 + br i1 %icmp, label %while.body.107, label %while.exit.108 -while.body.106: ; preds = %while.hdr.105 +while.body.107: ; preds = %while.hdr.106 %loadN = load i64, ptr %allocaN, align 8 %icmpN = icmp sgt i64 %loadN, 0 - br i1 %icmpN, label %if.then.108, label %if.merge.109 + br i1 %icmpN, label %if.then.109, label %if.merge.110 -while.exit.107: ; preds = %while.hdr.105 +while.exit.108: ; preds = %while.hdr.106 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.75, i64 1 }) ret { ptr, i64 } %callN -if.then.108: ; preds = %while.body.106 +if.then.109: ; preds = %while.body.107 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.76, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %if.merge.109 + br label %if.merge.110 -if.merge.109: ; preds = %if.then.108, %while.body.106 +if.merge.110: ; preds = %if.then.109, %while.body.107 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.80, i64 0, i64 %loadN @@ -2457,23 +2460,23 @@ fv.merge: ; preds = %fv.default, %fv.cas %loadN = load i64, ptr %allocaN, align 8 %add = add i64 %loadN, 1 store i64 %add, ptr %allocaN, align 8 - br label %while.hdr.105 + br label %while.hdr.106 -fv.default: ; preds = %if.merge.109 +fv.default: ; preds = %if.merge.110 br label %fv.merge -fv.case: ; preds = %if.merge.109 +fv.case: ; preds = %if.merge.110 %fv.field = extractvalue { ptr, i64, i64 } %loadN, 0 %pNi = ptrtoint ptr %fv.field to i64 %fv.val = insertvalue { i64, i64 } { i64 27, i64 undef }, i64 %pNi, 1 br label %fv.merge -fv.case17: ; preds = %if.merge.109 +fv.case17: ; preds = %if.merge.110 %fv.field18 = extractvalue { ptr, i64, i64 } %loadN, 1 %fv.val19 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field18, 1 br label %fv.merge -fv.case20: ; preds = %if.merge.109 +fv.case20: ; preds = %if.merge.110 %fv.field21 = extractvalue { ptr, i64, i64 } %loadN, 2 %fv.val22 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field21, 1 br label %fv.merge @@ -2489,30 +2492,30 @@ entry: store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 - br label %while.hdr.110 + br label %while.hdr.111 -while.hdr.110: ; preds = %fv.merge, %entry +while.hdr.111: ; preds = %fv.merge, %entry %load = load i64, ptr %allocaN, align 8 %icmp = icmp slt i64 %load, 4 - br i1 %icmp, label %while.body.111, label %while.exit.112 + br i1 %icmp, label %while.body.112, label %while.exit.113 -while.body.111: ; preds = %while.hdr.110 +while.body.112: ; preds = %while.hdr.111 %loadN = load i64, ptr %allocaN, align 8 %icmpN = icmp sgt i64 %loadN, 0 - br i1 %icmpN, label %if.then.113, label %if.merge.114 + br i1 %icmpN, label %if.then.114, label %if.merge.115 -while.exit.112: ; preds = %while.hdr.110 +while.exit.113: ; preds = %while.hdr.111 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.84, i64 1 }) ret { ptr, i64 } %callN -if.then.113: ; preds = %while.body.111 +if.then.114: ; preds = %while.body.112 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.85, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %if.merge.114 + br label %if.merge.115 -if.merge.114: ; preds = %if.then.113, %while.body.111 +if.merge.115: ; preds = %if.then.114, %while.body.112 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.90, i64 0, i64 %loadN @@ -2540,12 +2543,12 @@ fv.merge: ; preds = %fv.default, %fv.cas %loadN = load i64, ptr %allocaN, align 8 %add = add i64 %loadN, 1 store i64 %add, ptr %allocaN, align 8 - br label %while.hdr.110 + br label %while.hdr.111 -fv.default: ; preds = %if.merge.114 +fv.default: ; preds = %if.merge.115 br label %fv.merge -fv.case: ; preds = %if.merge.114 +fv.case: ; preds = %if.merge.115 %fv.field = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 0 %ba.tmp = alloca { ptr, ptr, ptr }, align 8 store { ptr, ptr, ptr } %fv.field, ptr %ba.tmp, align 8 @@ -2553,17 +2556,17 @@ fv.case: ; preds = %if.merge.114 %fv.val = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %ba.p2i, 1 br label %fv.merge -fv.case17: ; preds = %if.merge.114 +fv.case17: ; preds = %if.merge.115 %fv.field18 = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 1 %fv.val19 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field18, 1 br label %fv.merge -fv.case20: ; preds = %if.merge.114 +fv.case20: ; preds = %if.merge.115 %fv.field21 = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 2 %fv.val22 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field21, 1 br label %fv.merge -fv.case23: ; preds = %if.merge.114 +fv.case23: ; preds = %if.merge.115 %fv.field24 = extractvalue { { ptr, ptr, ptr }, i64, i64, i64 } %loadN, 3 %fv.val25 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field24, 1 br label %fv.merge @@ -2579,30 +2582,30 @@ entry: store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 - br label %while.hdr.115 + br label %while.hdr.116 -while.hdr.115: ; preds = %fv.merge, %entry +while.hdr.116: ; preds = %fv.merge, %entry %load = load i64, ptr %allocaN, align 8 %icmp = icmp slt i64 %load, 2 - br i1 %icmp, label %while.body.116, label %while.exit.117 + br i1 %icmp, label %while.body.117, label %while.exit.118 -while.body.116: ; preds = %while.hdr.115 +while.body.117: ; preds = %while.hdr.116 %loadN = load i64, ptr %allocaN, align 8 %icmpN = icmp sgt i64 %loadN, 0 - br i1 %icmpN, label %if.then.118, label %if.merge.119 + br i1 %icmpN, label %if.then.119, label %if.merge.120 -while.exit.117: ; preds = %while.hdr.115 +while.exit.118: ; preds = %while.hdr.116 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.94, i64 1 }) ret { ptr, i64 } %callN -if.then.118: ; preds = %while.body.116 +if.then.119: ; preds = %while.body.117 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.95, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %if.merge.119 + br label %if.merge.120 -if.merge.119: ; preds = %if.then.118, %while.body.116 +if.merge.120: ; preds = %if.then.119, %while.body.117 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.98, i64 0, i64 %loadN @@ -2628,12 +2631,12 @@ fv.merge: ; preds = %fv.default, %fv.cas %loadN = load i64, ptr %allocaN, align 8 %add = add i64 %loadN, 1 store i64 %add, ptr %allocaN, align 8 - br label %while.hdr.115 + br label %while.hdr.116 -fv.default: ; preds = %if.merge.119 +fv.default: ; preds = %if.merge.120 br label %fv.merge -fv.case: ; preds = %if.merge.119 +fv.case: ; preds = %if.merge.120 %fv.field = extractvalue { { ptr, ptr, ptr }, ptr } %loadN, 0 %ba.tmp = alloca { ptr, ptr, ptr }, align 8 store { ptr, ptr, ptr } %fv.field, ptr %ba.tmp, align 8 @@ -2641,7 +2644,7 @@ fv.case: ; preds = %if.merge.119 %fv.val = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %ba.p2i, 1 br label %fv.merge -fv.case17: ; preds = %if.merge.119 +fv.case17: ; preds = %if.merge.120 %fv.field18 = extractvalue { { ptr, ptr, ptr }, ptr } %loadN, 1 %pNi = ptrtoint ptr %fv.field18 to i64 %fv.val19 = insertvalue { i64, i64 } { i64 17, i64 undef }, i64 %pNi, 1 @@ -2658,30 +2661,30 @@ entry: store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 - br label %while.hdr.120 + br label %while.hdr.121 -while.hdr.120: ; preds = %if.merge.124, %entry +while.hdr.121: ; preds = %if.merge.125, %entry %load = load i64, ptr %allocaN, align 8 %icmp = icmp slt i64 %load, 0 - br i1 %icmp, label %while.body.121, label %while.exit.122 + br i1 %icmp, label %while.body.122, label %while.exit.123 -while.body.121: ; preds = %while.hdr.120 +while.body.122: ; preds = %while.hdr.121 %loadN = load i64, ptr %allocaN, align 8 %icmpN = icmp sgt i64 %loadN, 0 - br i1 %icmpN, label %if.then.123, label %if.merge.124 + br i1 %icmpN, label %if.then.124, label %if.merge.125 -while.exit.122: ; preds = %while.hdr.120 +while.exit.123: ; preds = %while.hdr.121 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.102, i64 1 }) ret { ptr, i64 } %callN -if.then.123: ; preds = %while.body.121 +if.then.124: ; preds = %while.body.122 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.103, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %if.merge.124 + br label %if.merge.125 -if.merge.124: ; preds = %if.then.123, %while.body.121 +if.merge.125: ; preds = %if.then.124, %while.body.122 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %fn.gep = getelementptr inbounds [0 x { ptr, i64 }], ptr @field_names.104, i64 0, i64 %loadN @@ -2700,7 +2703,7 @@ if.merge.124: ; preds = %if.then.123, %while %loadN = load i64, ptr %allocaN, align 8 %add = add i64 %loadN, 1 store i64 %add, ptr %allocaN, align 8 - br label %while.hdr.120 + br label %while.hdr.121 } ; Function Attrs: nounwind @@ -2713,30 +2716,30 @@ entry: store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 - br label %while.hdr.125 + br label %while.hdr.126 -while.hdr.125: ; preds = %fv.merge, %entry +while.hdr.126: ; preds = %fv.merge, %entry %load = load i64, ptr %allocaN, align 8 %icmp = icmp slt i64 %load, 3 - br i1 %icmp, label %while.body.126, label %while.exit.127 + br i1 %icmp, label %while.body.127, label %while.exit.128 -while.body.126: ; preds = %while.hdr.125 +while.body.127: ; preds = %while.hdr.126 %loadN = load i64, ptr %allocaN, align 8 %icmpN = icmp sgt i64 %loadN, 0 - br i1 %icmpN, label %if.then.128, label %if.merge.129 + br i1 %icmpN, label %if.then.129, label %if.merge.130 -while.exit.127: ; preds = %while.hdr.125 +while.exit.128: ; preds = %while.hdr.126 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.108, i64 1 }) ret { ptr, i64 } %callN -if.then.128: ; preds = %while.body.126 +if.then.129: ; preds = %while.body.127 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.109, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %if.merge.129 + br label %if.merge.130 -if.merge.129: ; preds = %if.then.128, %while.body.126 +if.merge.130: ; preds = %if.then.129, %while.body.127 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.113, i64 0, i64 %loadN @@ -2763,22 +2766,22 @@ fv.merge: ; preds = %fv.default, %fv.cas %loadN = load i64, ptr %allocaN, align 8 %add = add i64 %loadN, 1 store i64 %add, ptr %allocaN, align 8 - br label %while.hdr.125 + br label %while.hdr.126 -fv.default: ; preds = %if.merge.129 +fv.default: ; preds = %if.merge.130 br label %fv.merge -fv.case: ; preds = %if.merge.129 +fv.case: ; preds = %if.merge.130 %fv.field = extractvalue { i64, i64, i64 } %loadN, 0 %fv.val = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field, 1 br label %fv.merge -fv.case17: ; preds = %if.merge.129 +fv.case17: ; preds = %if.merge.130 %fv.field18 = extractvalue { i64, i64, i64 } %loadN, 1 %fv.val19 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field18, 1 br label %fv.merge -fv.case20: ; preds = %if.merge.129 +fv.case20: ; preds = %if.merge.130 %fv.field21 = extractvalue { i64, i64, i64 } %loadN, 2 %fv.val22 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field21, 1 br label %fv.merge @@ -2809,18 +2812,18 @@ entry: %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %len = extractvalue { ptr, i64 } %loadN, 1 %icmp = icmp sgt i64 %len, 0 - br i1 %icmp, label %if.then.134, label %if.merge.135 + br i1 %icmp, label %if.then.135, label %if.merge.136 -if.then.134: ; preds = %entry +if.then.135: ; preds = %entry %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.125, i64 1 }) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.124, i64 1 }, { ptr, i64 } %callN) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %if.merge.135 + br label %if.merge.136 -if.merge.135: ; preds = %if.then.134, %entry +if.merge.136: ; preds = %if.then.135, %entry %loadN = load { ptr, i64 }, ptr %allocaN, align 8 ret { ptr, i64 } %loadN } @@ -2850,18 +2853,18 @@ entry: %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %len = extractvalue { ptr, i64 } %loadN, 1 %icmp = icmp sgt i64 %len, 0 - br i1 %icmp, label %if.then.136, label %if.merge.137 + br i1 %icmp, label %if.then.137, label %if.merge.138 -if.then.136: ; preds = %entry +if.then.137: ; preds = %entry %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.134, i64 1 }) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.133, i64 1 }, { ptr, i64 } %callN) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %if.merge.137 + br label %if.merge.138 -if.merge.137: ; preds = %if.then.136, %entry +if.merge.138: ; preds = %if.then.137, %entry %loadN = load { ptr, i64 }, ptr %allocaN, align 8 ret { ptr, i64 } %loadN } @@ -2875,30 +2878,30 @@ entry: store { ptr, i64 } { ptr @str.135, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 - br label %while.hdr.142 + br label %while.hdr.143 -while.hdr.142: ; preds = %if.merge.146, %entry +while.hdr.143: ; preds = %if.merge.147, %entry %load = load i64, ptr %allocaN, align 8 %icmp = icmp slt i64 %load, 1 - br i1 %icmp, label %while.body.143, label %while.exit.144 + br i1 %icmp, label %while.body.144, label %while.exit.145 -while.body.143: ; preds = %while.hdr.142 +while.body.144: ; preds = %while.hdr.143 %loadN = load i64, ptr %allocaN, align 8 %icmpN = icmp sgt i64 %loadN, 0 - br i1 %icmpN, label %if.then.145, label %if.merge.146 + br i1 %icmpN, label %if.then.146, label %if.merge.147 -while.exit.144: ; preds = %while.hdr.142 +while.exit.145: ; preds = %while.hdr.143 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.136, i64 1 }) ret { ptr, i64 } %call -if.then.145: ; preds = %while.body.143 +if.then.146: ; preds = %while.body.144 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.137, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %if.merge.146 + br label %if.merge.147 -if.merge.146: ; preds = %if.then.145, %while.body.143 +if.merge.147: ; preds = %if.then.146, %while.body.144 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load [1 x { i64, i64 }], ptr %alloca, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2916,7 +2919,7 @@ if.merge.146: ; preds = %if.then.145, %while %loadN = load i64, ptr %allocaN, align 8 %add = add i64 %loadN, 1 store i64 %add, ptr %allocaN, align 8 - br label %while.hdr.142 + br label %while.hdr.143 } ; Function Attrs: nounwind @@ -2928,30 +2931,30 @@ entry: store { ptr, i64 } { ptr @str.138, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 - br label %while.hdr.147 + br label %while.hdr.148 -while.hdr.147: ; preds = %if.merge.151, %entry +while.hdr.148: ; preds = %if.merge.152, %entry %load = load i64, ptr %allocaN, align 8 %icmp = icmp slt i64 %load, 3 - br i1 %icmp, label %while.body.148, label %while.exit.149 + br i1 %icmp, label %while.body.149, label %while.exit.150 -while.body.148: ; preds = %while.hdr.147 +while.body.149: ; preds = %while.hdr.148 %loadN = load i64, ptr %allocaN, align 8 %icmpN = icmp sgt i64 %loadN, 0 - br i1 %icmpN, label %if.then.150, label %if.merge.151 + br i1 %icmpN, label %if.then.151, label %if.merge.152 -while.exit.149: ; preds = %while.hdr.147 +while.exit.150: ; preds = %while.hdr.148 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.139, i64 1 }) ret { ptr, i64 } %call -if.then.150: ; preds = %while.body.148 +if.then.151: ; preds = %while.body.149 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.140, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %if.merge.151 + br label %if.merge.152 -if.merge.151: ; preds = %if.then.150, %while.body.148 +if.merge.152: ; preds = %if.then.151, %while.body.149 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load [3 x { i64, i64 }], ptr %alloca, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -2969,7 +2972,7 @@ if.merge.151: ; preds = %if.then.150, %while %loadN = load i64, ptr %allocaN, align 8 %add = add i64 %loadN, 1 store i64 %add, ptr %allocaN, align 8 - br label %while.hdr.147 + br label %while.hdr.148 } ; Function Attrs: nounwind @@ -2981,32 +2984,32 @@ entry: store { ptr, i64 } { ptr @str.141, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 - br label %while.hdr.156 + br label %while.hdr.157 -while.hdr.156: ; preds = %if.merge.160, %entry +while.hdr.157: ; preds = %if.merge.161, %entry %load = load i64, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %alloca, align 8 %len = extractvalue { ptr, i64 } %loadN, 1 %icmp = icmp slt i64 %load, %len - br i1 %icmp, label %while.body.157, label %while.exit.158 + br i1 %icmp, label %while.body.158, label %while.exit.159 -while.body.157: ; preds = %while.hdr.156 +while.body.158: ; preds = %while.hdr.157 %loadN = load i64, ptr %allocaN, align 8 %icmpN = icmp sgt i64 %loadN, 0 - br i1 %icmpN, label %if.then.159, label %if.merge.160 + br i1 %icmpN, label %if.then.160, label %if.merge.161 -while.exit.158: ; preds = %while.hdr.156 +while.exit.159: ; preds = %while.hdr.157 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.142, i64 1 }) ret { ptr, i64 } %call -if.then.159: ; preds = %while.body.157 +if.then.160: ; preds = %while.body.158 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.143, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %if.merge.160 + br label %if.merge.161 -if.merge.160: ; preds = %if.then.159, %while.body.157 +if.merge.161: ; preds = %if.then.160, %while.body.158 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %alloca, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -3023,7 +3026,7 @@ if.merge.160: ; preds = %if.then.159, %while %loadN = load i64, ptr %allocaN, align 8 %add = add i64 %loadN, 1 store i64 %add, ptr %allocaN, align 8 - br label %while.hdr.156 + br label %while.hdr.157 } ; Function Attrs: nounwind @@ -3035,32 +3038,32 @@ entry: store { ptr, i64 } { ptr @str.144, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 - br label %while.hdr.161 + br label %while.hdr.162 -while.hdr.161: ; preds = %if.merge.165, %entry +while.hdr.162: ; preds = %if.merge.166, %entry %load = load i64, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %alloca, align 8 %len = extractvalue { ptr, i64 } %loadN, 1 %icmp = icmp slt i64 %load, %len - br i1 %icmp, label %while.body.162, label %while.exit.163 + br i1 %icmp, label %while.body.163, label %while.exit.164 -while.body.162: ; preds = %while.hdr.161 +while.body.163: ; preds = %while.hdr.162 %loadN = load i64, ptr %allocaN, align 8 %icmpN = icmp sgt i64 %loadN, 0 - br i1 %icmpN, label %if.then.164, label %if.merge.165 + br i1 %icmpN, label %if.then.165, label %if.merge.166 -while.exit.163: ; preds = %while.hdr.161 +while.exit.164: ; preds = %while.hdr.162 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.145, i64 1 }) ret { ptr, i64 } %call -if.then.164: ; preds = %while.body.162 +if.then.165: ; preds = %while.body.163 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.146, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %if.merge.165 + br label %if.merge.166 -if.merge.165: ; preds = %if.then.164, %while.body.162 +if.merge.166: ; preds = %if.then.165, %while.body.163 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %alloca, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -3077,7 +3080,7 @@ if.merge.165: ; preds = %if.then.164, %while %loadN = load i64, ptr %allocaN, align 8 %add = add i64 %loadN, 1 store i64 %add, ptr %allocaN, align 8 - br label %while.hdr.161 + br label %while.hdr.162 } ; Function Attrs: nounwind @@ -3091,20 +3094,20 @@ entry: store i64 %pti, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %icmp = icmp eq i64 %loadN, 0 - br i1 %icmp, label %if.then.187, label %if.else.188 + br i1 %icmp, label %if.then.188, label %if.else.189 -if.then.187: ; preds = %entry - br label %if.merge.189 +if.then.188: ; preds = %entry + br label %if.merge.190 -if.else.188: ; preds = %entry +if.else.189: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.149, i64 3 }, { ptr, i64 } %call) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.148, i64 5 }, { ptr, i64 } %callN) - br label %if.merge.189 + br label %if.merge.190 -if.merge.189: ; preds = %if.else.188, %if.then.187 - %bp = phi { ptr, i64 } [ { ptr @str.147, i64 4 }, %if.then.187 ], [ %callN, %if.else.188 ] +if.merge.190: ; preds = %if.else.189, %if.then.188 + %bp = phi { ptr, i64 } [ { ptr @str.147, i64 4 }, %if.then.188 ], [ %callN, %if.else.189 ] ret { ptr, i64 } %bp } @@ -3119,20 +3122,20 @@ entry: store i64 %pti, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %icmp = icmp eq i64 %loadN, 0 - br i1 %icmp, label %if.then.211, label %if.else.212 + br i1 %icmp, label %if.then.212, label %if.else.213 -if.then.211: ; preds = %entry - br label %if.merge.213 +if.then.212: ; preds = %entry + br label %if.merge.214 -if.else.212: ; preds = %entry +if.else.213: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.152, i64 3 }, { ptr, i64 } %call) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.151, i64 11 }, { ptr, i64 } %callN) - br label %if.merge.213 + br label %if.merge.214 -if.merge.213: ; preds = %if.else.212, %if.then.211 - %bp = phi { ptr, i64 } [ { ptr @str.150, i64 4 }, %if.then.211 ], [ %callN, %if.else.212 ] +if.merge.214: ; preds = %if.else.213, %if.then.212 + %bp = phi { ptr, i64 } [ { ptr @str.150, i64 4 }, %if.then.212 ], [ %callN, %if.else.213 ] ret { ptr, i64 } %bp } @@ -3147,20 +3150,20 @@ entry: store i64 %pti, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %icmp = icmp eq i64 %loadN, 0 - br i1 %icmp, label %if.then.214, label %if.else.215 + br i1 %icmp, label %if.then.215, label %if.else.216 -if.then.214: ; preds = %entry - br label %if.merge.216 +if.then.215: ; preds = %entry + br label %if.merge.217 -if.else.215: ; preds = %entry +if.else.216: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.155, i64 3 }, { ptr, i64 } %call) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.154, i64 4 }, { ptr, i64 } %callN) - br label %if.merge.216 + br label %if.merge.217 -if.merge.216: ; preds = %if.else.215, %if.then.214 - %bp = phi { ptr, i64 } [ { ptr @str.153, i64 4 }, %if.then.214 ], [ %callN, %if.else.215 ] +if.merge.217: ; preds = %if.else.216, %if.then.215 + %bp = phi { ptr, i64 } [ { ptr @str.153, i64 4 }, %if.then.215 ], [ %callN, %if.else.216 ] ret { ptr, i64 } %bp } @@ -3175,20 +3178,20 @@ entry: store i64 %pti, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %icmp = icmp eq i64 %loadN, 0 - br i1 %icmp, label %if.then.217, label %if.else.218 + br i1 %icmp, label %if.then.218, label %if.else.219 -if.then.217: ; preds = %entry - br label %if.merge.219 +if.then.218: ; preds = %entry + br label %if.merge.220 -if.else.218: ; preds = %entry +if.else.219: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.158, i64 3 }, { ptr, i64 } %call) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.157, i64 11 }, { ptr, i64 } %callN) - br label %if.merge.219 + br label %if.merge.220 -if.merge.219: ; preds = %if.else.218, %if.then.217 - %bp = phi { ptr, i64 } [ { ptr @str.156, i64 4 }, %if.then.217 ], [ %callN, %if.else.218 ] +if.merge.220: ; preds = %if.else.219, %if.then.218 + %bp = phi { ptr, i64 } [ { ptr @str.156, i64 4 }, %if.then.218 ], [ %callN, %if.else.219 ] ret { ptr, i64 } %bp } @@ -3203,20 +3206,20 @@ entry: store i64 %pti, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %icmp = icmp eq i64 %loadN, 0 - br i1 %icmp, label %if.then.220, label %if.else.221 + br i1 %icmp, label %if.then.221, label %if.else.222 -if.then.220: ; preds = %entry - br label %if.merge.222 +if.then.221: ; preds = %entry + br label %if.merge.223 -if.else.221: ; preds = %entry +if.else.222: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.161, i64 3 }, { ptr, i64 } %call) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.160, i64 6 }, { ptr, i64 } %callN) - br label %if.merge.222 + br label %if.merge.223 -if.merge.222: ; preds = %if.else.221, %if.then.220 - %bp = phi { ptr, i64 } [ { ptr @str.159, i64 4 }, %if.then.220 ], [ %callN, %if.else.221 ] +if.merge.223: ; preds = %if.else.222, %if.then.221 + %bp = phi { ptr, i64 } [ { ptr @str.159, i64 4 }, %if.then.221 ], [ %callN, %if.else.222 ] ret { ptr, i64 } %bp } @@ -3230,20 +3233,20 @@ entry: store ptr %load, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %icmp = icmp eq i64 %loadN, 0 - br i1 %icmp, label %if.then.223, label %if.else.224 + br i1 %icmp, label %if.then.224, label %if.else.225 -if.then.223: ; preds = %entry - br label %if.merge.225 +if.then.224: ; preds = %entry + br label %if.merge.226 -if.else.224: ; preds = %entry +if.else.225: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.164, i64 3 }, { ptr, i64 } %call) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.163, i64 5 }, { ptr, i64 } %callN) - br label %if.merge.225 + br label %if.merge.226 -if.merge.225: ; preds = %if.else.224, %if.then.223 - %bp = phi { ptr, i64 } [ { ptr @str.162, i64 4 }, %if.then.223 ], [ %callN, %if.else.224 ] +if.merge.226: ; preds = %if.else.225, %if.then.224 + %bp = phi { ptr, i64 } [ { ptr @str.162, i64 4 }, %if.then.224 ], [ %callN, %if.else.225 ] ret { ptr, i64 } %bp } @@ -3258,20 +3261,20 @@ entry: store i64 %pti, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %icmp = icmp eq i64 %loadN, 0 - br i1 %icmp, label %if.then.226, label %if.else.227 + br i1 %icmp, label %if.then.227, label %if.else.228 -if.then.226: ; preds = %entry - br label %if.merge.228 +if.then.227: ; preds = %entry + br label %if.merge.229 -if.else.227: ; preds = %entry +if.else.228: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.167, i64 3 }, { ptr, i64 } %call) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.166, i64 9 }, { ptr, i64 } %callN) - br label %if.merge.228 + br label %if.merge.229 -if.merge.228: ; preds = %if.else.227, %if.then.226 - %bp = phi { ptr, i64 } [ { ptr @str.165, i64 4 }, %if.then.226 ], [ %callN, %if.else.227 ] +if.merge.229: ; preds = %if.else.228, %if.then.227 + %bp = phi { ptr, i64 } [ { ptr @str.165, i64 4 }, %if.then.227 ], [ %callN, %if.else.228 ] ret { ptr, i64 } %bp } @@ -3286,20 +3289,20 @@ entry: store i64 %pti, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %icmp = icmp eq i64 %loadN, 0 - br i1 %icmp, label %if.then.229, label %if.else.230 + br i1 %icmp, label %if.then.230, label %if.else.231 -if.then.229: ; preds = %entry - br label %if.merge.231 +if.then.230: ; preds = %entry + br label %if.merge.232 -if.else.230: ; preds = %entry +if.else.231: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.170, i64 3 }, { ptr, i64 } %call) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.169, i64 18 }, { ptr, i64 } %callN) - br label %if.merge.231 + br label %if.merge.232 -if.merge.231: ; preds = %if.else.230, %if.then.229 - %bp = phi { ptr, i64 } [ { ptr @str.168, i64 4 }, %if.then.229 ], [ %callN, %if.else.230 ] +if.merge.232: ; preds = %if.else.231, %if.then.230 + %bp = phi { ptr, i64 } [ { ptr @str.168, i64 4 }, %if.then.230 ], [ %callN, %if.else.231 ] ret { ptr, i64 } %bp } @@ -3314,20 +3317,20 @@ entry: store i64 %pti, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %icmp = icmp eq i64 %loadN, 0 - br i1 %icmp, label %if.then.232, label %if.else.233 + br i1 %icmp, label %if.then.233, label %if.else.234 -if.then.232: ; preds = %entry - br label %if.merge.234 +if.then.233: ; preds = %entry + br label %if.merge.235 -if.else.233: ; preds = %entry +if.else.234: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.173, i64 3 }, { ptr, i64 } %call) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.172, i64 12 }, { ptr, i64 } %callN) - br label %if.merge.234 + br label %if.merge.235 -if.merge.234: ; preds = %if.else.233, %if.then.232 - %bp = phi { ptr, i64 } [ { ptr @str.171, i64 4 }, %if.then.232 ], [ %callN, %if.else.233 ] +if.merge.235: ; preds = %if.else.234, %if.then.233 + %bp = phi { ptr, i64 } [ { ptr @str.171, i64 4 }, %if.then.233 ], [ %callN, %if.else.234 ] ret { ptr, i64 } %bp } @@ -3342,20 +3345,20 @@ entry: store i64 %pti, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %icmp = icmp eq i64 %loadN, 0 - br i1 %icmp, label %if.then.235, label %if.else.236 + br i1 %icmp, label %if.then.236, label %if.else.237 -if.then.235: ; preds = %entry - br label %if.merge.237 +if.then.236: ; preds = %entry + br label %if.merge.238 -if.else.236: ; preds = %entry +if.else.237: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.176, i64 3 }, { ptr, i64 } %call) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.175, i64 4 }, { ptr, i64 } %callN) - br label %if.merge.237 + br label %if.merge.238 -if.merge.237: ; preds = %if.else.236, %if.then.235 - %bp = phi { ptr, i64 } [ { ptr @str.174, i64 4 }, %if.then.235 ], [ %callN, %if.else.236 ] +if.merge.238: ; preds = %if.else.237, %if.then.236 + %bp = phi { ptr, i64 } [ { ptr @str.174, i64 4 }, %if.then.236 ], [ %callN, %if.else.237 ] ret { ptr, i64 } %bp } @@ -3370,20 +3373,20 @@ entry: store i64 %pti, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %icmp = icmp eq i64 %loadN, 0 - br i1 %icmp, label %if.then.238, label %if.else.239 + br i1 %icmp, label %if.then.239, label %if.else.240 -if.then.238: ; preds = %entry - br label %if.merge.240 +if.then.239: ; preds = %entry + br label %if.merge.241 -if.else.239: ; preds = %entry +if.else.240: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.179, i64 3 }, { ptr, i64 } %call) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.178, i64 6 }, { ptr, i64 } %callN) - br label %if.merge.240 + br label %if.merge.241 -if.merge.240: ; preds = %if.else.239, %if.then.238 - %bp = phi { ptr, i64 } [ { ptr @str.177, i64 4 }, %if.then.238 ], [ %callN, %if.else.239 ] +if.merge.241: ; preds = %if.else.240, %if.then.239 + %bp = phi { ptr, i64 } [ { ptr @str.177, i64 4 }, %if.then.239 ], [ %callN, %if.else.240 ] ret { ptr, i64 } %bp } @@ -3398,20 +3401,20 @@ entry: store i64 %pti, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %icmp = icmp eq i64 %loadN, 0 - br i1 %icmp, label %if.then.241, label %if.else.242 + br i1 %icmp, label %if.then.242, label %if.else.243 -if.then.241: ; preds = %entry - br label %if.merge.243 +if.then.242: ; preds = %entry + br label %if.merge.244 -if.else.242: ; preds = %entry +if.else.243: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.182, i64 3 }, { ptr, i64 } %call) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.181, i64 5 }, { ptr, i64 } %callN) - br label %if.merge.243 + br label %if.merge.244 -if.merge.243: ; preds = %if.else.242, %if.then.241 - %bp = phi { ptr, i64 } [ { ptr @str.180, i64 4 }, %if.then.241 ], [ %callN, %if.else.242 ] +if.merge.244: ; preds = %if.else.243, %if.then.242 + %bp = phi { ptr, i64 } [ { ptr @str.180, i64 4 }, %if.then.242 ], [ %callN, %if.else.243 ] ret { ptr, i64 } %bp } @@ -3426,20 +3429,20 @@ entry: store i64 %pti, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %icmp = icmp eq i64 %loadN, 0 - br i1 %icmp, label %if.then.244, label %if.else.245 + br i1 %icmp, label %if.then.245, label %if.else.246 -if.then.244: ; preds = %entry - br label %if.merge.246 +if.then.245: ; preds = %entry + br label %if.merge.247 -if.else.245: ; preds = %entry +if.else.246: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.185, i64 3 }, { ptr, i64 } %call) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.184, i64 7 }, { ptr, i64 } %callN) - br label %if.merge.246 + br label %if.merge.247 -if.merge.246: ; preds = %if.else.245, %if.then.244 - %bp = phi { ptr, i64 } [ { ptr @str.183, i64 4 }, %if.then.244 ], [ %callN, %if.else.245 ] +if.merge.247: ; preds = %if.else.246, %if.then.245 + %bp = phi { ptr, i64 } [ { ptr @str.183, i64 4 }, %if.then.245 ], [ %callN, %if.else.246 ] ret { ptr, i64 } %bp } @@ -3454,20 +3457,20 @@ entry: store i64 %pti, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %icmp = icmp eq i64 %loadN, 0 - br i1 %icmp, label %if.then.247, label %if.else.248 + br i1 %icmp, label %if.then.248, label %if.else.249 -if.then.247: ; preds = %entry - br label %if.merge.249 +if.then.248: ; preds = %entry + br label %if.merge.250 -if.else.248: ; preds = %entry +if.else.249: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.188, i64 3 }, { ptr, i64 } %call) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.187, i64 4 }, { ptr, i64 } %callN) - br label %if.merge.249 + br label %if.merge.250 -if.merge.249: ; preds = %if.else.248, %if.then.247 - %bp = phi { ptr, i64 } [ { ptr @str.186, i64 4 }, %if.then.247 ], [ %callN, %if.else.248 ] +if.merge.250: ; preds = %if.else.249, %if.then.248 + %bp = phi { ptr, i64 } [ { ptr @str.186, i64 4 }, %if.then.248 ], [ %callN, %if.else.249 ] ret { ptr, i64 } %bp } @@ -3482,20 +3485,20 @@ entry: store i64 %pti, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %icmp = icmp eq i64 %loadN, 0 - br i1 %icmp, label %if.then.250, label %if.else.251 + br i1 %icmp, label %if.then.251, label %if.else.252 -if.then.250: ; preds = %entry - br label %if.merge.252 +if.then.251: ; preds = %entry + br label %if.merge.253 -if.else.251: ; preds = %entry +if.else.252: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.191, i64 3 }, { ptr, i64 } %call) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.190, i64 6 }, { ptr, i64 } %callN) - br label %if.merge.252 + br label %if.merge.253 -if.merge.252: ; preds = %if.else.251, %if.then.250 - %bp = phi { ptr, i64 } [ { ptr @str.189, i64 4 }, %if.then.250 ], [ %callN, %if.else.251 ] +if.merge.253: ; preds = %if.else.252, %if.then.251 + %bp = phi { ptr, i64 } [ { ptr @str.189, i64 4 }, %if.then.251 ], [ %callN, %if.else.252 ] ret { ptr, i64 } %bp } @@ -3510,20 +3513,20 @@ entry: store i64 %pti, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %icmp = icmp eq i64 %loadN, 0 - br i1 %icmp, label %if.then.253, label %if.else.254 + br i1 %icmp, label %if.then.254, label %if.else.255 -if.then.253: ; preds = %entry - br label %if.merge.255 +if.then.254: ; preds = %entry + br label %if.merge.256 -if.else.254: ; preds = %entry +if.else.255: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.194, i64 3 }, { ptr, i64 } %call) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.193, i64 7 }, { ptr, i64 } %callN) - br label %if.merge.255 + br label %if.merge.256 -if.merge.255: ; preds = %if.else.254, %if.then.253 - %bp = phi { ptr, i64 } [ { ptr @str.192, i64 4 }, %if.then.253 ], [ %callN, %if.else.254 ] +if.merge.256: ; preds = %if.else.255, %if.then.254 + %bp = phi { ptr, i64 } [ { ptr @str.192, i64 4 }, %if.then.254 ], [ %callN, %if.else.255 ] ret { ptr, i64 } %bp } @@ -3538,20 +3541,20 @@ entry: store i64 %pti, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %icmp = icmp eq i64 %loadN, 0 - br i1 %icmp, label %if.then.256, label %if.else.257 + br i1 %icmp, label %if.then.257, label %if.else.258 -if.then.256: ; preds = %entry - br label %if.merge.258 +if.then.257: ; preds = %entry + br label %if.merge.259 -if.else.257: ; preds = %entry +if.else.258: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.197, i64 3 }, { ptr, i64 } %call) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.196, i64 3 }, { ptr, i64 } %callN) - br label %if.merge.258 + br label %if.merge.259 -if.merge.258: ; preds = %if.else.257, %if.then.256 - %bp = phi { ptr, i64 } [ { ptr @str.195, i64 4 }, %if.then.256 ], [ %callN, %if.else.257 ] +if.merge.259: ; preds = %if.else.258, %if.then.257 + %bp = phi { ptr, i64 } [ { ptr @str.195, i64 4 }, %if.then.257 ], [ %callN, %if.else.258 ] ret { ptr, i64 } %bp } @@ -3566,20 +3569,20 @@ entry: store i64 %pti, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %icmp = icmp eq i64 %loadN, 0 - br i1 %icmp, label %if.then.259, label %if.else.260 + br i1 %icmp, label %if.then.260, label %if.else.261 -if.then.259: ; preds = %entry - br label %if.merge.261 +if.then.260: ; preds = %entry + br label %if.merge.262 -if.else.260: ; preds = %entry +if.else.261: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.200, i64 3 }, { ptr, i64 } %call) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.199, i64 7 }, { ptr, i64 } %callN) - br label %if.merge.261 + br label %if.merge.262 -if.merge.261: ; preds = %if.else.260, %if.then.259 - %bp = phi { ptr, i64 } [ { ptr @str.198, i64 4 }, %if.then.259 ], [ %callN, %if.else.260 ] +if.merge.262: ; preds = %if.else.261, %if.then.260 + %bp = phi { ptr, i64 } [ { ptr @str.198, i64 4 }, %if.then.260 ], [ %callN, %if.else.261 ] ret { ptr, i64 } %bp } @@ -3594,20 +3597,20 @@ entry: store i64 %pti, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %icmp = icmp eq i64 %loadN, 0 - br i1 %icmp, label %if.then.262, label %if.else.263 + br i1 %icmp, label %if.then.263, label %if.else.264 -if.then.262: ; preds = %entry - br label %if.merge.264 +if.then.263: ; preds = %entry + br label %if.merge.265 -if.else.263: ; preds = %entry +if.else.264: ; preds = %entry %loadN = load i64, ptr %allocaN, align 8 %call = call { ptr, i64 } @int_to_hex_string(ptr %0, i64 %loadN) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.203, i64 3 }, { ptr, i64 } %call) %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.202, i64 7 }, { ptr, i64 } %callN) - br label %if.merge.264 + br label %if.merge.265 -if.merge.264: ; preds = %if.else.263, %if.then.262 - %bp = phi { ptr, i64 } [ { ptr @str.201, i64 4 }, %if.then.262 ], [ %callN, %if.else.263 ] +if.merge.265: ; preds = %if.else.264, %if.then.263 + %bp = phi { ptr, i64 } [ { ptr @str.201, i64 4 }, %if.then.263 ], [ %callN, %if.else.264 ] ret { ptr, i64 } %bp } @@ -3619,5 +3622,3 @@ entry: store ptr %sel, ptr @OBJC_SELECTOR_REFERENCES_tripleValue, align 8 ret void } - - diff --git a/tests/expected/ffi-objc-dsl-07-mangling-table.ir b/tests/expected/ffi-objc-dsl-07-mangling-table.ir index c66c53c..f1bf9ac 100644 --- a/tests/expected/ffi-objc-dsl-07-mangling-table.ir +++ b/tests/expected/ffi-objc-dsl-07-mangling-table.ir @@ -953,5 +953,3 @@ entry: store ptr %selN, ptr @OBJC_SELECTOR_REFERENCES_actualSelectorName, align 8 ret void } - -