From 8e3c3ae9815db0da27d621d630e001cd2a57ff77 Mon Sep 17 00:00:00 2001 From: agra Date: Sat, 30 May 2026 17:39:38 +0300 Subject: [PATCH] objc: NSString type + Into(*NSString) for string Adds an NSString foreign class and impl Into(*NSString) for string so a string literal flows into any *NSString slot via xx. uikit's keyboard userInfo lookups now read objectForKey(xx "...") instead of ns_string("...".ptr), and objectForKey's key param is retyped *NSString. ffi-objc-call-06 .ir snapshot regenerated: declaring the NSString type adds its reflection thunks (struct_to_string/pointer_to_string), same as the existing NSObject/NSDictionary. Runtime output unchanged. --- library/modules/platform/uikit.sx | 8 +- library/modules/std/objc.sx | 18 + .../expected/ffi-objc-call-06-sret-return.ir | 1838 +++++++++-------- 3 files changed, 998 insertions(+), 866 deletions(-) diff --git a/library/modules/platform/uikit.sx b/library/modules/platform/uikit.sx index fa65302..11cf74d 100644 --- a/library/modules/platform/uikit.sx +++ b/library/modules/platform/uikit.sx @@ -75,7 +75,7 @@ NSNumber :: #foreign #objc_class("NSNumber") { NSDictionary :: #foreign #objc_class("NSDictionary") { #extends NSObject; - objectForKey :: (self: *Self, key: *void) -> *void; + objectForKey :: (self: *Self, key: *NSString) -> *void; } NSMutableDictionary :: #foreign #objc_class("NSMutableDictionary") { @@ -563,19 +563,19 @@ impl Platform for UIKitPlatform { user_info := notification.userInfo(); if user_info == null { return; } - end_value_raw := user_info.objectForKey(ns_string("UIKeyboardFrameEndUserInfoKey".ptr)); + end_value_raw := user_info.objectForKey(xx "UIKeyboardFrameEndUserInfoKey"); if end_value_raw == null { return; } end_value : *NSValue = xx end_value_raw; end_rect := end_value.CGRectValue(); - dur_value_raw := user_info.objectForKey(ns_string("UIKeyboardAnimationDurationUserInfoKey".ptr)); + dur_value_raw := user_info.objectForKey(xx "UIKeyboardAnimationDurationUserInfoKey"); anim_dur : f64 = 0.0; if dur_value_raw != null { dur_value : *NSNumber = xx dur_value_raw; anim_dur = dur_value.doubleValue(); } - curve_value_raw := user_info.objectForKey(ns_string("UIKeyboardAnimationCurveUserInfoKey".ptr)); + curve_value_raw := user_info.objectForKey(xx "UIKeyboardAnimationCurveUserInfoKey"); curve_int : u64 = 0; if curve_value_raw != null { curve_value : *NSNumber = xx curve_value_raw; diff --git a/library/modules/std/objc.sx b/library/modules/std/objc.sx index 192d627..6108a91 100644 --- a/library/modules/std/objc.sx +++ b/library/modules/std/objc.sx @@ -123,6 +123,24 @@ NSObject :: #foreign #objc_class("NSObject") { respondsToSelector :: (self: *Self, sel: *void) -> BOOL; } +// ─── NSString ──────────────────────────────────────────────────────────── +// Foundation's immutable string. `ns_string` builds an autoreleased instance +// from a C string; the `Into` impl lets a string literal flow into any +// `*NSString` slot via `xx`, e.g. `dict.objectForKey(xx "SomeKey")`. +NSString :: #foreign #objc_class("NSString") { + #extends NSObject; + UTF8String :: (self: *Self) -> [*]u8; +} + +// `self.ptr` must be NUL-terminated. String literals are; an arbitrary +// substring/built `string` may not be, so only pass literals (or otherwise +// NUL-terminated slices) through this conversion. +impl Into(*NSString) for string { + convert :: (self: string) -> *NSString { + return xx ns_string(self.ptr); + } +} + // ─── Autoreleasepool (M4.A) ────────────────────────────────────────────── // Foundation factory methods (`NSString.stringWithUTF8String:`, // `[NSArray array]`, ...) return autoreleased objects — valid until the diff --git a/tests/expected/ffi-objc-call-06-sret-return.ir b/tests/expected/ffi-objc-call-06-sret-return.ir index 261134f..72a71e1 100644 --- a/tests/expected/ffi-objc-call-06-sret-return.ir +++ b/tests/expected/ffi-objc-call-06-sret-return.ir @@ -49,247 +49,259 @@ @tn.str.41 = private constant [13 x i8] c"Architecture\00" @tn.str.42 = private constant [13 x i8] c"BuildOptions\00" @tn.str.43 = private constant [11 x i8] c"() -> bool\00" -@tn.str.44 = private constant [10 x i8] c"Closure()\00" -@tn.str.45 = private constant [7 x i8] c"Triple\00" -@tn.str.46 = private constant [13 x i8] c"**CAllocator\00" -@tn.str.47 = private constant [5 x i8] c"*s64\00" -@tn.str.48 = private constant [7 x i8] c"**void\00" -@tn.str.49 = private constant [6 x i8] c"*bool\00" -@tn.str.50 = private constant [8 x i8] c"*string\00" -@tn.str.51 = private constant [6 x i8] c"[]Any\00" -@tn.str.52 = private constant [5 x i8] c"*Any\00" -@tn.str.53 = private constant [7 x i8] c"[1]Any\00" -@tn.str.54 = private constant [8 x i8] c"*[1]Any\00" -@tn.str.55 = private constant [7 x i8] c"*[]Any\00" -@tn.str.56 = private constant [4 x i8] c"*u8\00" -@tn.str.57 = private constant [8 x i8] c"*Triple\00" -@tn.str.58 = private constant [7 x i8] c"[3]Any\00" -@tn.str.59 = private constant [8 x i8] c"*[3]Any\00" -@tn.str.60 = private constant [5 x i8] c"*f64\00" -@tn.str.61 = private constant [11 x i8] c"*Allocator\00" -@tn.str.62 = private constant [9 x i8] c"*Context\00" -@tn.str.63 = private constant [14 x i8] c"*BuildOptions\00" -@tn.str.64 = private constant [17 x i8] c"*OperatingSystem\00" -@tn.str.65 = private constant [14 x i8] c"*Architecture\00" -@tn.str.66 = private constant [10 x i8] c"*[]string\00" -@tn.str.67 = private constant [6 x i8] c"**GPA\00" -@tn.str.68 = private constant [13 x i8] c"**ArenaChunk\00" -@tn.str.69 = private constant [8 x i8] c"**Arena\00" -@tn.str.70 = private constant [7 x i8] c"*[*]u8\00" -@tn.str.71 = private constant [11 x i8] c"**BufAlloc\00" -@tn.str.72 = private constant [20 x i8] c"**TrackingAllocator\00" -@tn.str.73 = private constant [14 x i8] c"***CAllocator\00" -@tn.str.74 = private constant [6 x i8] c"**s64\00" -@tn.str.75 = private constant [8 x i8] c"***void\00" -@tn.str.76 = private constant [7 x i8] c"**bool\00" -@tn.str.77 = private constant [9 x i8] c"**string\00" -@tn.str.78 = private constant [6 x i8] c"**Any\00" -@tn.str.79 = private constant [9 x i8] c"**[1]Any\00" -@tn.str.80 = private constant [8 x i8] c"**[]Any\00" -@tn.str.81 = private constant [5 x i8] c"**u8\00" -@tn.str.82 = private constant [9 x i8] c"**Triple\00" -@tn.str.83 = private constant [9 x i8] c"**[3]Any\00" -@__sx_type_names = private constant [79 x { ptr, i64 }] [{ ptr, i64 } { ptr @tn.str, i64 12 }, { ptr, i64 } { ptr @tn.str.6, i64 4 }, { ptr, i64 } { ptr @tn.str.7, i64 2 }, { ptr, i64 } { ptr @tn.str.8, i64 3 }, { ptr, i64 } { ptr @tn.str.9, i64 3 }, { ptr, i64 } { ptr @tn.str.10, i64 3 }, { ptr, i64 } { ptr @tn.str.11, i64 2 }, { ptr, i64 } { ptr @tn.str.12, i64 3 }, { ptr, i64 } { ptr @tn.str.13, i64 3 }, { ptr, i64 } { ptr @tn.str.14, i64 3 }, { ptr, i64 } { ptr @tn.str.15, i64 3 }, { ptr, i64 } { ptr @tn.str.16, i64 3 }, { ptr, i64 } { ptr @tn.str.17, i64 6 }, { ptr, i64 } { ptr @tn.str.18, i64 3 }, { ptr, i64 } { ptr @tn.str.19, i64 8 }, { ptr, i64 } { ptr @tn.str.20, i64 5 }, { ptr, i64 } { ptr @tn.str.21, i64 5 }, { ptr, i64 } { ptr @tn.str.22, i64 4 }, { ptr, i64 } { ptr @tn.str.23, i64 5 }, { ptr, i64 } { ptr @tn.str.24, i64 9 }, { ptr, i64 } { ptr @tn.str.25, i64 10 }, { ptr, i64 } { ptr @tn.str.26, i64 11 }, { ptr, i64 } { ptr @tn.str.27, i64 3 }, { ptr, i64 } { ptr @tn.str.28, i64 4 }, { ptr, i64 } { ptr @tn.str.29, i64 10 }, { ptr, i64 } { ptr @tn.str.30, i64 11 }, { ptr, i64 } { ptr @tn.str.31, i64 5 }, { ptr, i64 } { ptr @tn.str.32, i64 6 }, { ptr, i64 } { ptr @tn.str.33, i64 5 }, { ptr, i64 } { ptr @tn.str.34, i64 8 }, { ptr, i64 } { ptr @tn.str.35, i64 9 }, { ptr, i64 } { ptr @tn.str.36, i64 17 }, { ptr, i64 } { ptr @tn.str.37, i64 18 }, { ptr, i64 } { ptr @tn.str.38, i64 7 }, { ptr, i64 } { ptr @tn.str.39, i64 8 }, { ptr, i64 } { ptr @tn.str.40, i64 15 }, { ptr, i64 } { ptr @tn.str.41, i64 12 }, { ptr, i64 } { ptr @tn.str.42, i64 12 }, { ptr, i64 } { ptr @tn.str.43, i64 10 }, { ptr, i64 } { ptr @tn.str.44, i64 9 }, { ptr, i64 } { ptr @tn.str.45, i64 6 }, { ptr, i64 } { ptr @tn.str.46, i64 12 }, { ptr, i64 } { ptr @tn.str.47, i64 4 }, { ptr, i64 } { ptr @tn.str.48, i64 6 }, { ptr, i64 } { ptr @tn.str.49, i64 5 }, { ptr, i64 } { ptr @tn.str.50, i64 7 }, { ptr, i64 } { ptr @tn.str.51, i64 5 }, { ptr, i64 } { ptr @tn.str.52, i64 4 }, { ptr, i64 } { ptr @tn.str.53, i64 6 }, { ptr, i64 } { ptr @tn.str.54, i64 7 }, { ptr, i64 } { ptr @tn.str.55, i64 6 }, { ptr, i64 } { ptr @tn.str.56, i64 3 }, { ptr, i64 } { ptr @tn.str.57, i64 7 }, { ptr, i64 } { ptr @tn.str.58, i64 6 }, { ptr, i64 } { ptr @tn.str.59, i64 7 }, { ptr, i64 } { ptr @tn.str.60, i64 4 }, { ptr, i64 } { ptr @tn.str.61, i64 10 }, { ptr, i64 } { ptr @tn.str.62, i64 8 }, { ptr, i64 } { ptr @tn.str.63, i64 13 }, { ptr, i64 } { ptr @tn.str.64, i64 16 }, { ptr, i64 } { ptr @tn.str.65, i64 13 }, { ptr, i64 } { ptr @tn.str.66, i64 9 }, { ptr, i64 } { ptr @tn.str.67, i64 5 }, { ptr, i64 } { ptr @tn.str.68, i64 12 }, { ptr, i64 } { ptr @tn.str.69, i64 7 }, { ptr, i64 } { ptr @tn.str.70, i64 6 }, { ptr, i64 } { ptr @tn.str.71, i64 10 }, { ptr, i64 } { ptr @tn.str.72, i64 19 }, { ptr, i64 } { ptr @tn.str.73, i64 13 }, { ptr, i64 } { ptr @tn.str.74, i64 5 }, { ptr, i64 } { ptr @tn.str.75, i64 7 }, { ptr, i64 } { ptr @tn.str.76, i64 6 }, { ptr, i64 } { ptr @tn.str.77, i64 8 }, { ptr, i64 } { ptr @tn.str.78, i64 5 }, { ptr, i64 } { ptr @tn.str.79, i64 8 }, { ptr, i64 } { ptr @tn.str.80, i64 7 }, { ptr, i64 } { ptr @tn.str.81, i64 4 }, { ptr, i64 } { ptr @tn.str.82, i64 8 }, { ptr, i64 } { ptr @tn.str.83, i64 8 }] -@str.84 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 -@str.85 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 -@str.86 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@tn.str.44 = private constant [9 x i8] c"NSString\00" +@tn.str.45 = private constant [10 x i8] c"*NSString\00" +@tn.str.46 = private constant [10 x i8] c"Closure()\00" +@tn.str.47 = private constant [7 x i8] c"Triple\00" +@tn.str.48 = private constant [13 x i8] c"**CAllocator\00" +@tn.str.49 = private constant [5 x i8] c"*s64\00" +@tn.str.50 = private constant [7 x i8] c"**void\00" +@tn.str.51 = private constant [6 x i8] c"*bool\00" +@tn.str.52 = private constant [8 x i8] c"*string\00" +@tn.str.53 = private constant [6 x i8] c"[]Any\00" +@tn.str.54 = private constant [5 x i8] c"*Any\00" +@tn.str.55 = private constant [7 x i8] c"[1]Any\00" +@tn.str.56 = private constant [8 x i8] c"*[1]Any\00" +@tn.str.57 = private constant [7 x i8] c"*[]Any\00" +@tn.str.58 = private constant [4 x i8] c"*u8\00" +@tn.str.59 = private constant [8 x i8] c"*Triple\00" +@tn.str.60 = private constant [7 x i8] c"[3]Any\00" +@tn.str.61 = private constant [8 x i8] c"*[3]Any\00" +@tn.str.62 = private constant [5 x i8] c"*f64\00" +@tn.str.63 = private constant [11 x i8] c"*Allocator\00" +@tn.str.64 = private constant [9 x i8] c"*Context\00" +@tn.str.65 = private constant [14 x i8] c"*BuildOptions\00" +@tn.str.66 = private constant [17 x i8] c"*OperatingSystem\00" +@tn.str.67 = private constant [14 x i8] c"*Architecture\00" +@tn.str.68 = private constant [10 x i8] c"*[]string\00" +@tn.str.69 = private constant [6 x i8] c"**GPA\00" +@tn.str.70 = private constant [13 x i8] c"**ArenaChunk\00" +@tn.str.71 = private constant [8 x i8] c"**Arena\00" +@tn.str.72 = private constant [7 x i8] c"*[*]u8\00" +@tn.str.73 = private constant [11 x i8] c"**BufAlloc\00" +@tn.str.74 = private constant [20 x i8] c"**TrackingAllocator\00" +@tn.str.75 = private constant [11 x i8] c"**NSString\00" +@tn.str.76 = private constant [14 x i8] c"***CAllocator\00" +@tn.str.77 = private constant [6 x i8] c"**s64\00" +@tn.str.78 = private constant [8 x i8] c"***void\00" +@tn.str.79 = private constant [7 x i8] c"**bool\00" +@tn.str.80 = private constant [9 x i8] c"**string\00" +@tn.str.81 = private constant [6 x i8] c"**Any\00" +@tn.str.82 = private constant [9 x i8] c"**[1]Any\00" +@tn.str.83 = private constant [8 x i8] c"**[]Any\00" +@tn.str.84 = private constant [5 x i8] c"**u8\00" +@tn.str.85 = private constant [9 x i8] c"**Triple\00" +@tn.str.86 = private constant [9 x i8] c"**[3]Any\00" +@__sx_type_names = private constant [82 x { ptr, i64 }] [{ ptr, i64 } { ptr @tn.str, i64 12 }, { ptr, i64 } { ptr @tn.str.6, i64 4 }, { ptr, i64 } { ptr @tn.str.7, i64 2 }, { ptr, i64 } { ptr @tn.str.8, i64 3 }, { ptr, i64 } { ptr @tn.str.9, i64 3 }, { ptr, i64 } { ptr @tn.str.10, i64 3 }, { ptr, i64 } { ptr @tn.str.11, i64 2 }, { ptr, i64 } { ptr @tn.str.12, i64 3 }, { ptr, i64 } { ptr @tn.str.13, i64 3 }, { ptr, i64 } { ptr @tn.str.14, i64 3 }, { ptr, i64 } { ptr @tn.str.15, i64 3 }, { ptr, i64 } { ptr @tn.str.16, i64 3 }, { ptr, i64 } { ptr @tn.str.17, i64 6 }, { ptr, i64 } { ptr @tn.str.18, i64 3 }, { ptr, i64 } { ptr @tn.str.19, i64 8 }, { ptr, i64 } { ptr @tn.str.20, i64 5 }, { ptr, i64 } { ptr @tn.str.21, i64 5 }, { ptr, i64 } { ptr @tn.str.22, i64 4 }, { ptr, i64 } { ptr @tn.str.23, i64 5 }, { ptr, i64 } { ptr @tn.str.24, i64 9 }, { ptr, i64 } { ptr @tn.str.25, i64 10 }, { ptr, i64 } { ptr @tn.str.26, i64 11 }, { ptr, i64 } { ptr @tn.str.27, i64 3 }, { ptr, i64 } { ptr @tn.str.28, i64 4 }, { ptr, i64 } { ptr @tn.str.29, i64 10 }, { ptr, i64 } { ptr @tn.str.30, i64 11 }, { ptr, i64 } { ptr @tn.str.31, i64 5 }, { ptr, i64 } { ptr @tn.str.32, i64 6 }, { ptr, i64 } { ptr @tn.str.33, i64 5 }, { ptr, i64 } { ptr @tn.str.34, i64 8 }, { ptr, i64 } { ptr @tn.str.35, i64 9 }, { ptr, i64 } { ptr @tn.str.36, i64 17 }, { ptr, i64 } { ptr @tn.str.37, i64 18 }, { ptr, i64 } { ptr @tn.str.38, i64 7 }, { ptr, i64 } { ptr @tn.str.39, i64 8 }, { ptr, i64 } { ptr @tn.str.40, i64 15 }, { ptr, i64 } { ptr @tn.str.41, i64 12 }, { ptr, i64 } { ptr @tn.str.42, i64 12 }, { ptr, i64 } { ptr @tn.str.43, i64 10 }, { ptr, i64 } { ptr @tn.str.44, i64 8 }, { ptr, i64 } { ptr @tn.str.45, i64 9 }, { ptr, i64 } { ptr @tn.str.46, i64 9 }, { ptr, i64 } { ptr @tn.str.47, i64 6 }, { ptr, i64 } { ptr @tn.str.48, i64 12 }, { ptr, i64 } { ptr @tn.str.49, i64 4 }, { ptr, i64 } { ptr @tn.str.50, i64 6 }, { ptr, i64 } { ptr @tn.str.51, i64 5 }, { ptr, i64 } { ptr @tn.str.52, i64 7 }, { ptr, i64 } { ptr @tn.str.53, i64 5 }, { ptr, i64 } { ptr @tn.str.54, i64 4 }, { ptr, i64 } { ptr @tn.str.55, i64 6 }, { ptr, i64 } { ptr @tn.str.56, i64 7 }, { ptr, i64 } { ptr @tn.str.57, i64 6 }, { ptr, i64 } { ptr @tn.str.58, i64 3 }, { ptr, i64 } { ptr @tn.str.59, i64 7 }, { ptr, i64 } { ptr @tn.str.60, i64 6 }, { ptr, i64 } { ptr @tn.str.61, i64 7 }, { ptr, i64 } { ptr @tn.str.62, i64 4 }, { ptr, i64 } { ptr @tn.str.63, i64 10 }, { ptr, i64 } { ptr @tn.str.64, i64 8 }, { ptr, i64 } { ptr @tn.str.65, i64 13 }, { ptr, i64 } { ptr @tn.str.66, i64 16 }, { ptr, i64 } { ptr @tn.str.67, i64 13 }, { ptr, i64 } { ptr @tn.str.68, i64 9 }, { ptr, i64 } { ptr @tn.str.69, i64 5 }, { ptr, i64 } { ptr @tn.str.70, i64 12 }, { ptr, i64 } { ptr @tn.str.71, i64 7 }, { ptr, i64 } { ptr @tn.str.72, i64 6 }, { ptr, i64 } { ptr @tn.str.73, i64 10 }, { ptr, i64 } { ptr @tn.str.74, i64 19 }, { ptr, i64 } { ptr @tn.str.75, i64 10 }, { ptr, i64 } { ptr @tn.str.76, i64 13 }, { ptr, i64 } { ptr @tn.str.77, i64 5 }, { ptr, i64 } { ptr @tn.str.78, i64 7 }, { ptr, i64 } { ptr @tn.str.79, i64 6 }, { ptr, i64 } { ptr @tn.str.80, i64 8 }, { ptr, i64 } { ptr @tn.str.81, i64 5 }, { ptr, i64 } { ptr @tn.str.82, i64 8 }, { ptr, i64 } { ptr @tn.str.83, i64 7 }, { ptr, i64 } { ptr @tn.str.84, i64 4 }, { ptr, i64 } { ptr @tn.str.85, i64 8 }, { ptr, i64 } { ptr @tn.str.86, i64 8 }] @str.87 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 @str.88 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 -@str.89 = private unnamed_addr constant [15 x i8] c"result := \22\22; \00", align 1 -@str.90 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 -@str.91 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.92 = private unnamed_addr constant [5 x i8] c")); \00", align 1 -@str.93 = private unnamed_addr constant [44 x i8] c"result = concat(result, any_to_string(args[\00", align 1 -@str.94 = private unnamed_addr constant [6 x i8] c"])); \00", align 1 -@str.95 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 -@str.96 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.97 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.89 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.90 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.91 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.92 = private unnamed_addr constant [15 x i8] c"result := \22\22; \00", align 1 +@str.93 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.94 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.95 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.96 = private unnamed_addr constant [44 x i8] c"result = concat(result, any_to_string(args[\00", align 1 +@str.97 = private unnamed_addr constant [6 x i8] c"])); \00", align 1 @str.98 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 @str.99 = private unnamed_addr constant [3 x i8] c", \00", align 1 @str.100 = private unnamed_addr constant [5 x i8] c")); \00", align 1 @str.101 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 @str.102 = private unnamed_addr constant [3 x i8] c", \00", align 1 @str.103 = private unnamed_addr constant [5 x i8] c")); \00", align 1 -@str.104 = private unnamed_addr constant [9 x i8] c"NSObject\00", align 1 -@str.105 = private unnamed_addr constant [14 x i8] c"SxTripleProbe\00", align 1 -@str.106 = private unnamed_addr constant [12 x i8] c"tripleValue\00", align 1 -@str.107 = private unnamed_addr constant [15 x i8] c"{Triple=qqq}@:\00", align 1 -@str.108 = private unnamed_addr constant [16 x i8] c"addMethod = {}\0A\00", align 1 -@str.109 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 -@str.110 = private unnamed_addr constant [16 x i8] c"addMethod = {}\0A\00", align 1 -@str.111 = private unnamed_addr constant [23 x i8] c"triple = ({}, {}, {})\0A\00", align 1 +@str.104 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1 +@str.105 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.106 = private unnamed_addr constant [5 x i8] c")); \00", align 1 +@str.107 = private unnamed_addr constant [9 x i8] c"NSObject\00", align 1 +@str.108 = private unnamed_addr constant [14 x i8] c"SxTripleProbe\00", align 1 +@str.109 = private unnamed_addr constant [12 x i8] c"tripleValue\00", align 1 +@str.110 = private unnamed_addr constant [15 x i8] c"{Triple=qqq}@:\00", align 1 +@str.111 = private unnamed_addr constant [16 x i8] c"addMethod = {}\0A\00", align 1 @str.112 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 -@str.113 = private unnamed_addr constant [23 x i8] c"triple = ({}, {}, {})\0A\00", align 1 -@str.114 = private unnamed_addr constant [10 x i8] c"Allocator\00", align 1 -@str.115 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.116 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.117 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.113 = private unnamed_addr constant [16 x i8] c"addMethod = {}\0A\00", align 1 +@str.114 = private unnamed_addr constant [23 x i8] c"triple = ({}, {}, {})\0A\00", align 1 +@str.115 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1 +@str.116 = private unnamed_addr constant [23 x i8] c"triple = ({}, {}, {})\0A\00", align 1 +@str.117 = private unnamed_addr constant [10 x i8] c"Allocator\00", align 1 +@str.118 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.119 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.120 = private unnamed_addr constant [3 x i8] c", \00", align 1 @fld.str = private constant [4 x i8] c"ctx\00" -@fld.str.118 = private constant [6 x i8] c"alloc\00" -@fld.str.119 = private constant [8 x i8] c"dealloc\00" -@field_names = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str, i64 3 }, { ptr, i64 } { ptr @fld.str.118, i64 5 }, { ptr, i64 } { ptr @fld.str.119, i64 7 }] -@str.120 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.121 = private unnamed_addr constant [11 x i8] c"CAllocator\00", align 1 -@str.122 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.123 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.124 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@field_names.125 = private constant [0 x { ptr, i64 }] zeroinitializer -@str.126 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.127 = private unnamed_addr constant [4 x i8] c"GPA\00", align 1 -@str.128 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.129 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.130 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.131 = private constant [12 x i8] c"alloc_count\00" -@field_names.132 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.131, i64 11 }] -@str.133 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.134 = private unnamed_addr constant [11 x i8] c"ArenaChunk\00", align 1 -@str.135 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.136 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.137 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.138 = private constant [5 x i8] c"next\00" -@fld.str.139 = private constant [4 x i8] c"cap\00" -@field_names.140 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.138, i64 4 }, { ptr, i64 } { ptr @fld.str.139, i64 3 }] -@str.141 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.142 = private unnamed_addr constant [6 x i8] c"Arena\00", align 1 -@str.143 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.144 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.145 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.146 = private constant [6 x i8] c"first\00" -@fld.str.147 = private constant [10 x i8] c"end_index\00" -@fld.str.148 = private constant [7 x i8] c"parent\00" -@field_names.149 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.146, i64 5 }, { ptr, i64 } { ptr @fld.str.147, i64 9 }, { ptr, i64 } { ptr @fld.str.148, i64 6 }] -@str.150 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.151 = private unnamed_addr constant [9 x i8] c"BufAlloc\00", align 1 -@str.152 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.153 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.154 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.155 = private constant [4 x i8] c"buf\00" -@fld.str.156 = private constant [4 x i8] c"len\00" -@fld.str.157 = private constant [4 x i8] c"pos\00" -@field_names.158 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.155, i64 3 }, { ptr, i64 } { ptr @fld.str.156, i64 3 }, { ptr, i64 } { ptr @fld.str.157, i64 3 }] -@str.159 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.160 = private unnamed_addr constant [18 x i8] c"TrackingAllocator\00", align 1 -@str.161 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.162 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.163 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.164 = private constant [7 x i8] c"parent\00" -@fld.str.165 = private constant [12 x i8] c"alloc_count\00" -@fld.str.166 = private constant [14 x i8] c"dealloc_count\00" -@fld.str.167 = private constant [18 x i8] c"total_alloc_bytes\00" -@field_names.168 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.164, i64 6 }, { ptr, i64 } { ptr @fld.str.165, i64 11 }, { ptr, i64 } { ptr @fld.str.166, i64 13 }, { ptr, i64 } { ptr @fld.str.167, i64 17 }] -@str.169 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.170 = private unnamed_addr constant [8 x i8] c"Context\00", align 1 -@str.171 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.172 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.173 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.174 = private constant [10 x i8] c"allocator\00" -@fld.str.175 = private constant [5 x i8] c"data\00" -@field_names.176 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.174, i64 9 }, { ptr, i64 } { ptr @fld.str.175, i64 4 }] -@str.177 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.178 = private unnamed_addr constant [13 x i8] c"BuildOptions\00", align 1 -@str.179 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.180 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.181 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@field_names.182 = private constant [0 x { ptr, i64 }] zeroinitializer -@str.183 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.184 = private unnamed_addr constant [7 x i8] c"Triple\00", align 1 -@str.185 = private unnamed_addr constant [2 x i8] c"{\00", align 1 -@str.186 = private unnamed_addr constant [2 x i8] c"}\00", align 1 -@str.187 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@fld.str.188 = private constant [2 x i8] c"a\00" -@fld.str.189 = private constant [2 x i8] c"b\00" -@fld.str.190 = private constant [2 x i8] c"c\00" -@field_names.191 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.188, i64 1 }, { ptr, i64 } { ptr @fld.str.189, i64 1 }, { ptr, i64 } { ptr @fld.str.190, i64 1 }] +@fld.str.121 = private constant [6 x i8] c"alloc\00" +@fld.str.122 = private constant [8 x i8] c"dealloc\00" +@field_names = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str, i64 3 }, { ptr, i64 } { ptr @fld.str.121, i64 5 }, { ptr, i64 } { ptr @fld.str.122, i64 7 }] +@str.123 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.124 = private unnamed_addr constant [11 x i8] c"CAllocator\00", align 1 +@str.125 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.126 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.127 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@field_names.128 = private constant [0 x { ptr, i64 }] zeroinitializer +@str.129 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.130 = private unnamed_addr constant [4 x i8] c"GPA\00", align 1 +@str.131 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.132 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.133 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.134 = private constant [12 x i8] c"alloc_count\00" +@field_names.135 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.134, i64 11 }] +@str.136 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.137 = private unnamed_addr constant [11 x i8] c"ArenaChunk\00", align 1 +@str.138 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.139 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.140 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.141 = private constant [5 x i8] c"next\00" +@fld.str.142 = private constant [4 x i8] c"cap\00" +@field_names.143 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.141, i64 4 }, { ptr, i64 } { ptr @fld.str.142, i64 3 }] +@str.144 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.145 = private unnamed_addr constant [6 x i8] c"Arena\00", align 1 +@str.146 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.147 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.148 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.149 = private constant [6 x i8] c"first\00" +@fld.str.150 = private constant [10 x i8] c"end_index\00" +@fld.str.151 = private constant [7 x i8] c"parent\00" +@field_names.152 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.149, i64 5 }, { ptr, i64 } { ptr @fld.str.150, i64 9 }, { ptr, i64 } { ptr @fld.str.151, i64 6 }] +@str.153 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.154 = private unnamed_addr constant [9 x i8] c"BufAlloc\00", align 1 +@str.155 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.156 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.157 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.158 = private constant [4 x i8] c"buf\00" +@fld.str.159 = private constant [4 x i8] c"len\00" +@fld.str.160 = private constant [4 x i8] c"pos\00" +@field_names.161 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.158, i64 3 }, { ptr, i64 } { ptr @fld.str.159, i64 3 }, { ptr, i64 } { ptr @fld.str.160, i64 3 }] +@str.162 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.163 = private unnamed_addr constant [18 x i8] c"TrackingAllocator\00", align 1 +@str.164 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.165 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.166 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.167 = private constant [7 x i8] c"parent\00" +@fld.str.168 = private constant [12 x i8] c"alloc_count\00" +@fld.str.169 = private constant [14 x i8] c"dealloc_count\00" +@fld.str.170 = private constant [18 x i8] c"total_alloc_bytes\00" +@field_names.171 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.167, i64 6 }, { ptr, i64 } { ptr @fld.str.168, i64 11 }, { ptr, i64 } { ptr @fld.str.169, i64 13 }, { ptr, i64 } { ptr @fld.str.170, i64 17 }] +@str.172 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.173 = private unnamed_addr constant [8 x i8] c"Context\00", align 1 +@str.174 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.175 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.176 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.177 = private constant [10 x i8] c"allocator\00" +@fld.str.178 = private constant [5 x i8] c"data\00" +@field_names.179 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.177, i64 9 }, { ptr, i64 } { ptr @fld.str.178, i64 4 }] +@str.180 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.181 = private unnamed_addr constant [13 x i8] c"BuildOptions\00", align 1 +@str.182 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.183 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.184 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@field_names.185 = private constant [0 x { ptr, i64 }] zeroinitializer +@str.186 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.187 = private unnamed_addr constant [9 x i8] c"NSString\00", align 1 +@str.188 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.189 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.190 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@field_names.191 = private constant [0 x { ptr, i64 }] zeroinitializer @str.192 = private unnamed_addr constant [3 x i8] c": \00", align 1 -@str.193 = private unnamed_addr constant [2 x i8] c".\00", align 1 -@fld.str.194 = private constant [6 x i8] c"macos\00" -@fld.str.195 = private constant [6 x i8] c"linux\00" -@fld.str.196 = private constant [8 x i8] c"windows\00" -@fld.str.197 = private constant [5 x i8] c"wasm\00" -@fld.str.198 = private constant [4 x i8] c"ios\00" -@fld.str.199 = private constant [8 x i8] c"android\00" -@fld.str.200 = private constant [8 x i8] c"unknown\00" -@field_names.201 = private constant [7 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.194, i64 5 }, { ptr, i64 } { ptr @fld.str.195, i64 5 }, { ptr, i64 } { ptr @fld.str.196, i64 7 }, { ptr, i64 } { ptr @fld.str.197, i64 4 }, { ptr, i64 } { ptr @fld.str.198, i64 3 }, { ptr, i64 } { ptr @fld.str.199, i64 7 }, { ptr, i64 } { ptr @fld.str.200, i64 7 }] -@str.202 = private unnamed_addr constant [2 x i8] c"(\00", align 1 -@str.203 = private unnamed_addr constant [2 x i8] c")\00", align 1 -@str.204 = private unnamed_addr constant [2 x i8] c".\00", align 1 -@fld.str.205 = private constant [8 x i8] c"aarch64\00" -@fld.str.206 = private constant [7 x i8] c"x86_64\00" -@fld.str.207 = private constant [7 x i8] c"wasm32\00" -@fld.str.208 = private constant [7 x i8] c"wasm64\00" +@str.193 = private unnamed_addr constant [7 x i8] c"Triple\00", align 1 +@str.194 = private unnamed_addr constant [2 x i8] c"{\00", align 1 +@str.195 = private unnamed_addr constant [2 x i8] c"}\00", align 1 +@str.196 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@fld.str.197 = private constant [2 x i8] c"a\00" +@fld.str.198 = private constant [2 x i8] c"b\00" +@fld.str.199 = private constant [2 x i8] c"c\00" +@field_names.200 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.197, i64 1 }, { ptr, i64 } { ptr @fld.str.198, i64 1 }, { ptr, i64 } { ptr @fld.str.199, i64 1 }] +@str.201 = private unnamed_addr constant [3 x i8] c": \00", align 1 +@str.202 = private unnamed_addr constant [2 x i8] c".\00", align 1 +@fld.str.203 = private constant [6 x i8] c"macos\00" +@fld.str.204 = private constant [6 x i8] c"linux\00" +@fld.str.205 = private constant [8 x i8] c"windows\00" +@fld.str.206 = private constant [5 x i8] c"wasm\00" +@fld.str.207 = private constant [4 x i8] c"ios\00" +@fld.str.208 = private constant [8 x i8] c"android\00" @fld.str.209 = private constant [8 x i8] c"unknown\00" -@field_names.210 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.205, i64 7 }, { ptr, i64 } { ptr @fld.str.206, i64 6 }, { ptr, i64 } { ptr @fld.str.207, i64 6 }, { ptr, i64 } { ptr @fld.str.208, i64 6 }, { ptr, i64 } { ptr @fld.str.209, i64 7 }] +@field_names.210 = private constant [7 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.203, i64 5 }, { ptr, i64 } { ptr @fld.str.204, i64 5 }, { ptr, i64 } { ptr @fld.str.205, i64 7 }, { ptr, i64 } { ptr @fld.str.206, i64 4 }, { ptr, i64 } { ptr @fld.str.207, i64 3 }, { ptr, i64 } { ptr @fld.str.208, i64 7 }, { ptr, i64 } { ptr @fld.str.209, i64 7 }] @str.211 = private unnamed_addr constant [2 x i8] c"(\00", align 1 @str.212 = private unnamed_addr constant [2 x i8] c")\00", align 1 -@str.213 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.214 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.215 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.216 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.217 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.218 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.219 = private unnamed_addr constant [2 x i8] c"[\00", align 1 -@str.220 = private unnamed_addr constant [2 x i8] c"]\00", align 1 -@str.221 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.213 = private unnamed_addr constant [2 x i8] c".\00", align 1 +@fld.str.214 = private constant [8 x i8] c"aarch64\00" +@fld.str.215 = private constant [7 x i8] c"x86_64\00" +@fld.str.216 = private constant [7 x i8] c"wasm32\00" +@fld.str.217 = private constant [7 x i8] c"wasm64\00" +@fld.str.218 = private constant [8 x i8] c"unknown\00" +@field_names.219 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.214, i64 7 }, { ptr, i64 } { ptr @fld.str.215, i64 6 }, { ptr, i64 } { ptr @fld.str.216, i64 6 }, { ptr, i64 } { ptr @fld.str.217, i64 6 }, { ptr, i64 } { ptr @fld.str.218, i64 7 }] +@str.220 = private unnamed_addr constant [2 x i8] c"(\00", align 1 +@str.221 = private unnamed_addr constant [2 x i8] c")\00", align 1 @str.222 = private unnamed_addr constant [2 x i8] c"[\00", align 1 @str.223 = private unnamed_addr constant [2 x i8] c"]\00", align 1 @str.224 = private unnamed_addr constant [3 x i8] c", \00", align 1 -@str.225 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.226 = private unnamed_addr constant [6 x i8] c"*void\00", align 1 -@str.227 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.228 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.229 = private unnamed_addr constant [12 x i8] c"*CAllocator\00", align 1 -@str.230 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 -@str.231 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.232 = private unnamed_addr constant [5 x i8] c"*GPA\00", align 1 -@str.233 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.225 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.226 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.227 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.228 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.229 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.230 = private unnamed_addr constant [3 x i8] c", \00", align 1 +@str.231 = private unnamed_addr constant [2 x i8] c"[\00", align 1 +@str.232 = private unnamed_addr constant [2 x i8] c"]\00", align 1 +@str.233 = private unnamed_addr constant [3 x i8] c", \00", align 1 @str.234 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.235 = private unnamed_addr constant [12 x i8] c"*ArenaChunk\00", align 1 +@str.235 = private unnamed_addr constant [6 x i8] c"*void\00", align 1 @str.236 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 @str.237 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.238 = private unnamed_addr constant [7 x i8] c"*Arena\00", align 1 +@str.238 = private unnamed_addr constant [12 x i8] c"*CAllocator\00", align 1 @str.239 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 @str.240 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.241 = private unnamed_addr constant [6 x i8] c"[*]u8\00", align 1 +@str.241 = private unnamed_addr constant [5 x i8] c"*GPA\00", align 1 @str.242 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 @str.243 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.244 = private unnamed_addr constant [10 x i8] c"*BufAlloc\00", align 1 +@str.244 = private unnamed_addr constant [12 x i8] c"*ArenaChunk\00", align 1 @str.245 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 @str.246 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.247 = private unnamed_addr constant [19 x i8] c"*TrackingAllocator\00", align 1 +@str.247 = private unnamed_addr constant [7 x i8] c"*Arena\00", align 1 @str.248 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 @str.249 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.250 = private unnamed_addr constant [13 x i8] c"**CAllocator\00", align 1 +@str.250 = private unnamed_addr constant [6 x i8] c"[*]u8\00", align 1 @str.251 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 @str.252 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.253 = private unnamed_addr constant [5 x i8] c"*s64\00", align 1 +@str.253 = private unnamed_addr constant [10 x i8] c"*BufAlloc\00", align 1 @str.254 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 @str.255 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.256 = private unnamed_addr constant [7 x i8] c"**void\00", align 1 +@str.256 = private unnamed_addr constant [19 x i8] c"*TrackingAllocator\00", align 1 @str.257 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 @str.258 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.259 = private unnamed_addr constant [6 x i8] c"*bool\00", align 1 +@str.259 = private unnamed_addr constant [10 x i8] c"*NSString\00", align 1 @str.260 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 @str.261 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.262 = private unnamed_addr constant [8 x i8] c"*string\00", align 1 +@str.262 = private unnamed_addr constant [13 x i8] c"**CAllocator\00", align 1 @str.263 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 @str.264 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.265 = private unnamed_addr constant [5 x i8] c"*Any\00", align 1 +@str.265 = private unnamed_addr constant [5 x i8] c"*s64\00", align 1 @str.266 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 @str.267 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.268 = private unnamed_addr constant [8 x i8] c"*[1]Any\00", align 1 +@str.268 = private unnamed_addr constant [7 x i8] c"**void\00", align 1 @str.269 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 @str.270 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.271 = private unnamed_addr constant [7 x i8] c"*[]Any\00", align 1 +@str.271 = private unnamed_addr constant [6 x i8] c"*bool\00", align 1 @str.272 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 @str.273 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.274 = private unnamed_addr constant [4 x i8] c"*u8\00", align 1 +@str.274 = private unnamed_addr constant [8 x i8] c"*string\00", align 1 @str.275 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 @str.276 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.277 = private unnamed_addr constant [8 x i8] c"*Triple\00", align 1 +@str.277 = private unnamed_addr constant [5 x i8] c"*Any\00", align 1 @str.278 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 @str.279 = private unnamed_addr constant [5 x i8] c"null\00", align 1 -@str.280 = private unnamed_addr constant [8 x i8] c"*[3]Any\00", align 1 +@str.280 = private unnamed_addr constant [8 x i8] c"*[1]Any\00", align 1 @str.281 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.282 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.283 = private unnamed_addr constant [7 x i8] c"*[]Any\00", align 1 +@str.284 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.285 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.286 = private unnamed_addr constant [4 x i8] c"*u8\00", align 1 +@str.287 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.288 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.289 = private unnamed_addr constant [8 x i8] c"*Triple\00", align 1 +@str.290 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 +@str.291 = private unnamed_addr constant [5 x i8] c"null\00", align 1 +@str.292 = private unnamed_addr constant [8 x i8] c"*[3]Any\00", align 1 +@str.293 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1 @OBJC_METH_VAR_NAME_ = private unnamed_addr constant [12 x i8] c"tripleValue\00" @llvm.global_ctors = appending global [1 x { i32, ptr, ptr }] [{ i32, ptr, ptr } { i32 65535, ptr @__sx_objc_selector_init, ptr null }] @@ -685,39 +697,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.201 + br label %while.hdr.208 -while.hdr.201: ; preds = %if.merge.206, %entry +while.hdr.208: ; preds = %if.merge.213, %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.202, label %while.exit.203 + br i1 %icmp, label %while.body.209, label %while.exit.210 -while.body.202: ; preds = %while.hdr.201 +while.body.209: ; preds = %while.hdr.208 %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.204, label %if.else.205 + br i1 %icmpN, label %if.then.211, label %if.else.212 -while.exit.203: ; preds = %while.hdr.201 +while.exit.210: ; preds = %while.hdr.208 ret void -if.then.204: ; preds = %while.body.202 +if.then.211: ; preds = %while.body.209 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 48 - br label %if.merge.206 + br label %if.merge.213 -if.else.205: ; preds = %while.body.202 +if.else.212: ; preds = %while.body.209 %loadN = load i64, ptr %allocaN, align 8 %sub = sub i64 %loadN, 10 %addN = add i64 %sub, 97 - br label %if.merge.206 + br label %if.merge.213 -if.merge.206: ; preds = %if.else.205, %if.then.204 - %bp = phi i64 [ %addN, %if.then.204 ], [ %addN, %if.else.205 ] +if.merge.213: ; preds = %if.else.212, %if.then.211 + %bp = phi i64 [ %addN, %if.then.211 ], [ %addN, %if.else.212 ] %loadN = load i64, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %alloca, align 8 %igp.data = extractvalue { ptr, i64 } %loadN, 0 @@ -730,7 +742,7 @@ if.merge.206: ; preds = %if.else.205, %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.201 + br label %while.hdr.208 } ; Function Attrs: nounwind @@ -740,27 +752,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.191, label %if.merge.192 + br i1 %icmp, label %if.then.198, label %if.merge.199 -if.then.191: ; preds = %entry +if.then.198: ; preds = %entry ret { ptr, i64 } { ptr @str.3, i64 1 } -if.merge.192: ; preds = %entry +if.merge.199: ; 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.193, label %if.merge.194 + br i1 %icmpN, label %if.then.200, label %if.merge.201 -if.then.193: ; preds = %if.merge.192 +if.then.200: ; preds = %if.merge.199 %loadN = load i64, ptr %allocaN, align 8 %add = add i64 %loadN, 65536 store i64 %add, ptr %allocaN, align 8 - br label %if.merge.194 + br label %if.merge.201 -if.merge.194: ; preds = %if.then.193, %if.merge.192 +if.merge.201: ; preds = %if.then.200, %if.merge.199 %loadN = load i64, ptr %alloca, align 8 %loadN = load i64, ptr %allocaN, align 8 %sub = sub i64 %loadN, %loadN @@ -773,15 +785,15 @@ if.merge.194: ; preds = %if.then.193, %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.195, label %if.merge.196 + br i1 %icmpN, label %if.then.202, label %if.merge.203 -if.then.195: ; preds = %if.merge.194 +if.then.202: ; preds = %if.merge.201 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 65536 store i64 %addN, ptr %allocaN, align 8 - br label %if.merge.196 + br label %if.merge.203 -if.merge.196: ; preds = %if.then.195, %if.merge.194 +if.merge.203: ; preds = %if.then.202, %if.merge.201 %loadN = load i64, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %subN = sub i64 %loadN, %loadN @@ -794,15 +806,15 @@ if.merge.196: ; preds = %if.then.195, %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.197, label %if.merge.198 + br i1 %icmpN, label %if.then.204, label %if.merge.205 -if.then.197: ; preds = %if.merge.196 +if.then.204: ; preds = %if.merge.203 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 65536 store i64 %addN, ptr %allocaN, align 8 - br label %if.merge.198 + br label %if.merge.205 -if.merge.198: ; preds = %if.then.197, %if.merge.196 +if.merge.205: ; preds = %if.then.204, %if.merge.203 %loadN = load i64, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %subN = sub i64 %loadN, %loadN @@ -815,15 +827,15 @@ if.merge.198: ; preds = %if.then.197, %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.199, label %if.merge.200 + br i1 %icmpN, label %if.then.206, label %if.merge.207 -if.then.199: ; preds = %if.merge.198 +if.then.206: ; preds = %if.merge.205 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 65536 store i64 %addN, ptr %allocaN, align 8 - br label %if.merge.200 + br label %if.merge.207 -if.merge.200: ; preds = %if.then.199, %if.merge.198 +if.merge.207: ; preds = %if.then.206, %if.merge.205 %call = call { ptr, i64 } @cstring(ptr %0, i64 16) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 @@ -841,14 +853,14 @@ if.merge.200: ; preds = %if.then.199, %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.207 + br label %while.hdr.214 -while.hdr.207: ; preds = %if.merge.211, %if.merge.200 +while.hdr.214: ; preds = %if.merge.218, %if.merge.207 %loadN = load i64, ptr %allocaN, align 8 %icmpN = icmp slt i64 %loadN, 15 - br i1 %icmpN, label %while.body.208, label %while.exit.209 + br i1 %icmpN, label %while.body.215, label %while.exit.216 -while.body.208: ; preds = %while.hdr.207 +while.body.215: ; preds = %while.hdr.214 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %ig.data = extractvalue { ptr, i64 } %loadN, 0 @@ -856,9 +868,9 @@ while.body.208: ; preds = %while.hdr.207 %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.210, label %if.merge.211 + br i1 %icmpN, label %if.then.217, label %if.merge.218 -while.exit.209: ; preds = %if.then.210, %while.hdr.207 +while.exit.216: ; preds = %if.then.217, %while.hdr.214 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -866,14 +878,14 @@ while.exit.209: ; preds = %if.then.210, %while %callN = call { ptr, i64 } @substr(ptr %0, { ptr, i64 } %loadN, i64 %loadN, i64 %subN) ret { ptr, i64 } %callN -if.then.210: ; preds = %while.body.208 - br label %while.exit.209 +if.then.217: ; preds = %while.body.215 + br label %while.exit.216 -if.merge.211: ; preds = %while.body.208 +if.merge.218: ; preds = %while.body.215 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 1 store i64 %addN, ptr %allocaN, align 8 - br label %while.hdr.207 + br label %while.hdr.214 } ; Function Attrs: nounwind @@ -985,13 +997,14 @@ entry: i64 31, label %match.arm.44 i64 33, label %match.arm.44 i64 37, label %match.arm.44 - i64 40, label %match.arm.44 + i64 39, label %match.arm.44 + i64 42, label %match.arm.44 i64 35, label %match.arm.45 i64 36, label %match.arm.45 - i64 48, label %match.arm.47 - i64 53, label %match.arm.47 + i64 50, label %match.arm.47 + i64 55, label %match.arm.47 i64 34, label %match.arm.48 - i64 46, label %match.arm.48 + i64 48, label %match.arm.48 i64 18, label %match.arm.49 i64 21, label %match.arm.49 i64 23, label %match.arm.49 @@ -1000,21 +1013,22 @@ entry: i64 28, label %match.arm.49 i64 30, label %match.arm.49 i64 32, label %match.arm.49 - i64 41, label %match.arm.49 - i64 42, label %match.arm.49 + i64 40, label %match.arm.49 i64 43, label %match.arm.49 i64 44, label %match.arm.49 i64 45, label %match.arm.49 + i64 46, label %match.arm.49 i64 47, label %match.arm.49 i64 49, label %match.arm.49 - i64 50, label %match.arm.49 i64 51, label %match.arm.49 i64 52, label %match.arm.49 + i64 53, label %match.arm.49 i64 54, label %match.arm.49 + i64 56, label %match.arm.49 i64 13, label %match.arm.51 ] -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 +match.merge.38: ; preds = %dispatch.merge.173, %dispatch.merge.159, %dispatch.merge.145, %dispatch.merge.137, %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 @@ -1055,7 +1069,7 @@ match.arm.43: ; preds = %entry, %entry %icmp = icmp eq i64 %sgN, 10 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 +match.arm.44: ; preds = %entry, %entry, %entry, %entry, %entry, %entry, %entry, %entry, %entry, %entry, %entry %loadN = load { i64, i64 }, ptr %allocaN, align 8 %ua.raw18 = extractvalue { i64, i64 } %loadN, 1 %loadN = load { i64, i64 }, ptr %alloca, align 8 @@ -1070,7 +1084,8 @@ match.arm.44: ; preds = %entry, %entry, %ent i64 31, label %dispatch.case.77 i64 33, label %dispatch.case.78 i64 37, label %dispatch.case.79 - i64 40, label %dispatch.case.80 + i64 39, label %dispatch.case.80 + i64 42, label %dispatch.case.81 ] match.arm.45: ; preds = %entry, %entry @@ -1078,9 +1093,9 @@ match.arm.45: ; preds = %entry, %entry %ua.raw22 = extractvalue { i64, i64 } %loadN, 1 %loadN = load { i64, i64 }, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - switch i64 %ua.raw22, label %dispatch.default.132 [ - i64 35, label %dispatch.case.133 - i64 36, label %dispatch.case.134 + switch i64 %ua.raw22, label %dispatch.default.138 [ + i64 35, label %dispatch.case.139 + i64 36, label %dispatch.case.140 ] match.arm.46: ; No predecessors! @@ -1091,9 +1106,9 @@ match.arm.47: ; preds = %entry, %entry %ua.raw26 = extractvalue { i64, i64 } %loadN, 1 %loadN = load { i64, i64 }, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - switch i64 %ua.raw26, label %dispatch.default.140 [ - i64 48, label %dispatch.case.141 - i64 53, label %dispatch.case.142 + switch i64 %ua.raw26, label %dispatch.default.146 [ + i64 50, label %dispatch.case.147 + i64 55, label %dispatch.case.148 ] match.arm.48: ; preds = %entry, %entry @@ -1101,36 +1116,37 @@ match.arm.48: ; preds = %entry, %entry %ua.raw30 = extractvalue { i64, i64 } %loadN, 1 %loadN = load { i64, i64 }, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - switch i64 %ua.raw30, label %dispatch.default.154 [ - i64 34, label %dispatch.case.155 - i64 46, label %dispatch.case.156 + switch i64 %ua.raw30, label %dispatch.default.160 [ + i64 34, label %dispatch.case.161 + i64 48, label %dispatch.case.162 ] -match.arm.49: ; preds = %entry, %entry, %entry, %entry, %entry, %entry, %entry, %entry, %entry, %entry, %entry, %entry, %entry, %entry, %entry, %entry, %entry, %entry, %entry +match.arm.49: ; preds = %entry, %entry, %entry, %entry, %entry, %entry, %entry, %entry, %entry, %entry, %entry, %entry, %entry, %entry, %entry, %entry, %entry, %entry, %entry, %entry %loadN = load { i64, i64 }, ptr %allocaN, align 8 %ua.raw34 = extractvalue { i64, i64 } %loadN, 1 %loadN = load { i64, i64 }, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - switch i64 %ua.raw34, label %dispatch.default.168 [ - i64 18, label %dispatch.case.169 - i64 21, label %dispatch.case.170 - i64 23, label %dispatch.case.171 - i64 25, label %dispatch.case.172 - i64 27, label %dispatch.case.173 - i64 28, label %dispatch.case.174 - i64 30, label %dispatch.case.175 - i64 32, label %dispatch.case.176 - i64 41, label %dispatch.case.177 - i64 42, label %dispatch.case.178 - i64 43, label %dispatch.case.179 - i64 44, label %dispatch.case.180 - i64 45, label %dispatch.case.181 - i64 47, label %dispatch.case.182 - i64 49, label %dispatch.case.183 - i64 50, label %dispatch.case.184 - i64 51, label %dispatch.case.185 - i64 52, label %dispatch.case.186 - i64 54, label %dispatch.case.187 + switch i64 %ua.raw34, label %dispatch.default.174 [ + i64 18, label %dispatch.case.175 + i64 21, label %dispatch.case.176 + i64 23, label %dispatch.case.177 + i64 25, label %dispatch.case.178 + i64 27, label %dispatch.case.179 + i64 28, label %dispatch.case.180 + i64 30, label %dispatch.case.181 + i64 32, label %dispatch.case.182 + i64 40, label %dispatch.case.183 + i64 43, label %dispatch.case.184 + i64 44, label %dispatch.case.185 + i64 45, label %dispatch.case.186 + i64 46, label %dispatch.case.187 + i64 47, label %dispatch.case.188 + i64 49, label %dispatch.case.189 + i64 51, label %dispatch.case.190 + i64 52, label %dispatch.case.191 + i64 53, label %dispatch.case.192 + i64 54, label %dispatch.case.193 + i64 56, label %dispatch.case.194 ] match.arm.50: ; No predecessors! @@ -1139,7 +1155,7 @@ match.arm.50: ; No predecessors! match.arm.51: ; preds = %entry %loadN = load { i64, i64 }, ptr %alloca, align 8 %tn.tid = extractvalue { i64, i64 } %loadN, 1 - %tn.gep = getelementptr inbounds [79 x { ptr, i64 }], ptr @__sx_type_names, i64 0, i64 %tn.tid + %tn.gep = getelementptr inbounds [82 x { ptr, i64 }], ptr @__sx_type_names, i64 0, i64 %tn.tid %tn.load = load { ptr, i64 }, ptr %tn.gep, align 8 store { ptr, i64 } %tn.load, ptr %allocaN, align 8 br label %match.merge.38 @@ -1167,13 +1183,13 @@ float.merge.58: ; preds = %fN.unbox.57, %fN.un store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %match.merge.38 -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 +dispatch.merge.69: ; preds = %dispatch.case.81, %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.70: ; preds = %match.arm.44 - store { ptr, i64 } { ptr @str.84, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.87, i64 0 }, ptr %allocaN, align 8 br label %dispatch.merge.69 dispatch.case.71: ; preds = %match.arm.44 @@ -1251,223 +1267,238 @@ dispatch.case.79: ; preds = %match.arm.44 dispatch.case.80: ; preds = %match.arm.44 %ua.raw79 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr80 = inttoptr i64 %ua.raw79 to ptr - %ua.load81 = load { i64, i64, i64 }, ptr %ua.ptr80, align 8 - %callN = call { ptr, i64 } @struct_to_string__Triple(ptr %0, { i64, i64, i64 } %ua.load81) + %ua.load81 = load {}, ptr %ua.ptr80, align 1 + %callN = call { ptr, i64 } @struct_to_string__NSString(ptr %0, {} %ua.load81) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %dispatch.merge.69 -dispatch.merge.131: ; preds = %dispatch.case.134, %dispatch.case.133, %dispatch.default.132 +dispatch.case.81: ; preds = %match.arm.44 + %ua.raw83 = extractvalue { i64, i64 } %loadN, 1 + %ua.ptr84 = inttoptr i64 %ua.raw83 to ptr + %ua.load85 = load { i64, i64, i64 }, ptr %ua.ptr84, align 8 + %callN = call { ptr, i64 } @struct_to_string__Triple(ptr %0, { i64, i64, i64 } %ua.load85) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + br label %dispatch.merge.69 + +dispatch.merge.137: ; preds = %dispatch.case.140, %dispatch.case.139, %dispatch.default.138 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 store { ptr, i64 } %loadN, ptr %allocaN, align 8 br label %match.merge.38 -dispatch.default.132: ; preds = %match.arm.45 - store { ptr, i64 } { ptr @str.85, i64 0 }, ptr %allocaN, align 8 - br label %dispatch.merge.131 +dispatch.default.138: ; preds = %match.arm.45 + store { ptr, i64 } { ptr @str.88, i64 0 }, ptr %allocaN, align 8 + br label %dispatch.merge.137 -dispatch.case.133: ; preds = %match.arm.45 - %ua.raw84 = extractvalue { i64, i64 } %loadN, 1 - %callN = call { ptr, i64 } @enum_to_string__OperatingSystem(ptr %0, i64 %ua.raw84) +dispatch.case.139: ; preds = %match.arm.45 + %ua.raw88 = extractvalue { i64, i64 } %loadN, 1 + %callN = call { ptr, i64 } @enum_to_string__OperatingSystem(ptr %0, i64 %ua.raw88) store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %dispatch.merge.131 + br label %dispatch.merge.137 -dispatch.case.134: ; preds = %match.arm.45 - %ua.raw86 = extractvalue { i64, i64 } %loadN, 1 - %callN = call { ptr, i64 } @enum_to_string__Architecture(ptr %0, i64 %ua.raw86) +dispatch.case.140: ; preds = %match.arm.45 + %ua.raw90 = extractvalue { i64, i64 } %loadN, 1 + %callN = call { ptr, i64 } @enum_to_string__Architecture(ptr %0, i64 %ua.raw90) store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %dispatch.merge.131 + br label %dispatch.merge.137 -dispatch.merge.139: ; preds = %dispatch.case.142, %dispatch.case.141, %dispatch.default.140 +dispatch.merge.145: ; preds = %dispatch.case.148, %dispatch.case.147, %dispatch.default.146 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 store { ptr, i64 } %loadN, ptr %allocaN, align 8 br label %match.merge.38 -dispatch.default.140: ; preds = %match.arm.47 - store { ptr, i64 } { ptr @str.86, i64 0 }, ptr %allocaN, align 8 - br label %dispatch.merge.139 +dispatch.default.146: ; preds = %match.arm.47 + store { ptr, i64 } { ptr @str.89, i64 0 }, ptr %allocaN, align 8 + br label %dispatch.merge.145 -dispatch.case.141: ; preds = %match.arm.47 - %ua.raw89 = extractvalue { i64, i64 } %loadN, 1 - %ua.ptr90 = inttoptr i64 %ua.raw89 to ptr - %ua.load91 = load [1 x { i64, i64 }], ptr %ua.ptr90, align 8 - %callN = call { ptr, i64 } @array_to_string__AR_1_Any(ptr %0, [1 x { i64, i64 }] %ua.load91) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %dispatch.merge.139 - -dispatch.case.142: ; preds = %match.arm.47 +dispatch.case.147: ; preds = %match.arm.47 %ua.raw93 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr94 = inttoptr i64 %ua.raw93 to ptr - %ua.load95 = load [3 x { i64, i64 }], ptr %ua.ptr94, align 8 - %callN = call { ptr, i64 } @array_to_string__AR_3_Any(ptr %0, [3 x { i64, i64 }] %ua.load95) + %ua.load95 = load [1 x { i64, i64 }], ptr %ua.ptr94, align 8 + %callN = call { ptr, i64 } @array_to_string__AR_1_Any(ptr %0, [1 x { i64, i64 }] %ua.load95) store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %dispatch.merge.139 + br label %dispatch.merge.145 -dispatch.merge.153: ; preds = %dispatch.case.156, %dispatch.case.155, %dispatch.default.154 +dispatch.case.148: ; preds = %match.arm.47 + %ua.raw97 = extractvalue { i64, i64 } %loadN, 1 + %ua.ptr98 = inttoptr i64 %ua.raw97 to ptr + %ua.load99 = load [3 x { i64, i64 }], ptr %ua.ptr98, align 8 + %callN = call { ptr, i64 } @array_to_string__AR_3_Any(ptr %0, [3 x { i64, i64 }] %ua.load99) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + br label %dispatch.merge.145 + +dispatch.merge.159: ; preds = %dispatch.case.162, %dispatch.case.161, %dispatch.default.160 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 store { ptr, i64 } %loadN, ptr %allocaN, align 8 br label %match.merge.38 -dispatch.default.154: ; preds = %match.arm.48 - store { ptr, i64 } { ptr @str.87, i64 0 }, ptr %allocaN, align 8 - br label %dispatch.merge.153 +dispatch.default.160: ; preds = %match.arm.48 + store { ptr, i64 } { ptr @str.90, i64 0 }, ptr %allocaN, align 8 + br label %dispatch.merge.159 -dispatch.case.155: ; preds = %match.arm.48 - %ua.raw98 = extractvalue { i64, i64 } %loadN, 1 - %ua.ptr99 = inttoptr i64 %ua.raw98 to ptr - %ua.load100 = load { ptr, i64 }, ptr %ua.ptr99, align 8 - %callN = call { ptr, i64 } @slice_to_string__string(ptr %0, { ptr, i64 } %ua.load100) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %dispatch.merge.153 - -dispatch.case.156: ; preds = %match.arm.48 +dispatch.case.161: ; preds = %match.arm.48 %ua.raw102 = extractvalue { i64, i64 } %loadN, 1 %ua.ptr103 = inttoptr i64 %ua.raw102 to ptr %ua.load104 = load { ptr, i64 }, ptr %ua.ptr103, align 8 - %callN = call { ptr, i64 } @slice_to_string__Any(ptr %0, { ptr, i64 } %ua.load104) + %callN = call { ptr, i64 } @slice_to_string__string(ptr %0, { ptr, i64 } %ua.load104) store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %dispatch.merge.153 + br label %dispatch.merge.159 -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 +dispatch.case.162: ; preds = %match.arm.48 + %ua.raw106 = extractvalue { i64, i64 } %loadN, 1 + %ua.ptr107 = inttoptr i64 %ua.raw106 to ptr + %ua.load108 = load { ptr, i64 }, ptr %ua.ptr107, align 8 + %callN = call { ptr, i64 } @slice_to_string__Any(ptr %0, { ptr, i64 } %ua.load108) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + br label %dispatch.merge.159 + +dispatch.merge.173: ; preds = %dispatch.case.194, %dispatch.case.193, %dispatch.case.192, %dispatch.case.191, %dispatch.case.190, %dispatch.case.189, %dispatch.case.188, %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.default.174 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 store { ptr, i64 } %loadN, ptr %allocaN, align 8 br label %match.merge.38 -dispatch.default.168: ; preds = %match.arm.49 - store { ptr, i64 } { ptr @str.88, i64 0 }, ptr %allocaN, align 8 - br label %dispatch.merge.167 - -dispatch.case.169: ; preds = %match.arm.49 - %ua.raw107 = extractvalue { i64, i64 } %loadN, 1 - %iNp = inttoptr i64 %ua.raw107 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.167 - -dispatch.case.170: ; preds = %match.arm.49 - %ua.raw109 = extractvalue { i64, i64 } %loadN, 1 - %iNp110 = inttoptr i64 %ua.raw109 to ptr - %callN = call { ptr, i64 } @pointer_to_string__ptr_CAllocator(ptr %0, ptr %iNp110) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %dispatch.merge.167 - -dispatch.case.171: ; preds = %match.arm.49 - %ua.raw112 = extractvalue { i64, i64 } %loadN, 1 - %iNp113 = inttoptr i64 %ua.raw112 to ptr - %callN = call { ptr, i64 } @pointer_to_string__ptr_GPA(ptr %0, ptr %iNp113) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %dispatch.merge.167 - -dispatch.case.172: ; preds = %match.arm.49 - %ua.raw115 = extractvalue { i64, i64 } %loadN, 1 - %iNp116 = inttoptr i64 %ua.raw115 to ptr - %callN = call { ptr, i64 } @pointer_to_string__ptr_ArenaChunk(ptr %0, ptr %iNp116) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %dispatch.merge.167 - -dispatch.case.173: ; preds = %match.arm.49 - %ua.raw118 = extractvalue { i64, i64 } %loadN, 1 - %iNp119 = inttoptr i64 %ua.raw118 to ptr - %callN = call { ptr, i64 } @pointer_to_string__ptr_Arena(ptr %0, ptr %iNp119) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %dispatch.merge.167 - -dispatch.case.174: ; preds = %match.arm.49 - %ua.raw121 = extractvalue { i64, i64 } %loadN, 1 - %iNp122 = inttoptr i64 %ua.raw121 to ptr - %callN = call { ptr, i64 } @pointer_to_string__mptr_u8(ptr %0, ptr %iNp122) - store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %dispatch.merge.167 +dispatch.default.174: ; preds = %match.arm.49 + store { ptr, i64 } { ptr @str.91, i64 0 }, ptr %allocaN, align 8 + br label %dispatch.merge.173 dispatch.case.175: ; preds = %match.arm.49 - %ua.raw124 = extractvalue { i64, i64 } %loadN, 1 - %iNp125 = inttoptr i64 %ua.raw124 to ptr - %callN = call { ptr, i64 } @pointer_to_string__ptr_BufAlloc(ptr %0, ptr %iNp125) + %ua.raw111 = extractvalue { i64, i64 } %loadN, 1 + %iNp = inttoptr i64 %ua.raw111 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.167 + br label %dispatch.merge.173 dispatch.case.176: ; preds = %match.arm.49 - %ua.raw127 = extractvalue { i64, i64 } %loadN, 1 - %iNp128 = inttoptr i64 %ua.raw127 to ptr - %callN = call { ptr, i64 } @pointer_to_string__ptr_TrackingAllocator(ptr %0, ptr %iNp128) + %ua.raw113 = extractvalue { i64, i64 } %loadN, 1 + %iNp114 = inttoptr i64 %ua.raw113 to ptr + %callN = call { ptr, i64 } @pointer_to_string__ptr_CAllocator(ptr %0, ptr %iNp114) store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %dispatch.merge.167 + br label %dispatch.merge.173 dispatch.case.177: ; preds = %match.arm.49 - %ua.raw130 = extractvalue { i64, i64 } %loadN, 1 - %iNp131 = inttoptr i64 %ua.raw130 to ptr - %callN = call { ptr, i64 } @pointer_to_string__ptr_ptr_CAllocator(ptr %0, ptr %iNp131) + %ua.raw116 = extractvalue { i64, i64 } %loadN, 1 + %iNp117 = inttoptr i64 %ua.raw116 to ptr + %callN = call { ptr, i64 } @pointer_to_string__ptr_GPA(ptr %0, ptr %iNp117) store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %dispatch.merge.167 + br label %dispatch.merge.173 dispatch.case.178: ; preds = %match.arm.49 - %ua.raw133 = extractvalue { i64, i64 } %loadN, 1 - %iNp134 = inttoptr i64 %ua.raw133 to ptr - %callN = call { ptr, i64 } @pointer_to_string__ptr_s64(ptr %0, ptr %iNp134) + %ua.raw119 = extractvalue { i64, i64 } %loadN, 1 + %iNp120 = inttoptr i64 %ua.raw119 to ptr + %callN = call { ptr, i64 } @pointer_to_string__ptr_ArenaChunk(ptr %0, ptr %iNp120) store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %dispatch.merge.167 + br label %dispatch.merge.173 dispatch.case.179: ; preds = %match.arm.49 - %ua.raw136 = extractvalue { i64, i64 } %loadN, 1 - %iNp137 = inttoptr i64 %ua.raw136 to ptr - %callN = call { ptr, i64 } @pointer_to_string__ptr_ptr_void(ptr %0, ptr %iNp137) + %ua.raw122 = extractvalue { i64, i64 } %loadN, 1 + %iNp123 = inttoptr i64 %ua.raw122 to ptr + %callN = call { ptr, i64 } @pointer_to_string__ptr_Arena(ptr %0, ptr %iNp123) store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %dispatch.merge.167 + br label %dispatch.merge.173 dispatch.case.180: ; preds = %match.arm.49 - %ua.raw139 = extractvalue { i64, i64 } %loadN, 1 - %iNp140 = inttoptr i64 %ua.raw139 to ptr - %callN = call { ptr, i64 } @pointer_to_string__ptr_bool(ptr %0, ptr %iNp140) + %ua.raw125 = extractvalue { i64, i64 } %loadN, 1 + %iNp126 = inttoptr i64 %ua.raw125 to ptr + %callN = call { ptr, i64 } @pointer_to_string__mptr_u8(ptr %0, ptr %iNp126) store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %dispatch.merge.167 + br label %dispatch.merge.173 dispatch.case.181: ; preds = %match.arm.49 - %ua.raw142 = extractvalue { i64, i64 } %loadN, 1 - %iNp143 = inttoptr i64 %ua.raw142 to ptr - %callN = call { ptr, i64 } @pointer_to_string__ptr_string(ptr %0, ptr %iNp143) + %ua.raw128 = extractvalue { i64, i64 } %loadN, 1 + %iNp129 = inttoptr i64 %ua.raw128 to ptr + %callN = call { ptr, i64 } @pointer_to_string__ptr_BufAlloc(ptr %0, ptr %iNp129) store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %dispatch.merge.167 + br label %dispatch.merge.173 dispatch.case.182: ; preds = %match.arm.49 - %ua.raw145 = extractvalue { i64, i64 } %loadN, 1 - %iNp146 = inttoptr i64 %ua.raw145 to ptr - %callN = call { ptr, i64 } @pointer_to_string__ptr_Any(ptr %0, ptr %iNp146) + %ua.raw131 = extractvalue { i64, i64 } %loadN, 1 + %iNp132 = inttoptr i64 %ua.raw131 to ptr + %callN = call { ptr, i64 } @pointer_to_string__ptr_TrackingAllocator(ptr %0, ptr %iNp132) store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %dispatch.merge.167 + br label %dispatch.merge.173 dispatch.case.183: ; preds = %match.arm.49 - %ua.raw148 = extractvalue { i64, i64 } %loadN, 1 - %iNp149 = inttoptr i64 %ua.raw148 to ptr - %callN = call { ptr, i64 } @pointer_to_string__ptr_AR_1_Any(ptr %0, ptr %iNp149) + %ua.raw134 = extractvalue { i64, i64 } %loadN, 1 + %iNp135 = inttoptr i64 %ua.raw134 to ptr + %callN = call { ptr, i64 } @pointer_to_string__ptr_NSString(ptr %0, ptr %iNp135) store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %dispatch.merge.167 + br label %dispatch.merge.173 dispatch.case.184: ; preds = %match.arm.49 - %ua.raw151 = extractvalue { i64, i64 } %loadN, 1 - %iNp152 = inttoptr i64 %ua.raw151 to ptr - %callN = call { ptr, i64 } @pointer_to_string__ptr_SL_Any(ptr %0, ptr %iNp152) + %ua.raw137 = extractvalue { i64, i64 } %loadN, 1 + %iNp138 = inttoptr i64 %ua.raw137 to ptr + %callN = call { ptr, i64 } @pointer_to_string__ptr_ptr_CAllocator(ptr %0, ptr %iNp138) store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %dispatch.merge.167 + br label %dispatch.merge.173 dispatch.case.185: ; preds = %match.arm.49 - %ua.raw154 = extractvalue { i64, i64 } %loadN, 1 - %iNp155 = inttoptr i64 %ua.raw154 to ptr - %callN = call { ptr, i64 } @pointer_to_string__ptr_u8(ptr %0, ptr %iNp155) + %ua.raw140 = extractvalue { i64, i64 } %loadN, 1 + %iNp141 = inttoptr i64 %ua.raw140 to ptr + %callN = call { ptr, i64 } @pointer_to_string__ptr_s64(ptr %0, ptr %iNp141) store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %dispatch.merge.167 + br label %dispatch.merge.173 dispatch.case.186: ; preds = %match.arm.49 - %ua.raw157 = extractvalue { i64, i64 } %loadN, 1 - %iNp158 = inttoptr i64 %ua.raw157 to ptr - %callN = call { ptr, i64 } @pointer_to_string__ptr_Triple(ptr %0, ptr %iNp158) + %ua.raw143 = extractvalue { i64, i64 } %loadN, 1 + %iNp144 = inttoptr i64 %ua.raw143 to ptr + %callN = call { ptr, i64 } @pointer_to_string__ptr_ptr_void(ptr %0, ptr %iNp144) store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %dispatch.merge.167 + br label %dispatch.merge.173 dispatch.case.187: ; preds = %match.arm.49 - %ua.raw160 = extractvalue { i64, i64 } %loadN, 1 - %iNp161 = inttoptr i64 %ua.raw160 to ptr - %callN = call { ptr, i64 } @pointer_to_string__ptr_AR_3_Any(ptr %0, ptr %iNp161) + %ua.raw146 = extractvalue { i64, i64 } %loadN, 1 + %iNp147 = inttoptr i64 %ua.raw146 to ptr + %callN = call { ptr, i64 } @pointer_to_string__ptr_bool(ptr %0, ptr %iNp147) store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %dispatch.merge.167 + br label %dispatch.merge.173 + +dispatch.case.188: ; preds = %match.arm.49 + %ua.raw149 = extractvalue { i64, i64 } %loadN, 1 + %iNp150 = inttoptr i64 %ua.raw149 to ptr + %callN = call { ptr, i64 } @pointer_to_string__ptr_string(ptr %0, ptr %iNp150) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + br label %dispatch.merge.173 + +dispatch.case.189: ; preds = %match.arm.49 + %ua.raw152 = extractvalue { i64, i64 } %loadN, 1 + %iNp153 = inttoptr i64 %ua.raw152 to ptr + %callN = call { ptr, i64 } @pointer_to_string__ptr_Any(ptr %0, ptr %iNp153) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + br label %dispatch.merge.173 + +dispatch.case.190: ; preds = %match.arm.49 + %ua.raw155 = extractvalue { i64, i64 } %loadN, 1 + %iNp156 = inttoptr i64 %ua.raw155 to ptr + %callN = call { ptr, i64 } @pointer_to_string__ptr_AR_1_Any(ptr %0, ptr %iNp156) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + br label %dispatch.merge.173 + +dispatch.case.191: ; preds = %match.arm.49 + %ua.raw158 = extractvalue { i64, i64 } %loadN, 1 + %iNp159 = inttoptr i64 %ua.raw158 to ptr + %callN = call { ptr, i64 } @pointer_to_string__ptr_SL_Any(ptr %0, ptr %iNp159) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + br label %dispatch.merge.173 + +dispatch.case.192: ; preds = %match.arm.49 + %ua.raw161 = extractvalue { i64, i64 } %loadN, 1 + %iNp162 = inttoptr i64 %ua.raw161 to ptr + %callN = call { ptr, i64 } @pointer_to_string__ptr_u8(ptr %0, ptr %iNp162) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + br label %dispatch.merge.173 + +dispatch.case.193: ; preds = %match.arm.49 + %ua.raw164 = extractvalue { i64, i64 } %loadN, 1 + %iNp165 = inttoptr i64 %ua.raw164 to ptr + %callN = call { ptr, i64 } @pointer_to_string__ptr_Triple(ptr %0, ptr %iNp165) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + br label %dispatch.merge.173 + +dispatch.case.194: ; preds = %match.arm.49 + %ua.raw167 = extractvalue { i64, i64 } %loadN, 1 + %iNp168 = inttoptr i64 %ua.raw167 to ptr + %callN = call { ptr, i64 } @pointer_to_string__ptr_AR_3_Any(ptr %0, ptr %iNp168) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + br label %dispatch.merge.173 } ; Function Attrs: nounwind @@ -1476,7 +1507,7 @@ entry: %alloca = alloca { ptr, i64 }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.89, i64 14 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.92, i64 14 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -1572,7 +1603,7 @@ if.merge.11: ; preds = %if.merge.26, %if.me if.then.12: ; preds = %if.then.9 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.90, i64 36 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.93, i64 36 }) store { ptr, i64 } %call, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -1580,7 +1611,7 @@ if.then.12: ; preds = %if.then.9 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, 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.91, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.94, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -1590,13 +1621,13 @@ if.then.12: ; preds = %if.then.9 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, 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.92, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.95, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.13 if.merge.13: ; preds = %if.then.12, %if.then.9 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.93, i64 43 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.96, i64 43 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -1604,7 +1635,7 @@ if.merge.13: ; preds = %if.then.12, %if.the %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, 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.94, i64 5 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.97, i64 5 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 1 @@ -1618,7 +1649,7 @@ if.merge.13: ; preds = %if.then.12, %if.the if.then.24: ; preds = %if.else.10 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.95, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.98, i64 36 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -1626,7 +1657,7 @@ if.then.24: ; preds = %if.else.10 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, 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.96, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.99, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -1637,7 +1668,7 @@ if.then.24: ; preds = %if.else.10 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, 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.97, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.100, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 2 @@ -1694,7 +1725,7 @@ if.merge.32: ; preds = %if.merge.35, %if.el if.then.33: ; preds = %if.then.30 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.98, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.101, i64 36 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -1702,7 +1733,7 @@ if.then.33: ; preds = %if.then.30 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, 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.99, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.102, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -1713,7 +1744,7 @@ if.then.33: ; preds = %if.then.30 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, 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.100, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.103, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 %addN = add i64 %loadN, 2 @@ -1733,7 +1764,7 @@ if.merge.35: ; preds = %if.else.34, %if.the if.then.36: ; preds = %while.exit.2 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.101, i64 36 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.104, i64 36 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -1741,7 +1772,7 @@ if.then.36: ; preds = %while.exit.2 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, 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.102, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.105, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %alloca, align 8 @@ -1752,7 +1783,7 @@ if.then.36: ; preds = %while.exit.2 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) store { ptr, i64 } %callN, 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.103, i64 4 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.106, i64 4 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 br label %if.merge.37 @@ -1944,19 +1975,19 @@ entry: define i32 @main() #0 { entry: call void @__sx_objc_selector_init() - %call = call ptr @objc_getClass(ptr @str.104) + %call = call ptr @objc_getClass(ptr @str.107) %alloca = alloca ptr, align 8 store ptr %call, ptr %alloca, align 8 %load = load ptr, ptr %alloca, align 8 - %callN = call ptr @objc_allocateClassPair(ptr %load, ptr @str.105, i64 0) + %callN = call ptr @objc_allocateClassPair(ptr %load, ptr @str.108, i64 0) %allocaN = alloca ptr, align 8 store ptr %callN, ptr %allocaN, align 8 - %callN = call ptr @sel_registerName(ptr @str.106) + %callN = call ptr @sel_registerName(ptr @str.109) %allocaN = alloca ptr, align 8 store ptr %callN, ptr %allocaN, align 8 %loadN = load ptr, ptr %allocaN, align 8 %loadN = load ptr, ptr %allocaN, align 8 - %callN = call i1 @class_addMethod(ptr %loadN, ptr %loadN, ptr @triple_imp, ptr @str.107) + %callN = call i1 @class_addMethod(ptr %loadN, ptr %loadN, ptr @triple_imp, ptr @str.110) %allocaN = alloca i1, align 1 store i1 %callN, ptr %allocaN, align 1 %loadN = load i1, ptr %allocaN, align 1 @@ -2002,7 +2033,7 @@ entry: define internal void @print__ct_s7f3aff1506f207ab__pack_bool(ptr %0, i1 %1) #0 { entry: %alloca = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.108, i64 15 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.111, i64 15 }, ptr %alloca, align 8 %allocaN = alloca i1, align 1 store i1 %1, ptr %allocaN, align 1 %allocaN = alloca [1 x { i64, i64 }], align 8 @@ -2018,7 +2049,7 @@ entry: %gepN = getelementptr inbounds { ptr, i64 }, ptr %allocaN, i32 0, i32 1 store i64 1, ptr %gepN, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.109, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.112, i64 0 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %alloca, align 8 %call = call { ptr, i64 } @substr(ptr %0, { ptr, i64 } %loadN, i64 0, i64 12) @@ -2046,7 +2077,7 @@ entry: ; Function Attrs: nounwind define internal { ptr, i64 } @__insert_0(ptr %0) #0 { entry: - %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.110, i64 15 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.113, i64 15 }) ret { ptr, i64 } %call } @@ -2054,7 +2085,7 @@ entry: define internal void @print__ct_s337be2777a405332__pack_s64_s64_s64(ptr %0, i64 %1, i64 %2, i64 %3) #0 { entry: %alloca = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.111, i64 22 }, ptr %alloca, align 8 + store { ptr, i64 } { ptr @str.114, i64 22 }, ptr %alloca, align 8 %allocaN = alloca i64, align 8 store i64 %1, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 @@ -2081,7 +2112,7 @@ entry: %gepN = getelementptr inbounds { ptr, i64 }, ptr %allocaN, i32 0, i32 1 store i64 3, ptr %gepN, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.112, i64 0 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.115, i64 0 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %alloca, align 8 %call = call { ptr, i64 } @substr(ptr %0, { ptr, i64 } %loadN, i64 0, i64 10) @@ -2130,7 +2161,7 @@ entry: ; Function Attrs: nounwind define internal { ptr, i64 } @__insert_1(ptr %0) #0 { entry: - %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.113, i64 22 }) + %call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.116, i64 22 }) ret { ptr, i64 } %call } @@ -2139,35 +2170,35 @@ define internal { ptr, i64 } @struct_to_string__Allocator(ptr %0, { ptr, ptr, pt entry: %alloca = alloca { ptr, ptr, ptr }, align 8 store { ptr, ptr, ptr } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.114, i64 9 }, { ptr, i64 } { ptr @str.115, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.117, i64 9 }, { ptr, i64 } { ptr @str.118, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 - br label %while.hdr.81 + br label %while.hdr.82 -while.hdr.81: ; preds = %fv.merge, %entry +while.hdr.82: ; preds = %fv.merge, %entry %load = load i64, ptr %allocaN, align 8 %icmp = icmp slt i64 %load, 3 - br i1 %icmp, label %while.body.82, label %while.exit.83 + br i1 %icmp, label %while.body.83, label %while.exit.84 -while.body.82: ; preds = %while.hdr.81 +while.body.83: ; preds = %while.hdr.82 %loadN = load i64, ptr %allocaN, align 8 %icmpN = icmp sgt i64 %loadN, 0 - br i1 %icmpN, label %if.then.84, label %if.merge.85 + br i1 %icmpN, label %if.then.85, label %if.merge.86 -while.exit.83: ; preds = %while.hdr.81 +while.exit.84: ; preds = %while.hdr.82 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.116, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.119, i64 1 }) ret { ptr, i64 } %callN -if.then.84: ; preds = %while.body.82 +if.then.85: ; preds = %while.body.83 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.117, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.120, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %if.merge.85 + br label %if.merge.86 -if.merge.85: ; preds = %if.then.84, %while.body.82 +if.merge.86: ; preds = %if.then.85, %while.body.83 %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 @@ -2175,7 +2206,7 @@ if.merge.85: ; preds = %if.then.84, %while. %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, 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.120, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.123, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, ptr, ptr }, ptr %alloca, align 8 @@ -2194,24 +2225,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.81 + br label %while.hdr.82 -fv.default: ; preds = %if.merge.85 +fv.default: ; preds = %if.merge.86 br label %fv.merge -fv.case: ; preds = %if.merge.85 +fv.case: ; preds = %if.merge.86 %fv.field = extractvalue { ptr, ptr, ptr } %loadN, 0 %pNi = ptrtoint ptr %fv.field to i64 %fv.val = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi, 1 br label %fv.merge -fv.case17: ; preds = %if.merge.85 +fv.case17: ; preds = %if.merge.86 %fv.field18 = extractvalue { ptr, ptr, ptr } %loadN, 1 %pNi19 = ptrtoint ptr %fv.field18 to i64 %fv.val20 = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi19, 1 br label %fv.merge -fv.case21: ; preds = %if.merge.85 +fv.case21: ; preds = %if.merge.86 %fv.field22 = extractvalue { ptr, ptr, ptr } %loadN, 2 %pNi23 = ptrtoint ptr %fv.field22 to i64 %fv.val24 = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi23, 1 @@ -2223,43 +2254,43 @@ define internal { ptr, i64 } @struct_to_string__CAllocator(ptr %0, {} %1) #0 { entry: %alloca = alloca {}, align 8 store {} %1, ptr %alloca, align 1 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.121, i64 10 }, { ptr, i64 } { ptr @str.122, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.124, i64 10 }, { ptr, i64 } { ptr @str.125, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 - br label %while.hdr.86 + br label %while.hdr.87 -while.hdr.86: ; preds = %if.merge.90, %entry +while.hdr.87: ; preds = %if.merge.91, %entry %load = load i64, ptr %allocaN, align 8 %icmp = icmp slt i64 %load, 0 - br i1 %icmp, label %while.body.87, label %while.exit.88 + br i1 %icmp, label %while.body.88, label %while.exit.89 -while.body.87: ; preds = %while.hdr.86 +while.body.88: ; preds = %while.hdr.87 %loadN = load i64, ptr %allocaN, align 8 %icmpN = icmp sgt i64 %loadN, 0 - br i1 %icmpN, label %if.then.89, label %if.merge.90 + br i1 %icmpN, label %if.then.90, label %if.merge.91 -while.exit.88: ; preds = %while.hdr.86 +while.exit.89: ; preds = %while.hdr.87 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.123, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.126, i64 1 }) ret { ptr, i64 } %callN -if.then.89: ; preds = %while.body.87 +if.then.90: ; preds = %while.body.88 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.124, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.127, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %if.merge.90 + br label %if.merge.91 -if.merge.90: ; preds = %if.then.89, %while.body.87 +if.merge.91: ; preds = %if.then.90, %while.body.88 %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.125, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [0 x { ptr, i64 }], ptr @field_names.128, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, 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.126, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.129, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load {}, ptr %alloca, align 1 @@ -2270,7 +2301,7 @@ if.merge.90: ; preds = %if.then.89, %while. %loadN = load i64, ptr %allocaN, align 8 %add = add i64 %loadN, 1 store i64 %add, ptr %allocaN, align 8 - br label %while.hdr.86 + br label %while.hdr.87 } ; Function Attrs: nounwind @@ -2278,43 +2309,43 @@ define internal { ptr, i64 } @struct_to_string__GPA(ptr %0, { i64 } %1) #0 { entry: %alloca = alloca { i64 }, align 8 store { i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.127, i64 3 }, { ptr, i64 } { ptr @str.128, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.130, i64 3 }, { ptr, i64 } { ptr @str.131, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 - br label %while.hdr.91 + br label %while.hdr.92 -while.hdr.91: ; preds = %fv.merge, %entry +while.hdr.92: ; preds = %fv.merge, %entry %load = load i64, ptr %allocaN, align 8 %icmp = icmp slt i64 %load, 1 - br i1 %icmp, label %while.body.92, label %while.exit.93 + br i1 %icmp, label %while.body.93, label %while.exit.94 -while.body.92: ; preds = %while.hdr.91 +while.body.93: ; preds = %while.hdr.92 %loadN = load i64, ptr %allocaN, align 8 %icmpN = icmp sgt i64 %loadN, 0 - br i1 %icmpN, label %if.then.94, label %if.merge.95 + br i1 %icmpN, label %if.then.95, label %if.merge.96 -while.exit.93: ; preds = %while.hdr.91 +while.exit.94: ; preds = %while.hdr.92 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.129, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.132, i64 1 }) ret { ptr, i64 } %callN -if.then.94: ; preds = %while.body.92 +if.then.95: ; preds = %while.body.93 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.130, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.133, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %if.merge.95 + br label %if.merge.96 -if.merge.95: ; preds = %if.then.94, %while.body.92 +if.merge.96: ; preds = %if.then.95, %while.body.93 %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.132, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [1 x { ptr, i64 }], ptr @field_names.135, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, 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.133, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.136, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i64 }, ptr %alloca, align 8 @@ -2331,12 +2362,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.91 + br label %while.hdr.92 -fv.default: ; preds = %if.merge.95 +fv.default: ; preds = %if.merge.96 br label %fv.merge -fv.case: ; preds = %if.merge.95 +fv.case: ; preds = %if.merge.96 %fv.field = extractvalue { i64 } %loadN, 0 %fv.val = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field, 1 br label %fv.merge @@ -2347,43 +2378,43 @@ define internal { ptr, i64 } @struct_to_string__ArenaChunk(ptr %0, { ptr, i64 } entry: %alloca = alloca { ptr, i64 }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.134, i64 10 }, { ptr, i64 } { ptr @str.135, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.137, i64 10 }, { ptr, i64 } { ptr @str.138, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 - br label %while.hdr.96 + br label %while.hdr.97 -while.hdr.96: ; preds = %fv.merge, %entry +while.hdr.97: ; preds = %fv.merge, %entry %load = load i64, ptr %allocaN, align 8 %icmp = icmp slt i64 %load, 2 - br i1 %icmp, label %while.body.97, label %while.exit.98 + br i1 %icmp, label %while.body.98, label %while.exit.99 -while.body.97: ; preds = %while.hdr.96 +while.body.98: ; preds = %while.hdr.97 %loadN = load i64, ptr %allocaN, align 8 %icmpN = icmp sgt i64 %loadN, 0 - br i1 %icmpN, label %if.then.99, label %if.merge.100 + br i1 %icmpN, label %if.then.100, label %if.merge.101 -while.exit.98: ; preds = %while.hdr.96 +while.exit.99: ; preds = %while.hdr.97 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.136, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.139, i64 1 }) ret { ptr, i64 } %callN -if.then.99: ; preds = %while.body.97 +if.then.100: ; preds = %while.body.98 %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 }) + %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.100 + br label %if.merge.101 -if.merge.100: ; preds = %if.then.99, %while.body.97 +if.merge.101: ; preds = %if.then.100, %while.body.98 %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.140, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.143, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, 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.141, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.144, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %alloca, align 8 @@ -2401,18 +2432,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.96 + br label %while.hdr.97 -fv.default: ; preds = %if.merge.100 +fv.default: ; preds = %if.merge.101 br label %fv.merge -fv.case: ; preds = %if.merge.100 +fv.case: ; preds = %if.merge.101 %fv.field = extractvalue { ptr, i64 } %loadN, 0 %pNi = ptrtoint ptr %fv.field to i64 %fv.val = insertvalue { i64, i64 } { i64 25, i64 undef }, i64 %pNi, 1 br label %fv.merge -fv.case17: ; preds = %if.merge.100 +fv.case17: ; preds = %if.merge.101 %fv.field18 = extractvalue { ptr, i64 } %loadN, 1 %fv.val19 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field18, 1 br label %fv.merge @@ -2423,43 +2454,43 @@ define internal { ptr, i64 } @struct_to_string__Arena(ptr %0, { ptr, i64, { ptr, entry: %alloca = alloca { ptr, i64, { ptr, ptr, ptr } }, align 8 store { ptr, i64, { ptr, ptr, ptr } } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.142, i64 5 }, { ptr, i64 } { ptr @str.143, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.145, i64 5 }, { ptr, i64 } { ptr @str.146, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 - br label %while.hdr.101 + br label %while.hdr.102 -while.hdr.101: ; preds = %fv.merge, %entry +while.hdr.102: ; preds = %fv.merge, %entry %load = load i64, ptr %allocaN, align 8 %icmp = icmp slt i64 %load, 3 - br i1 %icmp, label %while.body.102, label %while.exit.103 + br i1 %icmp, label %while.body.103, label %while.exit.104 -while.body.102: ; preds = %while.hdr.101 +while.body.103: ; preds = %while.hdr.102 %loadN = load i64, ptr %allocaN, align 8 %icmpN = icmp sgt i64 %loadN, 0 - br i1 %icmpN, label %if.then.104, label %if.merge.105 + br i1 %icmpN, label %if.then.105, label %if.merge.106 -while.exit.103: ; preds = %while.hdr.101 +while.exit.104: ; preds = %while.hdr.102 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.144, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.147, i64 1 }) ret { ptr, i64 } %callN -if.then.104: ; preds = %while.body.102 +if.then.105: ; preds = %while.body.103 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.145, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.148, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %if.merge.105 + br label %if.merge.106 -if.merge.105: ; preds = %if.then.104, %while.body.102 +if.merge.106: ; preds = %if.then.105, %while.body.103 %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.149, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.152, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, 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.150, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.153, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64, { ptr, ptr, ptr } }, ptr %alloca, align 8 @@ -2478,23 +2509,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.101 + br label %while.hdr.102 -fv.default: ; preds = %if.merge.105 +fv.default: ; preds = %if.merge.106 br label %fv.merge -fv.case: ; preds = %if.merge.105 +fv.case: ; preds = %if.merge.106 %fv.field = extractvalue { ptr, i64, { ptr, ptr, ptr } } %loadN, 0 %pNi = ptrtoint ptr %fv.field to i64 %fv.val = insertvalue { i64, i64 } { i64 25, i64 undef }, i64 %pNi, 1 br label %fv.merge -fv.case17: ; preds = %if.merge.105 +fv.case17: ; preds = %if.merge.106 %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.105 +fv.case20: ; preds = %if.merge.106 %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 @@ -2508,43 +2539,43 @@ define internal { ptr, i64 } @struct_to_string__BufAlloc(ptr %0, { ptr, i64, i64 entry: %alloca = alloca { ptr, i64, i64 }, align 8 store { ptr, i64, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.151, i64 8 }, { ptr, i64 } { ptr @str.152, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.154, i64 8 }, { ptr, i64 } { ptr @str.155, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 - br label %while.hdr.106 + br label %while.hdr.107 -while.hdr.106: ; preds = %fv.merge, %entry +while.hdr.107: ; preds = %fv.merge, %entry %load = load i64, ptr %allocaN, align 8 %icmp = icmp slt i64 %load, 3 - br i1 %icmp, label %while.body.107, label %while.exit.108 + br i1 %icmp, label %while.body.108, label %while.exit.109 -while.body.107: ; preds = %while.hdr.106 +while.body.108: ; preds = %while.hdr.107 %loadN = load i64, ptr %allocaN, align 8 %icmpN = icmp sgt i64 %loadN, 0 - br i1 %icmpN, label %if.then.109, label %if.merge.110 + br i1 %icmpN, label %if.then.110, label %if.merge.111 -while.exit.108: ; preds = %while.hdr.106 +while.exit.109: ; preds = %while.hdr.107 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.153, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.156, i64 1 }) ret { ptr, i64 } %callN -if.then.109: ; preds = %while.body.107 +if.then.110: ; preds = %while.body.108 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.154, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.157, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %if.merge.110 + br label %if.merge.111 -if.merge.110: ; preds = %if.then.109, %while.body.107 +if.merge.111: ; preds = %if.then.110, %while.body.108 %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.158, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.161, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, 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.159, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.162, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64, i64 }, ptr %alloca, align 8 @@ -2563,23 +2594,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.106 + br label %while.hdr.107 -fv.default: ; preds = %if.merge.110 +fv.default: ; preds = %if.merge.111 br label %fv.merge -fv.case: ; preds = %if.merge.110 +fv.case: ; preds = %if.merge.111 %fv.field = extractvalue { ptr, i64, i64 } %loadN, 0 %pNi = ptrtoint ptr %fv.field to i64 %fv.val = insertvalue { i64, i64 } { i64 28, i64 undef }, i64 %pNi, 1 br label %fv.merge -fv.case17: ; preds = %if.merge.110 +fv.case17: ; preds = %if.merge.111 %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.110 +fv.case20: ; preds = %if.merge.111 %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 @@ -2590,43 +2621,43 @@ define internal { ptr, i64 } @struct_to_string__TrackingAllocator(ptr %0, { { pt entry: %alloca = alloca { { ptr, ptr, ptr }, i64, i64, i64 }, align 8 store { { ptr, ptr, ptr }, i64, i64, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.160, i64 17 }, { ptr, i64 } { ptr @str.161, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.163, i64 17 }, { ptr, i64 } { ptr @str.164, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 - br label %while.hdr.111 + br label %while.hdr.112 -while.hdr.111: ; preds = %fv.merge, %entry +while.hdr.112: ; preds = %fv.merge, %entry %load = load i64, ptr %allocaN, align 8 %icmp = icmp slt i64 %load, 4 - br i1 %icmp, label %while.body.112, label %while.exit.113 + br i1 %icmp, label %while.body.113, label %while.exit.114 -while.body.112: ; preds = %while.hdr.111 +while.body.113: ; preds = %while.hdr.112 %loadN = load i64, ptr %allocaN, align 8 %icmpN = icmp sgt i64 %loadN, 0 - br i1 %icmpN, label %if.then.114, label %if.merge.115 + br i1 %icmpN, label %if.then.115, label %if.merge.116 -while.exit.113: ; preds = %while.hdr.111 +while.exit.114: ; preds = %while.hdr.112 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.162, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.165, i64 1 }) ret { ptr, i64 } %callN -if.then.114: ; preds = %while.body.112 +if.then.115: ; preds = %while.body.113 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.163, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.166, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %if.merge.115 + br label %if.merge.116 -if.merge.115: ; preds = %if.then.114, %while.body.112 +if.merge.116: ; preds = %if.then.115, %while.body.113 %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.168, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.171, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, 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.169, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.172, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, ptr, ptr }, i64, i64, i64 }, ptr %alloca, align 8 @@ -2646,12 +2677,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.111 + br label %while.hdr.112 -fv.default: ; preds = %if.merge.115 +fv.default: ; preds = %if.merge.116 br label %fv.merge -fv.case: ; preds = %if.merge.115 +fv.case: ; preds = %if.merge.116 %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 @@ -2659,17 +2690,17 @@ fv.case: ; preds = %if.merge.115 %fv.val = insertvalue { i64, i64 } { i64 19, i64 undef }, i64 %ba.p2i, 1 br label %fv.merge -fv.case17: ; preds = %if.merge.115 +fv.case17: ; preds = %if.merge.116 %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.115 +fv.case20: ; preds = %if.merge.116 %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.115 +fv.case23: ; preds = %if.merge.116 %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 @@ -2680,43 +2711,43 @@ define internal { ptr, i64 } @struct_to_string__Context(ptr %0, { { ptr, ptr, pt entry: %alloca = alloca { { ptr, ptr, ptr }, ptr }, align 8 store { { ptr, ptr, ptr }, ptr } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.170, i64 7 }, { ptr, i64 } { ptr @str.171, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.173, i64 7 }, { ptr, i64 } { ptr @str.174, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 - br label %while.hdr.116 + br label %while.hdr.117 -while.hdr.116: ; preds = %fv.merge, %entry +while.hdr.117: ; preds = %fv.merge, %entry %load = load i64, ptr %allocaN, align 8 %icmp = icmp slt i64 %load, 2 - br i1 %icmp, label %while.body.117, label %while.exit.118 + br i1 %icmp, label %while.body.118, label %while.exit.119 -while.body.117: ; preds = %while.hdr.116 +while.body.118: ; preds = %while.hdr.117 %loadN = load i64, ptr %allocaN, align 8 %icmpN = icmp sgt i64 %loadN, 0 - br i1 %icmpN, label %if.then.119, label %if.merge.120 + br i1 %icmpN, label %if.then.120, label %if.merge.121 -while.exit.118: ; preds = %while.hdr.116 +while.exit.119: ; preds = %while.hdr.117 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.172, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.175, i64 1 }) ret { ptr, i64 } %callN -if.then.119: ; preds = %while.body.117 +if.then.120: ; preds = %while.body.118 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.173, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.176, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %if.merge.120 + br label %if.merge.121 -if.merge.120: ; preds = %if.then.119, %while.body.117 +if.merge.121: ; preds = %if.then.120, %while.body.118 %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.176, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.179, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, 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.177, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.180, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { { ptr, ptr, ptr }, ptr }, ptr %alloca, align 8 @@ -2734,12 +2765,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.116 + br label %while.hdr.117 -fv.default: ; preds = %if.merge.120 +fv.default: ; preds = %if.merge.121 br label %fv.merge -fv.case: ; preds = %if.merge.120 +fv.case: ; preds = %if.merge.121 %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 @@ -2747,7 +2778,7 @@ fv.case: ; preds = %if.merge.120 %fv.val = insertvalue { i64, i64 } { i64 19, i64 undef }, i64 %ba.p2i, 1 br label %fv.merge -fv.case17: ; preds = %if.merge.120 +fv.case17: ; preds = %if.merge.121 %fv.field18 = extractvalue { { ptr, ptr, ptr }, ptr } %loadN, 1 %pNi = ptrtoint ptr %fv.field18 to i64 %fv.val19 = insertvalue { i64, i64 } { i64 18, i64 undef }, i64 %pNi, 1 @@ -2759,43 +2790,43 @@ define internal { ptr, i64 } @struct_to_string__BuildOptions(ptr %0, {} %1) #0 { entry: %alloca = alloca {}, align 8 store {} %1, ptr %alloca, align 1 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.178, i64 12 }, { ptr, i64 } { ptr @str.179, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.181, i64 12 }, { ptr, i64 } { ptr @str.182, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 - br label %while.hdr.121 + br label %while.hdr.122 -while.hdr.121: ; preds = %if.merge.125, %entry +while.hdr.122: ; preds = %if.merge.126, %entry %load = load i64, ptr %allocaN, align 8 %icmp = icmp slt i64 %load, 0 - br i1 %icmp, label %while.body.122, label %while.exit.123 + br i1 %icmp, label %while.body.123, label %while.exit.124 -while.body.122: ; preds = %while.hdr.121 +while.body.123: ; preds = %while.hdr.122 %loadN = load i64, ptr %allocaN, align 8 %icmpN = icmp sgt i64 %loadN, 0 - br i1 %icmpN, label %if.then.124, label %if.merge.125 + br i1 %icmpN, label %if.then.125, label %if.merge.126 -while.exit.123: ; preds = %while.hdr.121 +while.exit.124: ; preds = %while.hdr.122 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.180, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.183, i64 1 }) ret { ptr, i64 } %callN -if.then.124: ; preds = %while.body.122 +if.then.125: ; preds = %while.body.123 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.181, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.184, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %if.merge.125 + br label %if.merge.126 -if.merge.125: ; preds = %if.then.124, %while.body.122 +if.merge.126: ; preds = %if.then.125, %while.body.123 %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.182, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [0 x { ptr, i64 }], ptr @field_names.185, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, 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.183, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.186, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load {}, ptr %alloca, align 1 @@ -2806,7 +2837,62 @@ if.merge.125: ; preds = %if.then.124, %while %loadN = load i64, ptr %allocaN, align 8 %add = add i64 %loadN, 1 store i64 %add, ptr %allocaN, align 8 - br label %while.hdr.121 + br label %while.hdr.122 +} + +; Function Attrs: nounwind +define internal { ptr, i64 } @struct_to_string__NSString(ptr %0, {} %1) #0 { +entry: + %alloca = alloca {}, align 8 + store {} %1, ptr %alloca, align 1 + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.187, i64 8 }, { ptr, i64 } { ptr @str.188, i64 1 }) + %allocaN = alloca { ptr, i64 }, align 8 + store { ptr, i64 } %call, ptr %allocaN, align 8 + %allocaN = alloca i64, align 8 + store i64 0, ptr %allocaN, align 8 + br label %while.hdr.127 + +while.hdr.127: ; preds = %if.merge.131, %entry + %load = load i64, ptr %allocaN, align 8 + %icmp = icmp slt i64 %load, 0 + br i1 %icmp, label %while.body.128, label %while.exit.129 + +while.body.128: ; preds = %while.hdr.127 + %loadN = load i64, ptr %allocaN, align 8 + %icmpN = icmp sgt i64 %loadN, 0 + br i1 %icmpN, label %if.then.130, label %if.merge.131 + +while.exit.129: ; preds = %while.hdr.127 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.189, i64 1 }) + ret { ptr, i64 } %callN + +if.then.130: ; preds = %while.body.128 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.190, i64 2 }) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + br label %if.merge.131 + +if.merge.131: ; preds = %if.then.130, %while.body.128 + %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.191, i64 0, i64 %loadN + %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) + store { ptr, i64 } %callN, 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.192, i64 2 }) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load { ptr, i64 }, ptr %allocaN, align 8 + %loadN = load {}, ptr %alloca, align 1 + %loadN = load i64, ptr %allocaN, align 8 + %callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } { i64 17, i64 0 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN) + store { ptr, i64 } %callN, ptr %allocaN, align 8 + %loadN = load i64, ptr %allocaN, align 8 + %add = add i64 %loadN, 1 + store i64 %add, ptr %allocaN, align 8 + br label %while.hdr.127 } ; Function Attrs: nounwind @@ -2814,43 +2900,43 @@ define internal { ptr, i64 } @struct_to_string__Triple(ptr %0, { i64, i64, i64 } entry: %alloca = alloca { i64, i64, i64 }, align 8 store { i64, i64, i64 } %1, ptr %alloca, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.184, i64 6 }, { ptr, i64 } { ptr @str.185, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.193, i64 6 }, { ptr, i64 } { ptr @str.194, i64 1 }) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 - br label %while.hdr.126 + br label %while.hdr.132 -while.hdr.126: ; preds = %fv.merge, %entry +while.hdr.132: ; preds = %fv.merge, %entry %load = load i64, ptr %allocaN, align 8 %icmp = icmp slt i64 %load, 3 - br i1 %icmp, label %while.body.127, label %while.exit.128 + br i1 %icmp, label %while.body.133, label %while.exit.134 -while.body.127: ; preds = %while.hdr.126 +while.body.133: ; preds = %while.hdr.132 %loadN = load i64, ptr %allocaN, align 8 %icmpN = icmp sgt i64 %loadN, 0 - br i1 %icmpN, label %if.then.129, label %if.merge.130 + br i1 %icmpN, label %if.then.135, label %if.merge.136 -while.exit.128: ; preds = %while.hdr.126 +while.exit.134: ; preds = %while.hdr.132 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.186, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.195, i64 1 }) ret { ptr, i64 } %callN -if.then.129: ; preds = %while.body.127 +if.then.135: ; preds = %while.body.133 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.187, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.196, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %if.merge.130 + br label %if.merge.136 -if.merge.130: ; preds = %if.then.129, %while.body.127 +if.merge.136: ; preds = %if.then.135, %while.body.133 %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.191, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.200, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %fn.load) store { ptr, i64 } %callN, 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.192, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.201, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { i64, i64, i64 }, ptr %alloca, align 8 @@ -2869,22 +2955,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.126 + br label %while.hdr.132 -fv.default: ; preds = %if.merge.130 +fv.default: ; preds = %if.merge.136 br label %fv.merge -fv.case: ; preds = %if.merge.130 +fv.case: ; preds = %if.merge.136 %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.130 +fv.case17: ; preds = %if.merge.136 %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.130 +fv.case20: ; preds = %if.merge.136 %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 @@ -2899,9 +2985,9 @@ entry: %allocaN = alloca i64, align 8 store i64 %load, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [7 x { ptr, i64 }], ptr @field_names.201, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [7 x { ptr, i64 }], ptr @field_names.210, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.193, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.202, i64 1 }, { ptr, i64 } %fn.load) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %loadN = load i64, ptr %alloca, align 8 @@ -2915,18 +3001,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.135, label %if.merge.136 + br i1 %icmp, label %if.then.141, label %if.merge.142 -if.then.135: ; preds = %entry +if.then.141: ; 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.203, i64 1 }) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.202, i64 1 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.212, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.211, 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.136 + br label %if.merge.142 -if.merge.136: ; preds = %if.then.135, %entry +if.merge.142: ; preds = %if.then.141, %entry %loadN = load { ptr, i64 }, ptr %allocaN, align 8 ret { ptr, i64 } %loadN } @@ -2940,9 +3026,9 @@ entry: %allocaN = alloca i64, align 8 store i64 %load, ptr %allocaN, align 8 %loadN = load i64, ptr %allocaN, align 8 - %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.210, i64 0, i64 %loadN + %fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.219, i64 0, i64 %loadN %fn.load = load { ptr, i64 }, ptr %fn.gep, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.204, i64 1 }, { ptr, i64 } %fn.load) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.213, i64 1 }, { ptr, i64 } %fn.load) %allocaN = alloca { ptr, i64 }, align 8 store { ptr, i64 } %call, ptr %allocaN, align 8 %loadN = load i64, ptr %alloca, align 8 @@ -2956,18 +3042,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.137, label %if.merge.138 + br i1 %icmp, label %if.then.143, label %if.merge.144 -if.then.137: ; preds = %entry +if.then.143: ; 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.212, i64 1 }) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.211, i64 1 }, { ptr, i64 } %callN) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.221, i64 1 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.220, 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.138 + br label %if.merge.144 -if.merge.138: ; preds = %if.then.137, %entry +if.merge.144: ; preds = %if.then.143, %entry %loadN = load { ptr, i64 }, ptr %allocaN, align 8 ret { ptr, i64 } %loadN } @@ -2978,33 +3064,33 @@ entry: %alloca = alloca [1 x { i64, i64 }], align 8 store [1 x { i64, i64 }] %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.213, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.222, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 - br label %while.hdr.143 + br label %while.hdr.149 -while.hdr.143: ; preds = %if.merge.147, %entry +while.hdr.149: ; preds = %if.merge.153, %entry %load = load i64, ptr %allocaN, align 8 %icmp = icmp slt i64 %load, 1 - br i1 %icmp, label %while.body.144, label %while.exit.145 + br i1 %icmp, label %while.body.150, label %while.exit.151 -while.body.144: ; preds = %while.hdr.143 +while.body.150: ; preds = %while.hdr.149 %loadN = load i64, ptr %allocaN, align 8 %icmpN = icmp sgt i64 %loadN, 0 - br i1 %icmpN, label %if.then.146, label %if.merge.147 + br i1 %icmpN, label %if.then.152, label %if.merge.153 -while.exit.145: ; preds = %while.hdr.143 +while.exit.151: ; preds = %while.hdr.149 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.214, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.223, i64 1 }) ret { ptr, i64 } %call -if.then.146: ; preds = %while.body.144 +if.then.152: ; preds = %while.body.150 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.215, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.224, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %if.merge.147 + br label %if.merge.153 -if.merge.147: ; preds = %if.then.146, %while.body.144 +if.merge.153: ; preds = %if.then.152, %while.body.150 %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 @@ -3022,7 +3108,7 @@ if.merge.147: ; preds = %if.then.146, %while %loadN = load i64, ptr %allocaN, align 8 %add = add i64 %loadN, 1 store i64 %add, ptr %allocaN, align 8 - br label %while.hdr.143 + br label %while.hdr.149 } ; Function Attrs: nounwind @@ -3031,33 +3117,33 @@ entry: %alloca = alloca [3 x { i64, i64 }], align 8 store [3 x { i64, i64 }] %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.216, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.225, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 - br label %while.hdr.148 + br label %while.hdr.154 -while.hdr.148: ; preds = %if.merge.152, %entry +while.hdr.154: ; preds = %if.merge.158, %entry %load = load i64, ptr %allocaN, align 8 %icmp = icmp slt i64 %load, 3 - br i1 %icmp, label %while.body.149, label %while.exit.150 + br i1 %icmp, label %while.body.155, label %while.exit.156 -while.body.149: ; preds = %while.hdr.148 +while.body.155: ; preds = %while.hdr.154 %loadN = load i64, ptr %allocaN, align 8 %icmpN = icmp sgt i64 %loadN, 0 - br i1 %icmpN, label %if.then.151, label %if.merge.152 + br i1 %icmpN, label %if.then.157, label %if.merge.158 -while.exit.150: ; preds = %while.hdr.148 +while.exit.156: ; preds = %while.hdr.154 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.217, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.226, i64 1 }) ret { ptr, i64 } %call -if.then.151: ; preds = %while.body.149 +if.then.157: ; preds = %while.body.155 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.218, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.227, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %if.merge.152 + br label %if.merge.158 -if.merge.152: ; preds = %if.then.151, %while.body.149 +if.merge.158: ; preds = %if.then.157, %while.body.155 %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 @@ -3075,7 +3161,7 @@ if.merge.152: ; preds = %if.then.151, %while %loadN = load i64, ptr %allocaN, align 8 %add = add i64 %loadN, 1 store i64 %add, ptr %allocaN, align 8 - br label %while.hdr.148 + br label %while.hdr.154 } ; Function Attrs: nounwind @@ -3084,35 +3170,35 @@ entry: %alloca = alloca { ptr, i64 }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.219, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.228, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 - br label %while.hdr.157 + br label %while.hdr.163 -while.hdr.157: ; preds = %if.merge.161, %entry +while.hdr.163: ; preds = %if.merge.167, %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.158, label %while.exit.159 + br i1 %icmp, label %while.body.164, label %while.exit.165 -while.body.158: ; preds = %while.hdr.157 +while.body.164: ; preds = %while.hdr.163 %loadN = load i64, ptr %allocaN, align 8 %icmpN = icmp sgt i64 %loadN, 0 - br i1 %icmpN, label %if.then.160, label %if.merge.161 + br i1 %icmpN, label %if.then.166, label %if.merge.167 -while.exit.159: ; preds = %while.hdr.157 +while.exit.165: ; preds = %while.hdr.163 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.220, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.229, i64 1 }) ret { ptr, i64 } %call -if.then.160: ; preds = %while.body.158 +if.then.166: ; preds = %while.body.164 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.221, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.230, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %if.merge.161 + br label %if.merge.167 -if.merge.161: ; preds = %if.then.160, %while.body.158 +if.merge.167: ; preds = %if.then.166, %while.body.164 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %alloca, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -3129,7 +3215,7 @@ if.merge.161: ; preds = %if.then.160, %while %loadN = load i64, ptr %allocaN, align 8 %add = add i64 %loadN, 1 store i64 %add, ptr %allocaN, align 8 - br label %while.hdr.157 + br label %while.hdr.163 } ; Function Attrs: nounwind @@ -3138,35 +3224,35 @@ entry: %alloca = alloca { ptr, i64 }, align 8 store { ptr, i64 } %1, ptr %alloca, align 8 %allocaN = alloca { ptr, i64 }, align 8 - store { ptr, i64 } { ptr @str.222, i64 1 }, ptr %allocaN, align 8 + store { ptr, i64 } { ptr @str.231, i64 1 }, ptr %allocaN, align 8 %allocaN = alloca i64, align 8 store i64 0, ptr %allocaN, align 8 - br label %while.hdr.162 + br label %while.hdr.168 -while.hdr.162: ; preds = %if.merge.166, %entry +while.hdr.168: ; preds = %if.merge.172, %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.163, label %while.exit.164 + br i1 %icmp, label %while.body.169, label %while.exit.170 -while.body.163: ; preds = %while.hdr.162 +while.body.169: ; preds = %while.hdr.168 %loadN = load i64, ptr %allocaN, align 8 %icmpN = icmp sgt i64 %loadN, 0 - br i1 %icmpN, label %if.then.165, label %if.merge.166 + br i1 %icmpN, label %if.then.171, label %if.merge.172 -while.exit.164: ; preds = %while.hdr.162 +while.exit.170: ; preds = %while.hdr.168 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.223, i64 1 }) + %call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.232, i64 1 }) ret { ptr, i64 } %call -if.then.165: ; preds = %while.body.163 +if.then.171: ; preds = %while.body.169 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.224, i64 2 }) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.233, i64 2 }) store { ptr, i64 } %callN, ptr %allocaN, align 8 - br label %if.merge.166 + br label %if.merge.172 -if.merge.166: ; preds = %if.then.165, %while.body.163 +if.merge.172: ; preds = %if.then.171, %while.body.169 %loadN = load { ptr, i64 }, ptr %allocaN, align 8 %loadN = load { ptr, i64 }, ptr %alloca, align 8 %loadN = load i64, ptr %allocaN, align 8 @@ -3183,7 +3269,7 @@ if.merge.166: ; preds = %if.then.165, %while %loadN = load i64, ptr %allocaN, align 8 %add = add i64 %loadN, 1 store i64 %add, ptr %allocaN, align 8 - br label %while.hdr.162 + br label %while.hdr.168 } ; Function Attrs: nounwind @@ -3197,20 +3283,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.188, label %if.else.189 + br i1 %icmp, label %if.then.195, label %if.else.196 -if.then.188: ; preds = %entry - br label %if.merge.190 +if.then.195: ; preds = %entry + br label %if.merge.197 -if.else.189: ; preds = %entry +if.else.196: ; 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.227, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.226, i64 5 }, { ptr, i64 } %callN) - br label %if.merge.190 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.236, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.235, i64 5 }, { ptr, i64 } %callN) + br label %if.merge.197 -if.merge.190: ; preds = %if.else.189, %if.then.188 - %bp = phi { ptr, i64 } [ { ptr @str.225, i64 4 }, %if.then.188 ], [ %callN, %if.else.189 ] +if.merge.197: ; preds = %if.else.196, %if.then.195 + %bp = phi { ptr, i64 } [ { ptr @str.234, i64 4 }, %if.then.195 ], [ %callN, %if.else.196 ] ret { ptr, i64 } %bp } @@ -3225,20 +3311,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.212, label %if.else.213 + br i1 %icmp, label %if.then.219, label %if.else.220 -if.then.212: ; preds = %entry - br label %if.merge.214 +if.then.219: ; preds = %entry + br label %if.merge.221 -if.else.213: ; preds = %entry +if.else.220: ; 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.230, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.229, i64 11 }, { ptr, i64 } %callN) - br label %if.merge.214 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.239, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.238, i64 11 }, { ptr, i64 } %callN) + br label %if.merge.221 -if.merge.214: ; preds = %if.else.213, %if.then.212 - %bp = phi { ptr, i64 } [ { ptr @str.228, i64 4 }, %if.then.212 ], [ %callN, %if.else.213 ] +if.merge.221: ; preds = %if.else.220, %if.then.219 + %bp = phi { ptr, i64 } [ { ptr @str.237, i64 4 }, %if.then.219 ], [ %callN, %if.else.220 ] ret { ptr, i64 } %bp } @@ -3253,20 +3339,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.215, label %if.else.216 + br i1 %icmp, label %if.then.222, label %if.else.223 -if.then.215: ; preds = %entry - br label %if.merge.217 +if.then.222: ; preds = %entry + br label %if.merge.224 -if.else.216: ; preds = %entry +if.else.223: ; 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.233, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.232, i64 4 }, { ptr, i64 } %callN) - br label %if.merge.217 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.242, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.241, i64 4 }, { ptr, i64 } %callN) + br label %if.merge.224 -if.merge.217: ; preds = %if.else.216, %if.then.215 - %bp = phi { ptr, i64 } [ { ptr @str.231, i64 4 }, %if.then.215 ], [ %callN, %if.else.216 ] +if.merge.224: ; preds = %if.else.223, %if.then.222 + %bp = phi { ptr, i64 } [ { ptr @str.240, i64 4 }, %if.then.222 ], [ %callN, %if.else.223 ] ret { ptr, i64 } %bp } @@ -3281,20 +3367,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.218, label %if.else.219 + br i1 %icmp, label %if.then.225, label %if.else.226 -if.then.218: ; preds = %entry - br label %if.merge.220 +if.then.225: ; preds = %entry + br label %if.merge.227 -if.else.219: ; preds = %entry +if.else.226: ; 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.236, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.235, i64 11 }, { ptr, i64 } %callN) - br label %if.merge.220 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.245, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.244, i64 11 }, { ptr, i64 } %callN) + br label %if.merge.227 -if.merge.220: ; preds = %if.else.219, %if.then.218 - %bp = phi { ptr, i64 } [ { ptr @str.234, i64 4 }, %if.then.218 ], [ %callN, %if.else.219 ] +if.merge.227: ; preds = %if.else.226, %if.then.225 + %bp = phi { ptr, i64 } [ { ptr @str.243, i64 4 }, %if.then.225 ], [ %callN, %if.else.226 ] ret { ptr, i64 } %bp } @@ -3309,20 +3395,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.221, label %if.else.222 + br i1 %icmp, label %if.then.228, label %if.else.229 -if.then.221: ; preds = %entry - br label %if.merge.223 +if.then.228: ; preds = %entry + br label %if.merge.230 -if.else.222: ; preds = %entry +if.else.229: ; 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.239, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.238, i64 6 }, { ptr, i64 } %callN) - br label %if.merge.223 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.248, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.247, i64 6 }, { ptr, i64 } %callN) + br label %if.merge.230 -if.merge.223: ; preds = %if.else.222, %if.then.221 - %bp = phi { ptr, i64 } [ { ptr @str.237, i64 4 }, %if.then.221 ], [ %callN, %if.else.222 ] +if.merge.230: ; preds = %if.else.229, %if.then.228 + %bp = phi { ptr, i64 } [ { ptr @str.246, i64 4 }, %if.then.228 ], [ %callN, %if.else.229 ] ret { ptr, i64 } %bp } @@ -3336,20 +3422,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.224, label %if.else.225 + br i1 %icmp, label %if.then.231, label %if.else.232 -if.then.224: ; preds = %entry - br label %if.merge.226 +if.then.231: ; preds = %entry + br label %if.merge.233 -if.else.225: ; preds = %entry +if.else.232: ; 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.242, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.241, i64 5 }, { ptr, i64 } %callN) - br label %if.merge.226 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.251, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.250, i64 5 }, { ptr, i64 } %callN) + br label %if.merge.233 -if.merge.226: ; preds = %if.else.225, %if.then.224 - %bp = phi { ptr, i64 } [ { ptr @str.240, i64 4 }, %if.then.224 ], [ %callN, %if.else.225 ] +if.merge.233: ; preds = %if.else.232, %if.then.231 + %bp = phi { ptr, i64 } [ { ptr @str.249, i64 4 }, %if.then.231 ], [ %callN, %if.else.232 ] ret { ptr, i64 } %bp } @@ -3364,20 +3450,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.227, label %if.else.228 + br i1 %icmp, label %if.then.234, label %if.else.235 -if.then.227: ; preds = %entry - br label %if.merge.229 +if.then.234: ; preds = %entry + br label %if.merge.236 -if.else.228: ; preds = %entry +if.else.235: ; 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.245, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.244, i64 9 }, { ptr, i64 } %callN) - br label %if.merge.229 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.254, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.253, i64 9 }, { ptr, i64 } %callN) + br label %if.merge.236 -if.merge.229: ; preds = %if.else.228, %if.then.227 - %bp = phi { ptr, i64 } [ { ptr @str.243, i64 4 }, %if.then.227 ], [ %callN, %if.else.228 ] +if.merge.236: ; preds = %if.else.235, %if.then.234 + %bp = phi { ptr, i64 } [ { ptr @str.252, i64 4 }, %if.then.234 ], [ %callN, %if.else.235 ] ret { ptr, i64 } %bp } @@ -3392,20 +3478,48 @@ 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.230, label %if.else.231 + br i1 %icmp, label %if.then.237, label %if.else.238 -if.then.230: ; preds = %entry - br label %if.merge.232 +if.then.237: ; preds = %entry + br label %if.merge.239 -if.else.231: ; preds = %entry +if.else.238: ; 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.248, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.247, i64 18 }, { ptr, i64 } %callN) - br label %if.merge.232 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.257, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.256, i64 18 }, { ptr, i64 } %callN) + br label %if.merge.239 -if.merge.232: ; preds = %if.else.231, %if.then.230 - %bp = phi { ptr, i64 } [ { ptr @str.246, i64 4 }, %if.then.230 ], [ %callN, %if.else.231 ] +if.merge.239: ; preds = %if.else.238, %if.then.237 + %bp = phi { ptr, i64 } [ { ptr @str.255, i64 4 }, %if.then.237 ], [ %callN, %if.else.238 ] + ret { ptr, i64 } %bp +} + +; Function Attrs: nounwind +define internal { ptr, i64 } @pointer_to_string__ptr_NSString(ptr %0, ptr %1) #0 { +entry: + %alloca = alloca ptr, align 8 + store ptr %1, ptr %alloca, align 8 + %allocaN = alloca i64, align 8 + %load = load ptr, ptr %alloca, align 8 + %pti = ptrtoint ptr %load to i64 + 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.240, label %if.else.241 + +if.then.240: ; preds = %entry + br label %if.merge.242 + +if.else.241: ; 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.260, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.259, i64 9 }, { ptr, i64 } %callN) + br label %if.merge.242 + +if.merge.242: ; preds = %if.else.241, %if.then.240 + %bp = phi { ptr, i64 } [ { ptr @str.258, i64 4 }, %if.then.240 ], [ %callN, %if.else.241 ] ret { ptr, i64 } %bp } @@ -3420,20 +3534,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.233, label %if.else.234 + br i1 %icmp, label %if.then.243, label %if.else.244 -if.then.233: ; preds = %entry - br label %if.merge.235 +if.then.243: ; preds = %entry + br label %if.merge.245 -if.else.234: ; preds = %entry +if.else.244: ; 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.251, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.250, i64 12 }, { ptr, i64 } %callN) - br label %if.merge.235 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.263, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.262, i64 12 }, { ptr, i64 } %callN) + br label %if.merge.245 -if.merge.235: ; preds = %if.else.234, %if.then.233 - %bp = phi { ptr, i64 } [ { ptr @str.249, i64 4 }, %if.then.233 ], [ %callN, %if.else.234 ] +if.merge.245: ; preds = %if.else.244, %if.then.243 + %bp = phi { ptr, i64 } [ { ptr @str.261, i64 4 }, %if.then.243 ], [ %callN, %if.else.244 ] ret { ptr, i64 } %bp } @@ -3448,20 +3562,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.236, label %if.else.237 + br i1 %icmp, label %if.then.246, label %if.else.247 -if.then.236: ; preds = %entry - br label %if.merge.238 +if.then.246: ; preds = %entry + br label %if.merge.248 -if.else.237: ; preds = %entry +if.else.247: ; 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.254, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.253, i64 4 }, { ptr, i64 } %callN) - br label %if.merge.238 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.266, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.265, i64 4 }, { ptr, i64 } %callN) + br label %if.merge.248 -if.merge.238: ; preds = %if.else.237, %if.then.236 - %bp = phi { ptr, i64 } [ { ptr @str.252, i64 4 }, %if.then.236 ], [ %callN, %if.else.237 ] +if.merge.248: ; preds = %if.else.247, %if.then.246 + %bp = phi { ptr, i64 } [ { ptr @str.264, i64 4 }, %if.then.246 ], [ %callN, %if.else.247 ] ret { ptr, i64 } %bp } @@ -3476,20 +3590,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.239, label %if.else.240 + br i1 %icmp, label %if.then.249, label %if.else.250 -if.then.239: ; preds = %entry - br label %if.merge.241 +if.then.249: ; preds = %entry + br label %if.merge.251 -if.else.240: ; preds = %entry +if.else.250: ; 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.257, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.256, i64 6 }, { ptr, i64 } %callN) - br label %if.merge.241 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.269, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.268, i64 6 }, { ptr, i64 } %callN) + br label %if.merge.251 -if.merge.241: ; preds = %if.else.240, %if.then.239 - %bp = phi { ptr, i64 } [ { ptr @str.255, i64 4 }, %if.then.239 ], [ %callN, %if.else.240 ] +if.merge.251: ; preds = %if.else.250, %if.then.249 + %bp = phi { ptr, i64 } [ { ptr @str.267, i64 4 }, %if.then.249 ], [ %callN, %if.else.250 ] ret { ptr, i64 } %bp } @@ -3504,20 +3618,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.242, label %if.else.243 + br i1 %icmp, label %if.then.252, label %if.else.253 -if.then.242: ; preds = %entry - br label %if.merge.244 +if.then.252: ; preds = %entry + br label %if.merge.254 -if.else.243: ; preds = %entry +if.else.253: ; 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.260, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.259, i64 5 }, { ptr, i64 } %callN) - br label %if.merge.244 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.272, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.271, i64 5 }, { ptr, i64 } %callN) + br label %if.merge.254 -if.merge.244: ; preds = %if.else.243, %if.then.242 - %bp = phi { ptr, i64 } [ { ptr @str.258, i64 4 }, %if.then.242 ], [ %callN, %if.else.243 ] +if.merge.254: ; preds = %if.else.253, %if.then.252 + %bp = phi { ptr, i64 } [ { ptr @str.270, i64 4 }, %if.then.252 ], [ %callN, %if.else.253 ] ret { ptr, i64 } %bp } @@ -3532,20 +3646,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.245, label %if.else.246 + br i1 %icmp, label %if.then.255, label %if.else.256 -if.then.245: ; preds = %entry - br label %if.merge.247 +if.then.255: ; preds = %entry + br label %if.merge.257 -if.else.246: ; preds = %entry +if.else.256: ; 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.263, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.262, i64 7 }, { ptr, i64 } %callN) - br label %if.merge.247 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.275, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.274, i64 7 }, { ptr, i64 } %callN) + br label %if.merge.257 -if.merge.247: ; preds = %if.else.246, %if.then.245 - %bp = phi { ptr, i64 } [ { ptr @str.261, i64 4 }, %if.then.245 ], [ %callN, %if.else.246 ] +if.merge.257: ; preds = %if.else.256, %if.then.255 + %bp = phi { ptr, i64 } [ { ptr @str.273, i64 4 }, %if.then.255 ], [ %callN, %if.else.256 ] ret { ptr, i64 } %bp } @@ -3560,20 +3674,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.248, label %if.else.249 + br i1 %icmp, label %if.then.258, label %if.else.259 -if.then.248: ; preds = %entry - br label %if.merge.250 +if.then.258: ; preds = %entry + br label %if.merge.260 -if.else.249: ; preds = %entry +if.else.259: ; 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.266, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.265, i64 4 }, { ptr, i64 } %callN) - br label %if.merge.250 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.278, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.277, i64 4 }, { ptr, i64 } %callN) + br label %if.merge.260 -if.merge.250: ; preds = %if.else.249, %if.then.248 - %bp = phi { ptr, i64 } [ { ptr @str.264, i64 4 }, %if.then.248 ], [ %callN, %if.else.249 ] +if.merge.260: ; preds = %if.else.259, %if.then.258 + %bp = phi { ptr, i64 } [ { ptr @str.276, i64 4 }, %if.then.258 ], [ %callN, %if.else.259 ] ret { ptr, i64 } %bp } @@ -3588,20 +3702,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.251, label %if.else.252 + br i1 %icmp, label %if.then.261, label %if.else.262 -if.then.251: ; preds = %entry - br label %if.merge.253 +if.then.261: ; preds = %entry + br label %if.merge.263 -if.else.252: ; preds = %entry +if.else.262: ; 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.269, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.268, i64 7 }, { ptr, i64 } %callN) - br label %if.merge.253 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.281, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.280, i64 7 }, { ptr, i64 } %callN) + br label %if.merge.263 -if.merge.253: ; preds = %if.else.252, %if.then.251 - %bp = phi { ptr, i64 } [ { ptr @str.267, i64 4 }, %if.then.251 ], [ %callN, %if.else.252 ] +if.merge.263: ; preds = %if.else.262, %if.then.261 + %bp = phi { ptr, i64 } [ { ptr @str.279, i64 4 }, %if.then.261 ], [ %callN, %if.else.262 ] ret { ptr, i64 } %bp } @@ -3616,20 +3730,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.254, label %if.else.255 + br i1 %icmp, label %if.then.264, label %if.else.265 -if.then.254: ; preds = %entry - br label %if.merge.256 +if.then.264: ; preds = %entry + br label %if.merge.266 -if.else.255: ; preds = %entry +if.else.265: ; 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.272, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.271, i64 6 }, { ptr, i64 } %callN) - br label %if.merge.256 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.284, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.283, i64 6 }, { ptr, i64 } %callN) + br label %if.merge.266 -if.merge.256: ; preds = %if.else.255, %if.then.254 - %bp = phi { ptr, i64 } [ { ptr @str.270, i64 4 }, %if.then.254 ], [ %callN, %if.else.255 ] +if.merge.266: ; preds = %if.else.265, %if.then.264 + %bp = phi { ptr, i64 } [ { ptr @str.282, i64 4 }, %if.then.264 ], [ %callN, %if.else.265 ] ret { ptr, i64 } %bp } @@ -3644,20 +3758,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.257, label %if.else.258 + br i1 %icmp, label %if.then.267, label %if.else.268 -if.then.257: ; preds = %entry - br label %if.merge.259 +if.then.267: ; preds = %entry + br label %if.merge.269 -if.else.258: ; preds = %entry +if.else.268: ; 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.275, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.274, i64 3 }, { ptr, i64 } %callN) - br label %if.merge.259 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.287, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.286, i64 3 }, { ptr, i64 } %callN) + br label %if.merge.269 -if.merge.259: ; preds = %if.else.258, %if.then.257 - %bp = phi { ptr, i64 } [ { ptr @str.273, i64 4 }, %if.then.257 ], [ %callN, %if.else.258 ] +if.merge.269: ; preds = %if.else.268, %if.then.267 + %bp = phi { ptr, i64 } [ { ptr @str.285, i64 4 }, %if.then.267 ], [ %callN, %if.else.268 ] ret { ptr, i64 } %bp } @@ -3672,20 +3786,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.260, label %if.else.261 + br i1 %icmp, label %if.then.270, label %if.else.271 -if.then.260: ; preds = %entry - br label %if.merge.262 +if.then.270: ; preds = %entry + br label %if.merge.272 -if.else.261: ; preds = %entry +if.else.271: ; 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.278, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.277, i64 7 }, { ptr, i64 } %callN) - br label %if.merge.262 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.290, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.289, i64 7 }, { ptr, i64 } %callN) + br label %if.merge.272 -if.merge.262: ; preds = %if.else.261, %if.then.260 - %bp = phi { ptr, i64 } [ { ptr @str.276, i64 4 }, %if.then.260 ], [ %callN, %if.else.261 ] +if.merge.272: ; preds = %if.else.271, %if.then.270 + %bp = phi { ptr, i64 } [ { ptr @str.288, i64 4 }, %if.then.270 ], [ %callN, %if.else.271 ] ret { ptr, i64 } %bp } @@ -3700,20 +3814,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.263, label %if.else.264 + br i1 %icmp, label %if.then.273, label %if.else.274 -if.then.263: ; preds = %entry - br label %if.merge.265 +if.then.273: ; preds = %entry + br label %if.merge.275 -if.else.264: ; preds = %entry +if.else.274: ; 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.281, i64 3 }, { ptr, i64 } %call) - %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.280, i64 7 }, { ptr, i64 } %callN) - br label %if.merge.265 + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.293, i64 3 }, { ptr, i64 } %call) + %callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.292, i64 7 }, { ptr, i64 } %callN) + br label %if.merge.275 -if.merge.265: ; preds = %if.else.264, %if.then.263 - %bp = phi { ptr, i64 } [ { ptr @str.279, i64 4 }, %if.then.263 ], [ %callN, %if.else.264 ] +if.merge.275: ; preds = %if.else.274, %if.then.273 + %bp = phi { ptr, i64 } [ { ptr @str.291, i64 4 }, %if.then.273 ], [ %callN, %if.else.274 ] ret { ptr, i64 } %bp }