Files
sx/examples/expected/0903-optionals-optional-roundtrip.ir
agra 50dd2cc3d8 test(ir): lock coercion forms before A4.3 extraction (A4.3 scaffolding step 1)
Test-first scaffolding ahead of extracting src/ir/conversions.zig — no code
change to the coercion targets (lowerXX / coerceToType / coerceOrErase /
buildProtocolErasure / tryUserConversion / failable-adapter selection).

Adds 4 .ir snapshots (first .ir for 01xx/09xx/10xx), each captured surgically
via `sx ir | normalize_ir`, path-free, idempotent, and print-free at IR-gen time
(0114-types-build-block-convert was rejected — it prints `--- void / 0 args ---`
+ sx source at IR-gen):
- 0107-types-int-cmp-in-float-ternary   numeric int<->float coercion
- 0903-optionals-optional-roundtrip     optional wrap/unwrap
- 0904-optionals-any-to-string-optional xx unbox_any + optional
- 1004-errors-try                       error-channel adapter/coercion

Protocol erasure + user Into are already pinned by the 04xx snapshots
(0400/0413/0414/0416); duplicate-conversion rejection by the 0410/0411/0412
anchors.

Adds 1 unit test via the public surface (no new exposure, mirroring A4.1/A4.2
sub-step 1): optionalOfFlattened — the optional wrap/flatten coercion rule
(T -> ?T; ?T -> ?T, never ??T; contrasted with the non-flattening optionalOf).
The lowerXX/coerceToType/coerceOrErase/buildProtocolErasure decisions are private
+ emission-bound, so their CoercionPlan unit tests land with the extracted module
in sub-step 2.

zig build, zig build test, tests/run_examples.sh (357/0) all green.
2026-06-02 22:32:01 +03:00

4416 lines
204 KiB
Plaintext

@__sx_default_context = internal global { { ptr, ptr, ptr }, ptr } { { ptr, ptr, ptr } { ptr null, ptr @__thunk_CAllocator_Allocator_alloc, ptr @__thunk_CAllocator_Allocator_dealloc }, ptr null }
@__Sizable__Widget__vtable = internal constant { ptr } { ptr @__thunk_Widget_Sizable_size }
@str = private unnamed_addr constant [2 x i8] c"0\00", align 1
@str.1 = private unnamed_addr constant [5 x i8] c"true\00", align 1
@str.2 = private unnamed_addr constant [6 x i8] c"false\00", align 1
@str.3 = private unnamed_addr constant [2 x i8] c"0\00", align 1
@str.4 = private unnamed_addr constant [4 x i8] c"<?>\00", align 1
@str.5 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1
@tn.str = private constant [13 x i8] c"<unresolved>\00"
@tn.str.6 = private constant [5 x i8] c"bool\00"
@tn.str.7 = private constant [3 x i8] c"s8\00"
@tn.str.8 = private constant [4 x i8] c"s16\00"
@tn.str.9 = private constant [4 x i8] c"s32\00"
@tn.str.10 = private constant [4 x i8] c"s64\00"
@tn.str.11 = private constant [3 x i8] c"u8\00"
@tn.str.12 = private constant [4 x i8] c"u16\00"
@tn.str.13 = private constant [4 x i8] c"u32\00"
@tn.str.14 = private constant [4 x i8] c"u64\00"
@tn.str.15 = private constant [4 x i8] c"f32\00"
@tn.str.16 = private constant [4 x i8] c"f64\00"
@tn.str.17 = private constant [7 x i8] c"string\00"
@tn.str.18 = private constant [4 x i8] c"Any\00"
@tn.str.19 = private constant [9 x i8] c"noreturn\00"
@tn.str.20 = private constant [6 x i8] c"isize\00"
@tn.str.21 = private constant [6 x i8] c"usize\00"
@tn.str.22 = private constant [5 x i8] c"void\00"
@tn.str.23 = private constant [6 x i8] c"*void\00"
@tn.str.24 = private constant [16 x i8] c"Source_Location\00"
@tn.str.25 = private constant [10 x i8] c"Allocator\00"
@tn.str.26 = private constant [11 x i8] c"CAllocator\00"
@tn.str.27 = private constant [12 x i8] c"*CAllocator\00"
@tn.str.28 = private constant [4 x i8] c"GPA\00"
@tn.str.29 = private constant [5 x i8] c"*GPA\00"
@tn.str.30 = private constant [11 x i8] c"ArenaChunk\00"
@tn.str.31 = private constant [12 x i8] c"*ArenaChunk\00"
@tn.str.32 = private constant [6 x i8] c"Arena\00"
@tn.str.33 = private constant [7 x i8] c"*Arena\00"
@tn.str.34 = private constant [6 x i8] c"[*]u8\00"
@tn.str.35 = private constant [9 x i8] c"BufAlloc\00"
@tn.str.36 = private constant [10 x i8] c"*BufAlloc\00"
@tn.str.37 = private constant [18 x i8] c"TrackingAllocator\00"
@tn.str.38 = private constant [19 x i8] c"*TrackingAllocator\00"
@tn.str.39 = private constant [8 x i8] c"Context\00"
@tn.str.40 = private constant [9 x i8] c"[]string\00"
@tn.str.41 = private constant [5 x i8] c"?f32\00"
@tn.str.42 = private constant [13 x i8] c"ProposedSize\00"
@tn.str.43 = private constant [8 x i8] c"Sizable\00"
@tn.str.44 = private constant [18 x i8] c"__Sizable__Vtable\00"
@tn.str.45 = private constant [7 x i8] c"Widget\00"
@tn.str.46 = private constant [8 x i8] c"*Widget\00"
@tn.str.47 = private constant [13 x i8] c"**CAllocator\00"
@tn.str.48 = private constant [5 x i8] c"*s64\00"
@tn.str.49 = private constant [7 x i8] c"**void\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"*[]Any\00"
@tn.str.54 = private constant [4 x i8] c"*u8\00"
@tn.str.55 = private constant [6 x i8] c"*bool\00"
@tn.str.56 = private constant [14 x i8] c"*ProposedSize\00"
@tn.str.57 = private constant [5 x i8] c"*f32\00"
@tn.str.58 = private constant [5 x i8] c"*f64\00"
@tn.str.59 = private constant [7 x i8] c"[1]Any\00"
@tn.str.60 = private constant [8 x i8] c"*[1]Any\00"
@tn.str.61 = private constant [9 x i8] c"*Sizable\00"
@tn.str.62 = private constant [9 x i8] c"**Widget\00"
@tn.str.63 = private constant [19 x i8] c"*__Sizable__Vtable\00"
@tn.str.64 = private constant [17 x i8] c"*Source_Location\00"
@tn.str.65 = private constant [11 x i8] c"*Allocator\00"
@tn.str.66 = private constant [9 x i8] c"*Context\00"
@tn.str.67 = private constant [10 x i8] c"*[]string\00"
@tn.str.68 = private constant [6 x i8] c"**GPA\00"
@tn.str.69 = private constant [13 x i8] c"**ArenaChunk\00"
@tn.str.70 = private constant [8 x i8] c"**Arena\00"
@tn.str.71 = private constant [7 x i8] c"*[*]u8\00"
@tn.str.72 = private constant [11 x i8] c"**BufAlloc\00"
@tn.str.73 = private constant [20 x i8] c"**TrackingAllocator\00"
@tn.str.74 = private constant [14 x i8] c"***CAllocator\00"
@tn.str.75 = private constant [6 x i8] c"**s64\00"
@tn.str.76 = private constant [8 x i8] c"***void\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 [8 x i8] c"**[]Any\00"
@tn.str.80 = private constant [5 x i8] c"**u8\00"
@tn.str.81 = private constant [7 x i8] c"**bool\00"
@tn.str.82 = private constant [15 x i8] c"**ProposedSize\00"
@tn.str.83 = private constant [6 x i8] c"**f32\00"
@tn.str.84 = private constant [6 x i8] c"**f64\00"
@tn.str.85 = private constant [9 x i8] c"**[1]Any\00"
@tn.str.86 = private constant [10 x i8] c"**Sizable\00"
@tn.str.87 = private constant [10 x i8] c"***Widget\00"
@tn.str.88 = private constant [20 x i8] c"**__Sizable__Vtable\00"
@tn.str.89 = private constant [6 x i8] c"*?f32\00"
@__sx_type_names = private constant [85 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 15 }, { ptr, i64 } { ptr @tn.str.25, i64 9 }, { ptr, i64 } { ptr @tn.str.26, i64 10 }, { ptr, i64 } { ptr @tn.str.27, i64 11 }, { ptr, i64 } { ptr @tn.str.28, i64 3 }, { ptr, i64 } { ptr @tn.str.29, i64 4 }, { ptr, i64 } { ptr @tn.str.30, i64 10 }, { ptr, i64 } { ptr @tn.str.31, i64 11 }, { ptr, i64 } { ptr @tn.str.32, i64 5 }, { ptr, i64 } { ptr @tn.str.33, i64 6 }, { ptr, i64 } { ptr @tn.str.34, i64 5 }, { ptr, i64 } { ptr @tn.str.35, i64 8 }, { ptr, i64 } { ptr @tn.str.36, i64 9 }, { ptr, i64 } { ptr @tn.str.37, i64 17 }, { ptr, i64 } { ptr @tn.str.38, i64 18 }, { ptr, i64 } { ptr @tn.str.39, i64 7 }, { ptr, i64 } { ptr @tn.str.40, i64 8 }, { ptr, i64 } { ptr @tn.str.41, i64 4 }, { ptr, i64 } { ptr @tn.str.42, i64 12 }, { ptr, i64 } { ptr @tn.str.43, i64 7 }, { ptr, i64 } { ptr @tn.str.44, i64 17 }, { ptr, i64 } { ptr @tn.str.45, i64 6 }, { ptr, i64 } { ptr @tn.str.46, i64 7 }, { ptr, i64 } { ptr @tn.str.47, i64 12 }, { ptr, i64 } { ptr @tn.str.48, i64 4 }, { ptr, i64 } { ptr @tn.str.49, i64 6 }, { 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 3 }, { ptr, i64 } { ptr @tn.str.55, i64 5 }, { ptr, i64 } { ptr @tn.str.56, i64 13 }, { ptr, i64 } { ptr @tn.str.57, i64 4 }, { ptr, i64 } { ptr @tn.str.58, i64 4 }, { ptr, i64 } { ptr @tn.str.59, i64 6 }, { ptr, i64 } { ptr @tn.str.60, i64 7 }, { ptr, i64 } { ptr @tn.str.61, i64 8 }, { ptr, i64 } { ptr @tn.str.62, i64 8 }, { ptr, i64 } { ptr @tn.str.63, i64 18 }, { ptr, i64 } { ptr @tn.str.64, i64 16 }, { ptr, i64 } { ptr @tn.str.65, i64 10 }, { ptr, i64 } { ptr @tn.str.66, i64 8 }, { ptr, i64 } { ptr @tn.str.67, i64 9 }, { ptr, i64 } { ptr @tn.str.68, i64 5 }, { ptr, i64 } { ptr @tn.str.69, i64 12 }, { ptr, i64 } { ptr @tn.str.70, i64 7 }, { ptr, i64 } { ptr @tn.str.71, i64 6 }, { ptr, i64 } { ptr @tn.str.72, i64 10 }, { ptr, i64 } { ptr @tn.str.73, i64 19 }, { ptr, i64 } { ptr @tn.str.74, i64 13 }, { ptr, i64 } { ptr @tn.str.75, i64 5 }, { ptr, i64 } { ptr @tn.str.76, i64 7 }, { ptr, i64 } { ptr @tn.str.77, i64 8 }, { ptr, i64 } { ptr @tn.str.78, i64 5 }, { ptr, i64 } { ptr @tn.str.79, i64 7 }, { ptr, i64 } { ptr @tn.str.80, i64 4 }, { ptr, i64 } { ptr @tn.str.81, i64 6 }, { ptr, i64 } { ptr @tn.str.82, i64 14 }, { ptr, i64 } { ptr @tn.str.83, i64 5 }, { ptr, i64 } { ptr @tn.str.84, i64 5 }, { ptr, i64 } { ptr @tn.str.85, i64 8 }, { ptr, i64 } { ptr @tn.str.86, i64 9 }, { ptr, i64 } { ptr @tn.str.87, i64 9 }, { ptr, i64 } { ptr @tn.str.88, i64 19 }, { ptr, i64 } { ptr @tn.str.89, i64 5 }]
@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 [1 x i8] zeroinitializer, align 1
@str.93 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1
@str.94 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1
@str.95 = private unnamed_addr constant [15 x i8] c"result := \22\22; \00", align 1
@str.96 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1
@str.97 = private unnamed_addr constant [3 x i8] c", \00", align 1
@str.98 = private unnamed_addr constant [5 x i8] c")); \00", align 1
@str.99 = private unnamed_addr constant [44 x i8] c"result = concat(result, any_to_string(args[\00", align 1
@str.100 = private unnamed_addr constant [6 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 [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 [37 x i8] c"result = concat(result, substr(fmt, \00", align 1
@str.108 = private unnamed_addr constant [3 x i8] c", \00", align 1
@str.109 = private unnamed_addr constant [5 x i8] c")); \00", align 1
@str.110 = private unnamed_addr constant [22 x i8] c"=== Direct calls ===\0A\00", align 1
@str.111 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1
@str.112 = private unnamed_addr constant [22 x i8] c"=== Direct calls ===\0A\00", align 1
@str.113 = private unnamed_addr constant [9 x i8] c"d1 = {}\0A\00", align 1
@str.114 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1
@str.115 = private unnamed_addr constant [9 x i8] c"d1 = {}\0A\00", align 1
@str.116 = private unnamed_addr constant [9 x i8] c"d2 = {}\0A\00", align 1
@str.117 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1
@str.118 = private unnamed_addr constant [9 x i8] c"d2 = {}\0A\00", align 1
@str.119 = private unnamed_addr constant [9 x i8] c"d3 = {}\0A\00", align 1
@str.120 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1
@str.121 = private unnamed_addr constant [9 x i8] c"d3 = {}\0A\00", align 1
@str.122 = private unnamed_addr constant [9 x i8] c"d4 = {}\0A\00", align 1
@str.123 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1
@str.124 = private unnamed_addr constant [9 x i8] c"d4 = {}\0A\00", align 1
@str.125 = private unnamed_addr constant [27 x i8] c"=== Protocol dispatch ===\0A\00", align 1
@str.126 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1
@str.127 = private unnamed_addr constant [27 x i8] c"=== Protocol dispatch ===\0A\00", align 1
@str.128 = private unnamed_addr constant [9 x i8] c"r1 = {}\0A\00", align 1
@str.129 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1
@str.130 = private unnamed_addr constant [9 x i8] c"r1 = {}\0A\00", align 1
@str.131 = private unnamed_addr constant [9 x i8] c"r2 = {}\0A\00", align 1
@str.132 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1
@str.133 = private unnamed_addr constant [9 x i8] c"r2 = {}\0A\00", align 1
@str.134 = private unnamed_addr constant [9 x i8] c"r3 = {}\0A\00", align 1
@str.135 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1
@str.136 = private unnamed_addr constant [9 x i8] c"r3 = {}\0A\00", align 1
@str.137 = private unnamed_addr constant [9 x i8] c"r4 = {}\0A\00", align 1
@str.138 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1
@str.139 = private unnamed_addr constant [9 x i8] c"r4 = {}\0A\00", align 1
@str.140 = private unnamed_addr constant [16 x i8] c"Source_Location\00", align 1
@str.141 = private unnamed_addr constant [2 x i8] c"{\00", align 1
@str.142 = private unnamed_addr constant [2 x i8] c"}\00", align 1
@str.143 = private unnamed_addr constant [3 x i8] c", \00", align 1
@fld.str = private constant [5 x i8] c"file\00"
@fld.str.144 = private constant [5 x i8] c"line\00"
@fld.str.145 = private constant [4 x i8] c"col\00"
@fld.str.146 = private constant [5 x i8] c"func\00"
@field_names = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str, i64 4 }, { ptr, i64 } { ptr @fld.str.144, i64 4 }, { ptr, i64 } { ptr @fld.str.145, i64 3 }, { ptr, i64 } { ptr @fld.str.146, i64 4 }]
@str.147 = private unnamed_addr constant [3 x i8] c": \00", align 1
@str.148 = private unnamed_addr constant [10 x i8] c"Allocator\00", align 1
@str.149 = private unnamed_addr constant [2 x i8] c"{\00", align 1
@str.150 = private unnamed_addr constant [2 x i8] c"}\00", align 1
@str.151 = private unnamed_addr constant [3 x i8] c", \00", align 1
@fld.str.152 = private constant [4 x i8] c"ctx\00"
@fld.str.153 = private constant [6 x i8] c"alloc\00"
@fld.str.154 = private constant [8 x i8] c"dealloc\00"
@field_names.155 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.152, i64 3 }, { ptr, i64 } { ptr @fld.str.153, i64 5 }, { ptr, i64 } { ptr @fld.str.154, i64 7 }]
@str.156 = private unnamed_addr constant [3 x i8] c": \00", align 1
@str.157 = private unnamed_addr constant [11 x i8] c"CAllocator\00", align 1
@str.158 = private unnamed_addr constant [2 x i8] c"{\00", align 1
@str.159 = private unnamed_addr constant [2 x i8] c"}\00", align 1
@str.160 = private unnamed_addr constant [3 x i8] c", \00", align 1
@field_names.161 = private constant [0 x { ptr, i64 }] zeroinitializer
@str.162 = private unnamed_addr constant [3 x i8] c": \00", align 1
@str.163 = private unnamed_addr constant [4 x i8] c"GPA\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 [12 x i8] c"alloc_count\00"
@field_names.168 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.167, i64 11 }]
@str.169 = private unnamed_addr constant [3 x i8] c": \00", align 1
@str.170 = private unnamed_addr constant [11 x i8] c"ArenaChunk\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 [5 x i8] c"next\00"
@fld.str.175 = private constant [4 x i8] c"cap\00"
@field_names.176 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.174, i64 4 }, { ptr, i64 } { ptr @fld.str.175, i64 3 }]
@str.177 = private unnamed_addr constant [3 x i8] c": \00", align 1
@str.178 = private unnamed_addr constant [6 x i8] c"Arena\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
@fld.str.182 = private constant [6 x i8] c"first\00"
@fld.str.183 = private constant [10 x i8] c"end_index\00"
@fld.str.184 = private constant [7 x i8] c"parent\00"
@field_names.185 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.182, i64 5 }, { ptr, i64 } { ptr @fld.str.183, i64 9 }, { ptr, i64 } { ptr @fld.str.184, i64 6 }]
@str.186 = private unnamed_addr constant [3 x i8] c": \00", align 1
@str.187 = private unnamed_addr constant [9 x i8] c"BufAlloc\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
@fld.str.191 = private constant [4 x i8] c"buf\00"
@fld.str.192 = private constant [4 x i8] c"len\00"
@fld.str.193 = private constant [4 x i8] c"pos\00"
@field_names.194 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.191, i64 3 }, { ptr, i64 } { ptr @fld.str.192, i64 3 }, { ptr, i64 } { ptr @fld.str.193, i64 3 }]
@str.195 = private unnamed_addr constant [3 x i8] c": \00", align 1
@str.196 = private unnamed_addr constant [18 x i8] c"TrackingAllocator\00", align 1
@str.197 = private unnamed_addr constant [2 x i8] c"{\00", align 1
@str.198 = private unnamed_addr constant [2 x i8] c"}\00", align 1
@str.199 = private unnamed_addr constant [3 x i8] c", \00", align 1
@fld.str.200 = private constant [7 x i8] c"parent\00"
@fld.str.201 = private constant [12 x i8] c"alloc_count\00"
@fld.str.202 = private constant [14 x i8] c"dealloc_count\00"
@fld.str.203 = private constant [18 x i8] c"total_alloc_bytes\00"
@field_names.204 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.200, i64 6 }, { ptr, i64 } { ptr @fld.str.201, i64 11 }, { ptr, i64 } { ptr @fld.str.202, i64 13 }, { ptr, i64 } { ptr @fld.str.203, i64 17 }]
@str.205 = private unnamed_addr constant [3 x i8] c": \00", align 1
@str.206 = private unnamed_addr constant [8 x i8] c"Context\00", align 1
@str.207 = private unnamed_addr constant [2 x i8] c"{\00", align 1
@str.208 = private unnamed_addr constant [2 x i8] c"}\00", align 1
@str.209 = private unnamed_addr constant [3 x i8] c", \00", align 1
@fld.str.210 = private constant [10 x i8] c"allocator\00"
@fld.str.211 = private constant [5 x i8] c"data\00"
@field_names.212 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.210, i64 9 }, { ptr, i64 } { ptr @fld.str.211, i64 4 }]
@str.213 = private unnamed_addr constant [3 x i8] c": \00", align 1
@str.214 = private unnamed_addr constant [13 x i8] c"ProposedSize\00", align 1
@str.215 = private unnamed_addr constant [2 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 [3 x i8] c", \00", align 1
@fld.str.218 = private constant [6 x i8] c"width\00"
@fld.str.219 = private constant [7 x i8] c"height\00"
@field_names.220 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.218, i64 5 }, { ptr, i64 } { ptr @fld.str.219, i64 6 }]
@str.221 = private unnamed_addr constant [3 x i8] c": \00", align 1
@str.222 = private unnamed_addr constant [8 x i8] c"Sizable\00", align 1
@str.223 = private unnamed_addr constant [2 x i8] c"{\00", align 1
@str.224 = private unnamed_addr constant [2 x i8] c"}\00", align 1
@str.225 = private unnamed_addr constant [3 x i8] c", \00", align 1
@fld.str.226 = private constant [4 x i8] c"ctx\00"
@fld.str.227 = private constant [9 x i8] c"__vtable\00"
@field_names.228 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.226, i64 3 }, { ptr, i64 } { ptr @fld.str.227, i64 8 }]
@str.229 = private unnamed_addr constant [3 x i8] c": \00", align 1
@str.230 = private unnamed_addr constant [18 x i8] c"__Sizable__Vtable\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
@fld.str.234 = private constant [5 x i8] c"size\00"
@field_names.235 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.234, i64 4 }]
@str.236 = private unnamed_addr constant [3 x i8] c": \00", align 1
@str.237 = private unnamed_addr constant [7 x i8] c"Widget\00", align 1
@str.238 = private unnamed_addr constant [2 x i8] c"{\00", align 1
@str.239 = private unnamed_addr constant [2 x i8] c"}\00", align 1
@str.240 = private unnamed_addr constant [3 x i8] c", \00", align 1
@field_names.241 = private constant [0 x { ptr, i64 }] zeroinitializer
@str.242 = private unnamed_addr constant [3 x i8] c": \00", align 1
@str.243 = private unnamed_addr constant [2 x i8] c"[\00", align 1
@str.244 = private unnamed_addr constant [2 x i8] c"]\00", align 1
@str.245 = private unnamed_addr constant [3 x i8] c", \00", align 1
@str.246 = private unnamed_addr constant [2 x i8] c"[\00", align 1
@str.247 = private unnamed_addr constant [2 x i8] c"]\00", align 1
@str.248 = private unnamed_addr constant [3 x i8] c", \00", align 1
@str.249 = private unnamed_addr constant [2 x i8] c"[\00", align 1
@str.250 = private unnamed_addr constant [2 x i8] c"]\00", align 1
@str.251 = private unnamed_addr constant [3 x i8] c", \00", align 1
@str.252 = private unnamed_addr constant [5 x i8] c"null\00", align 1
@str.253 = private unnamed_addr constant [6 x i8] c"*void\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 [12 x i8] c"*CAllocator\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 [5 x i8] c"*GPA\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 [12 x i8] c"*ArenaChunk\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 [7 x i8] c"*Arena\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 [6 x i8] c"[*]u8\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 [10 x i8] c"*BufAlloc\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 [19 x i8] c"*TrackingAllocator\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"*Widget\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 [13 x i8] c"**CAllocator\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 [5 x i8] c"*s64\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 [7 x i8] c"**void\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"*string\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 [5 x i8] c"*Any\00", align 1
@str.293 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1
@str.294 = private unnamed_addr constant [5 x i8] c"null\00", align 1
@str.295 = private unnamed_addr constant [7 x i8] c"*[]Any\00", align 1
@str.296 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1
@str.297 = private unnamed_addr constant [5 x i8] c"null\00", align 1
@str.298 = private unnamed_addr constant [4 x i8] c"*u8\00", align 1
@str.299 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1
@str.300 = private unnamed_addr constant [5 x i8] c"null\00", align 1
@str.301 = private unnamed_addr constant [6 x i8] c"*bool\00", align 1
@str.302 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1
@str.303 = private unnamed_addr constant [5 x i8] c"null\00", align 1
@str.304 = private unnamed_addr constant [14 x i8] c"*ProposedSize\00", align 1
@str.305 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1
@str.306 = private unnamed_addr constant [5 x i8] c"null\00", align 1
@str.307 = private unnamed_addr constant [5 x i8] c"*f32\00", align 1
@str.308 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1
@str.309 = private unnamed_addr constant [5 x i8] c"null\00", align 1
@str.310 = private unnamed_addr constant [5 x i8] c"*f64\00", align 1
@str.311 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1
@str.312 = private unnamed_addr constant [5 x i8] c"null\00", align 1
@str.313 = private unnamed_addr constant [8 x i8] c"*[1]Any\00", align 1
@str.314 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1
@str.315 = private unnamed_addr constant [5 x i8] c"null\00", align 1
@str.316 = private unnamed_addr constant [9 x i8] c"*Sizable\00", align 1
@str.317 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1
@str.318 = private unnamed_addr constant [5 x i8] c"null\00", align 1
@str.319 = private unnamed_addr constant [9 x i8] c"**Widget\00", align 1
@str.320 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1
@str.321 = private unnamed_addr constant [5 x i8] c"null\00", align 1
@str.322 = private unnamed_addr constant [19 x i8] c"*__Sizable__Vtable\00", align 1
@str.323 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1
@str.324 = private unnamed_addr constant [5 x i8] c"null\00", align 1
; Function Attrs: nounwind
declare void @out(ptr) #0
declare ptr @malloc(i64)
declare void @free(ptr)
declare ptr @memcpy(ptr, ptr, i64)
declare ptr @memset(ptr, i32, i64)
; Function Attrs: nounwind
define internal ptr @CAllocator.alloc(ptr %0, ptr %1, i64 %2) #0 {
entry:
%alloca = alloca ptr, align 8
store ptr %1, ptr %alloca, align 8
%allocaN = alloca i64, align 8
store i64 %2, ptr %allocaN, align 8
%load = load i64, ptr %allocaN, align 8
%call = call ptr @malloc(i64 %load)
ret ptr %call
}
; Function Attrs: nounwind
define internal void @CAllocator.dealloc(ptr %0, ptr %1, ptr %2) #0 {
entry:
%alloca = alloca ptr, align 8
store ptr %1, ptr %alloca, align 8
%allocaN = alloca ptr, align 8
store ptr %2, ptr %allocaN, align 8
%load = load ptr, ptr %allocaN, align 8
call void @free(ptr %load)
ret void
}
; Function Attrs: nounwind
declare i64 @GPA.init(ptr) #0
; Function Attrs: nounwind
declare ptr @GPA.alloc(ptr, ptr, i64) #0
; Function Attrs: nounwind
declare void @GPA.dealloc(ptr, ptr, ptr) #0
; Function Attrs: nounwind
declare void @Arena.add_chunk(ptr, ptr, i64) #0
; Function Attrs: nounwind
declare void @Arena.init(ptr sret({ ptr, i64, { ptr, ptr, ptr } }), ptr, ptr, i64) #0
; Function Attrs: nounwind
declare void @Arena.reset(ptr, ptr) #0
; Function Attrs: nounwind
declare void @Arena.deinit(ptr, ptr) #0
; Function Attrs: nounwind
declare ptr @Arena.alloc(ptr, ptr, i64) #0
; Function Attrs: nounwind
declare void @Arena.dealloc(ptr, ptr, ptr) #0
; Function Attrs: nounwind
declare ptr @BufAlloc.init(ptr, ptr, i64) #0
; Function Attrs: nounwind
declare void @BufAlloc.reset(ptr, ptr) #0
; Function Attrs: nounwind
declare ptr @BufAlloc.alloc(ptr, ptr, i64) #0
; Function Attrs: nounwind
declare void @BufAlloc.dealloc(ptr, ptr, ptr) #0
; Function Attrs: nounwind
declare void @TrackingAllocator.init(ptr sret({ { ptr, ptr, ptr }, i64, i64, i64 }), ptr, ptr) #0
; Function Attrs: nounwind
declare i64 @TrackingAllocator.leak_count(ptr, ptr) #0
; Function Attrs: nounwind
declare void @TrackingAllocator.report(ptr, ptr) #0
; Function Attrs: nounwind
declare ptr @TrackingAllocator.alloc(ptr, ptr, i64) #0
; Function Attrs: nounwind
declare void @TrackingAllocator.dealloc(ptr, ptr, ptr) #0
; Function Attrs: nounwind
define internal { ptr, i64 } @cstring(ptr %0, i64 %1) #0 {
entry:
%alloca = alloca i64, align 8
store i64 %1, ptr %alloca, align 8
%load = load i64, ptr %alloca, align 8
%add = add i64 %load, 1
%loadN = load { { ptr, ptr, ptr }, ptr }, ptr %0, align 8
%sg = extractvalue { { ptr, ptr, ptr }, ptr } %loadN, 0
%sgN = extractvalue { ptr, ptr, ptr } %sg, 0
%sgN = extractvalue { ptr, ptr, ptr } %sg, 1
%icall = call ptr %sgN(ptr %0, ptr %sgN, i64 %add)
%allocaN = alloca ptr, align 8
store ptr %icall, ptr %allocaN, align 8
%loadN = load ptr, ptr %allocaN, align 8
%loadN = load i64, ptr %alloca, align 8
%addN = add i64 %loadN, 1
%2 = call ptr @memset(ptr %loadN, i32 0, i64 %addN)
%allocaN = alloca { ptr, i64 }, align 8
store { ptr, i64 } undef, ptr %allocaN, align 8
%loadN = load ptr, ptr %allocaN, align 8
%gep = getelementptr inbounds { ptr, i64 }, ptr %allocaN, i32 0, i32 0
%pti = ptrtoint ptr %loadN to i64
store i64 %pti, ptr %gep, align 8
%loadN = load i64, ptr %alloca, align 8
%gepN = getelementptr inbounds { ptr, i64 }, ptr %allocaN, i32 0, i32 1
store i64 %loadN, ptr %gepN, align 8
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
ret { ptr, i64 } %loadN
}
; Function Attrs: nounwind
define internal { ptr, i64 } @int_to_string(ptr %0, i64 %1) #0 {
entry:
%alloca = alloca i64, align 8
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.14, label %if.merge.15
if.then.14: ; preds = %entry
ret { ptr, i64 } { ptr @str, i64 1 }
if.merge.15: ; preds = %entry
%loadN = load i64, ptr %alloca, align 8
%icmpN = icmp slt i64 %loadN, 0
%allocaN = alloca i1, align 1
store i1 %icmpN, ptr %allocaN, align 1
%loadN = load i1, ptr %allocaN, align 1
br i1 %loadN, label %if.then.16, label %if.else.17
if.then.16: ; preds = %if.merge.15
%loadN = load i64, ptr %alloca, align 8
%sub = sub i64 0, %loadN
br label %if.merge.18
if.else.17: ; preds = %if.merge.15
%loadN = load i64, ptr %alloca, align 8
br label %if.merge.18
if.merge.18: ; preds = %if.else.17, %if.then.16
%bp = phi i64 [ %sub, %if.then.16 ], [ %loadN, %if.else.17 ]
%allocaN = alloca i64, align 8
store i64 %bp, ptr %allocaN, align 8
%call = call { ptr, i64 } @cstring(ptr %0, i64 20)
%allocaN = alloca { ptr, i64 }, align 8
store { ptr, i64 } %call, ptr %allocaN, align 8
%allocaN = alloca i64, align 8
store i64 19, ptr %allocaN, align 8
br label %while.hdr.19
while.hdr.19: ; preds = %while.body.20, %if.merge.18
%loadN = load i64, ptr %allocaN, align 8
%icmpN = icmp sgt i64 %loadN, 0
br i1 %icmpN, label %while.body.20, label %while.exit.21
while.body.20: ; preds = %while.hdr.19
%loadN = load i64, ptr %allocaN, align 8
%srem = srem i64 %loadN, 10
%add = add i64 %srem, 48
%loadN = load i64, ptr %allocaN, align 8
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%igp.data = extractvalue { ptr, i64 } %loadN, 0
%igp.ptr = getelementptr i8, ptr %igp.data, i64 %loadN
%trunc = trunc i64 %add to i8
store i8 %trunc, ptr %igp.ptr, align 1
%loadN = load i64, ptr %allocaN, align 8
%sdiv = sdiv i64 %loadN, 10
store i64 %sdiv, ptr %allocaN, align 8
%loadN = load i64, ptr %allocaN, align 8
%subN = sub i64 %loadN, 1
store i64 %subN, ptr %allocaN, align 8
br label %while.hdr.19
while.exit.21: ; preds = %while.hdr.19
%loadN = load i1, ptr %allocaN, align 1
br i1 %loadN, label %if.then.22, label %if.merge.23
if.then.22: ; preds = %while.exit.21
%loadN = load i64, ptr %allocaN, align 8
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%igp.data21 = extractvalue { ptr, i64 } %loadN, 0
%igp.ptr22 = getelementptr i8, ptr %igp.data21, i64 %loadN
store i8 45, ptr %igp.ptr22, align 1
%loadN = load i64, ptr %allocaN, align 8
%subN = sub i64 %loadN, 1
store i64 %subN, ptr %allocaN, align 8
br label %if.merge.23
if.merge.23: ; preds = %if.then.22, %while.exit.21
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%loadN = load i64, ptr %allocaN, align 8
%addN = add i64 %loadN, 1
%loadN = load i64, ptr %allocaN, align 8
%subN = sub i64 20, %loadN
%subN = sub i64 %subN, 1
%callN = call { ptr, i64 } @substr(ptr %0, { ptr, i64 } %loadN, i64 %addN, i64 %subN)
ret { ptr, i64 } %callN
}
; Function Attrs: nounwind
define internal { ptr, i64 } @bool_to_string(ptr %0, i1 %1) #0 {
entry:
%alloca = alloca i1, align 1
store i1 %1, ptr %alloca, align 1
%load = load i1, ptr %alloca, align 1
br i1 %load, label %if.then.66, label %if.else.67
if.then.66: ; preds = %entry
br label %if.merge.68
if.else.67: ; preds = %entry
br label %if.merge.68
if.merge.68: ; preds = %if.else.67, %if.then.66
%bp = phi { ptr, i64 } [ { ptr @str.1, i64 4 }, %if.then.66 ], [ { ptr @str.2, i64 5 }, %if.else.67 ]
ret { ptr, i64 } %bp
}
; Function Attrs: nounwind
define internal { ptr, i64 } @float_to_string(ptr %0, double %1) #0 {
entry:
%alloca = alloca double, align 8
store double %1, ptr %alloca, align 8
%load = load double, ptr %alloca, align 8
%fcmp = fcmp olt double %load, 0.000000e+00
%allocaN = alloca i1, align 1
store i1 %fcmp, ptr %allocaN, align 1
%loadN = load i1, ptr %allocaN, align 1
br i1 %loadN, label %if.then.72, label %if.else.73
if.then.72: ; preds = %entry
%loadN = load double, ptr %alloca, align 8
%fsub = fsub double 0.000000e+00, %loadN
br label %if.merge.74
if.else.73: ; preds = %entry
%loadN = load double, ptr %alloca, align 8
br label %if.merge.74
if.merge.74: ; preds = %if.else.73, %if.then.72
%bp = phi double [ %fsub, %if.then.72 ], [ %loadN, %if.else.73 ]
%allocaN = alloca double, align 8
store double %bp, ptr %allocaN, align 8
%loadN = load double, ptr %allocaN, align 8
%fptosi = fptosi double %loadN to i64
%allocaN = alloca i64, align 8
store i64 %fptosi, ptr %allocaN, align 8
%loadN = load double, ptr %allocaN, align 8
%loadN = load i64, ptr %allocaN, align 8
%sitofp = sitofp i64 %loadN to double
%fsubN = fsub double %loadN, %sitofp
%fmul = fmul double %fsubN, 1.000000e+06
%fptosiN = fptosi double %fmul to i64
%allocaN = alloca i64, align 8
store i64 %fptosiN, ptr %allocaN, align 8
%loadN = load i64, ptr %allocaN, align 8
%icmp = icmp slt i64 %loadN, 0
br i1 %icmp, label %if.then.75, label %if.merge.76
if.then.75: ; preds = %if.merge.74
%loadN = load i64, ptr %allocaN, align 8
%sub = sub i64 0, %loadN
store i64 %sub, ptr %allocaN, align 8
br label %if.merge.76
if.merge.76: ; preds = %if.then.75, %if.merge.74
%loadN = load i64, ptr %allocaN, align 8
%call = call { ptr, i64 } @int_to_string(ptr %0, i64 %loadN)
%allocaN = alloca { ptr, i64 }, align 8
store { ptr, i64 } %call, ptr %allocaN, align 8
%loadN = load i64, ptr %allocaN, align 8
%callN = call { ptr, i64 } @int_to_string(ptr %0, i64 %loadN)
%allocaN = alloca { ptr, i64 }, align 8
store { ptr, i64 } %callN, ptr %allocaN, align 8
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%len = extractvalue { ptr, i64 } %loadN, 1
%allocaN = alloca i64, align 8
store i64 %len, ptr %allocaN, align 8
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%lenN = extractvalue { ptr, i64 } %loadN, 1
%allocaN = alloca i64, align 8
store i64 %lenN, ptr %allocaN, align 8
%loadN = load i1, ptr %allocaN, align 1
br i1 %loadN, label %if.then.77, label %if.else.78
if.then.77: ; preds = %if.merge.76
br label %if.merge.79
if.else.78: ; preds = %if.merge.76
br label %if.merge.79
if.merge.79: ; preds = %if.else.78, %if.then.77
%bpN = phi i64 [ 1, %if.then.77 ], [ 0, %if.else.78 ]
%allocaN = alloca i64, align 8
store i64 %bpN, ptr %allocaN, align 8
%loadN = load i64, ptr %allocaN, align 8
%loadN = load i64, ptr %allocaN, align 8
%add = add i64 %loadN, %loadN
%addN = add i64 %add, 1
%addN = add i64 %addN, 6
%allocaN = alloca i64, align 8
store i64 %addN, ptr %allocaN, align 8
%loadN = load i64, ptr %allocaN, align 8
%callN = call { ptr, i64 } @cstring(ptr %0, i64 %loadN)
%allocaN = alloca { ptr, i64 }, align 8
store { ptr, i64 } %callN, ptr %allocaN, align 8
%allocaN = alloca i64, align 8
store i64 0, ptr %allocaN, align 8
%loadN = load i1, ptr %allocaN, align 1
br i1 %loadN, label %if.then.80, label %if.merge.81
if.then.80: ; preds = %if.merge.79
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%igp.data = extractvalue { ptr, i64 } %loadN, 0
%igp.ptr = getelementptr i8, ptr %igp.data, i64 0
store i8 45, ptr %igp.ptr, align 1
store i64 1, ptr %allocaN, align 8
br label %if.merge.81
if.merge.81: ; preds = %if.then.80, %if.merge.79
%loadN = load i64, ptr %allocaN, align 8
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%igp.data41 = extractvalue { ptr, i64 } %loadN, 0
%igp.ptr42 = getelementptr i8, ptr %igp.data41, i64 %loadN
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%dptr = extractvalue { ptr, i64 } %loadN, 0
%loadN = load i64, ptr %allocaN, align 8
%callN = call ptr @memcpy(ptr %igp.ptr42, ptr %dptr, i64 %loadN)
%loadN = load i64, ptr %allocaN, align 8
%loadN = load i64, ptr %allocaN, align 8
%addN = add i64 %loadN, %loadN
store i64 %addN, ptr %allocaN, align 8
%loadN = load i64, ptr %allocaN, align 8
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%igp.data51 = extractvalue { ptr, i64 } %loadN, 0
%igp.ptr52 = getelementptr i8, ptr %igp.data51, i64 %loadN
store i8 46, ptr %igp.ptr52, align 1
%loadN = load i64, ptr %allocaN, align 8
%addN = add i64 %loadN, 1
store i64 %addN, ptr %allocaN, align 8
%loadN = load i64, ptr %allocaN, align 8
%subN = sub i64 6, %loadN
%allocaN = alloca i64, align 8
store i64 %subN, ptr %allocaN, align 8
%loadN = load i64, ptr %allocaN, align 8
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%igp.data60 = extractvalue { ptr, i64 } %loadN, 0
%igp.ptr61 = getelementptr i8, ptr %igp.data60, i64 %loadN
%loadN = load i64, ptr %allocaN, align 8
%2 = call ptr @memset(ptr %igp.ptr61, i32 48, i64 %loadN)
%loadN = load i64, ptr %allocaN, align 8
%loadN = load i64, ptr %allocaN, align 8
%addN = add i64 %loadN, %loadN
store i64 %addN, ptr %allocaN, align 8
%loadN = load i64, ptr %allocaN, align 8
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%igp.data68 = extractvalue { ptr, i64 } %loadN, 0
%igp.ptr69 = getelementptr i8, ptr %igp.data68, i64 %loadN
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%dptrN = extractvalue { ptr, i64 } %loadN, 0
%loadN = load i64, ptr %allocaN, align 8
%callN = call ptr @memcpy(ptr %igp.ptr69, ptr %dptrN, i64 %loadN)
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
ret { ptr, i64 } %loadN
}
; Function Attrs: nounwind
define internal void @hex_group(ptr %0, { ptr, i64 } %1, i64 %2, i64 %3) #0 {
entry:
%alloca = alloca { ptr, i64 }, align 8
store { ptr, i64 } %1, ptr %alloca, align 8
%allocaN = alloca i64, align 8
store i64 %2, ptr %allocaN, align 8
%allocaN = alloca i64, align 8
store i64 %3, ptr %allocaN, align 8
%load = load i64, ptr %allocaN, align 8
%add = add i64 %load, 3
%allocaN = alloca i64, align 8
store i64 %add, ptr %allocaN, align 8
%loadN = load i64, ptr %allocaN, align 8
%allocaN = alloca i64, align 8
store i64 %loadN, ptr %allocaN, align 8
br label %while.hdr.223
while.hdr.223: ; preds = %if.merge.228, %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.224, label %while.exit.225
while.body.224: ; preds = %while.hdr.223
%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.226, label %if.else.227
while.exit.225: ; preds = %while.hdr.223
ret void
if.then.226: ; preds = %while.body.224
%loadN = load i64, ptr %allocaN, align 8
%addN = add i64 %loadN, 48
br label %if.merge.228
if.else.227: ; preds = %while.body.224
%loadN = load i64, ptr %allocaN, align 8
%sub = sub i64 %loadN, 10
%addN = add i64 %sub, 97
br label %if.merge.228
if.merge.228: ; preds = %if.else.227, %if.then.226
%bp = phi i64 [ %addN, %if.then.226 ], [ %addN, %if.else.227 ]
%loadN = load i64, ptr %allocaN, align 8
%loadN = load { ptr, i64 }, ptr %alloca, align 8
%igp.data = extractvalue { ptr, i64 } %loadN, 0
%igp.ptr = getelementptr i8, ptr %igp.data, i64 %loadN
%trunc = trunc i64 %bp to i8
store i8 %trunc, ptr %igp.ptr, align 1
%loadN = load i64, ptr %allocaN, align 8
%sdiv = sdiv i64 %loadN, 16
store i64 %sdiv, ptr %allocaN, align 8
%loadN = load i64, ptr %allocaN, align 8
%subN = sub i64 %loadN, 1
store i64 %subN, ptr %allocaN, align 8
br label %while.hdr.223
}
; Function Attrs: nounwind
define internal { ptr, i64 } @int_to_hex_string(ptr %0, i64 %1) #0 {
entry:
%alloca = alloca i64, align 8
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.213, label %if.merge.214
if.then.213: ; preds = %entry
ret { ptr, i64 } { ptr @str.3, i64 1 }
if.merge.214: ; 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.215, label %if.merge.216
if.then.215: ; preds = %if.merge.214
%loadN = load i64, ptr %allocaN, align 8
%add = add i64 %loadN, 65536
store i64 %add, ptr %allocaN, align 8
br label %if.merge.216
if.merge.216: ; preds = %if.then.215, %if.merge.214
%loadN = load i64, ptr %alloca, align 8
%loadN = load i64, ptr %allocaN, align 8
%sub = sub i64 %loadN, %loadN
%sdiv = sdiv i64 %sub, 65536
%allocaN = alloca i64, align 8
store i64 %sdiv, ptr %allocaN, align 8
%loadN = load i64, ptr %allocaN, align 8
%sremN = srem i64 %loadN, 65536
%allocaN = alloca i64, align 8
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.217, label %if.merge.218
if.then.217: ; preds = %if.merge.216
%loadN = load i64, ptr %allocaN, align 8
%addN = add i64 %loadN, 65536
store i64 %addN, ptr %allocaN, align 8
br label %if.merge.218
if.merge.218: ; preds = %if.then.217, %if.merge.216
%loadN = load i64, ptr %allocaN, align 8
%loadN = load i64, ptr %allocaN, align 8
%subN = sub i64 %loadN, %loadN
%sdivN = sdiv i64 %subN, 65536
%allocaN = alloca i64, align 8
store i64 %sdivN, ptr %allocaN, align 8
%loadN = load i64, ptr %allocaN, align 8
%sremN = srem i64 %loadN, 65536
%allocaN = alloca i64, align 8
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.219, label %if.merge.220
if.then.219: ; preds = %if.merge.218
%loadN = load i64, ptr %allocaN, align 8
%addN = add i64 %loadN, 65536
store i64 %addN, ptr %allocaN, align 8
br label %if.merge.220
if.merge.220: ; preds = %if.then.219, %if.merge.218
%loadN = load i64, ptr %allocaN, align 8
%loadN = load i64, ptr %allocaN, align 8
%subN = sub i64 %loadN, %loadN
%sdivN = sdiv i64 %subN, 65536
%allocaN = alloca i64, align 8
store i64 %sdivN, ptr %allocaN, align 8
%loadN = load i64, ptr %allocaN, align 8
%sremN = srem i64 %loadN, 65536
%allocaN = alloca i64, align 8
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.221, label %if.merge.222
if.then.221: ; preds = %if.merge.220
%loadN = load i64, ptr %allocaN, align 8
%addN = add i64 %loadN, 65536
store i64 %addN, ptr %allocaN, align 8
br label %if.merge.222
if.merge.222: ; preds = %if.then.221, %if.merge.220
%call = call { ptr, i64 } @cstring(ptr %0, i64 16)
%allocaN = alloca { ptr, i64 }, align 8
store { ptr, i64 } %call, ptr %allocaN, align 8
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%loadN = load i64, ptr %allocaN, align 8
call void @hex_group(ptr %0, { ptr, i64 } %loadN, i64 0, i64 %loadN)
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%loadN = load i64, ptr %allocaN, align 8
call void @hex_group(ptr %0, { ptr, i64 } %loadN, i64 4, i64 %loadN)
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%loadN = load i64, ptr %allocaN, align 8
call void @hex_group(ptr %0, { ptr, i64 } %loadN, i64 8, i64 %loadN)
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%loadN = load i64, ptr %allocaN, align 8
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.229
while.hdr.229: ; preds = %if.merge.233, %if.merge.222
%loadN = load i64, ptr %allocaN, align 8
%icmpN = icmp slt i64 %loadN, 15
br i1 %icmpN, label %while.body.230, label %while.exit.231
while.body.230: ; preds = %while.hdr.229
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%loadN = load i64, ptr %allocaN, align 8
%ig.data = extractvalue { ptr, i64 } %loadN, 0
%ig.ptr = getelementptr i8, ptr %ig.data, i64 %loadN
%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.232, label %if.merge.233
while.exit.231: ; preds = %if.then.232, %while.hdr.229
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%loadN = load i64, ptr %allocaN, align 8
%loadN = load i64, ptr %allocaN, align 8
%subN = sub i64 16, %loadN
%callN = call { ptr, i64 } @substr(ptr %0, { ptr, i64 } %loadN, i64 %loadN, i64 %subN)
ret { ptr, i64 } %callN
if.then.232: ; preds = %while.body.230
br label %while.exit.231
if.merge.233: ; preds = %while.body.230
%loadN = load i64, ptr %allocaN, align 8
%addN = add i64 %loadN, 1
store i64 %addN, ptr %allocaN, align 8
br label %while.hdr.229
}
; Function Attrs: nounwind
define internal { ptr, i64 } @concat(ptr %0, { ptr, i64 } %1, { ptr, i64 } %2) #0 {
entry:
%alloca = alloca { ptr, i64 }, align 8
store { ptr, i64 } %1, ptr %alloca, align 8
%allocaN = alloca { ptr, i64 }, align 8
store { ptr, i64 } %2, ptr %allocaN, align 8
%load = load { ptr, i64 }, ptr %alloca, align 8
%len = extractvalue { ptr, i64 } %load, 1
%allocaN = alloca i64, align 8
store i64 %len, ptr %allocaN, align 8
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%lenN = extractvalue { ptr, i64 } %loadN, 1
%allocaN = alloca i64, align 8
store i64 %lenN, ptr %allocaN, align 8
%loadN = load i64, ptr %allocaN, align 8
%loadN = load i64, ptr %allocaN, align 8
%add = add i64 %loadN, %loadN
%call = call { ptr, i64 } @cstring(ptr %0, i64 %add)
%allocaN = alloca { ptr, i64 }, align 8
store { ptr, i64 } %call, ptr %allocaN, align 8
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%dptr = extractvalue { ptr, i64 } %loadN, 0
%loadN = load { ptr, i64 }, ptr %alloca, align 8
%dptrN = extractvalue { ptr, i64 } %loadN, 0
%loadN = load i64, ptr %allocaN, align 8
%callN = call ptr @memcpy(ptr %dptr, ptr %dptrN, i64 %loadN)
%loadN = load i64, ptr %allocaN, align 8
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%igp.data = extractvalue { ptr, i64 } %loadN, 0
%igp.ptr = getelementptr i8, ptr %igp.data, i64 %loadN
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%dptrN = extractvalue { ptr, i64 } %loadN, 0
%loadN = load i64, ptr %allocaN, align 8
%callN = call ptr @memcpy(ptr %igp.ptr, ptr %dptrN, i64 %loadN)
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
ret { ptr, i64 } %loadN
}
; Function Attrs: nounwind
define internal { ptr, i64 } @substr(ptr %0, { ptr, i64 } %1, i64 %2, i64 %3) #0 {
entry:
%alloca = alloca { ptr, i64 }, align 8
store { ptr, i64 } %1, ptr %alloca, align 8
%allocaN = alloca i64, align 8
store i64 %2, ptr %allocaN, align 8
%allocaN = alloca i64, align 8
store i64 %3, ptr %allocaN, align 8
%load = load i64, ptr %allocaN, align 8
%call = call { ptr, i64 } @cstring(ptr %0, i64 %load)
%allocaN = alloca { ptr, i64 }, align 8
store { ptr, i64 } %call, ptr %allocaN, align 8
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%dptr = extractvalue { ptr, i64 } %loadN, 0
%loadN = load i64, ptr %allocaN, align 8
%loadN = load { ptr, i64 }, ptr %alloca, align 8
%igp.data = extractvalue { ptr, i64 } %loadN, 0
%igp.ptr = getelementptr i8, ptr %igp.data, i64 %loadN
%loadN = load i64, ptr %allocaN, align 8
%callN = call ptr @memcpy(ptr %dptr, ptr %igp.ptr, i64 %loadN)
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
ret { ptr, i64 } %loadN
}
; Function Attrs: nounwind
declare ptr @xml_escape(ptr, ptr) #0
; Function Attrs: nounwind
declare ptr @path_join(ptr, ptr) #0
; Function Attrs: nounwind
define internal { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %1) #0 {
entry:
%alloca = alloca { i64, i64 }, align 8
store { i64, i64 } %1, ptr %alloca, align 8
%allocaN = alloca { ptr, i64 }, align 8
store { ptr, i64 } { ptr @str.4, i64 3 }, ptr %allocaN, align 8
%load = load { i64, i64 }, ptr %alloca, align 8
%sg = extractvalue { i64, i64 } %load, 0
%ba.val = insertvalue { i64, i64 } { i64 13, i64 undef }, i64 %sg, 1
%allocaN = alloca { i64, i64 }, align 8
store { i64, i64 } %ba.val, ptr %allocaN, align 8
%loadN = load { i64, i64 }, ptr %allocaN, align 8
%ua.raw = extractvalue { i64, i64 } %loadN, 1
switch i64 %ua.raw, label %match.unr.65 [
i64 17, label %match.arm.51
i64 2, label %match.arm.52
i64 3, label %match.arm.52
i64 4, label %match.arm.52
i64 5, label %match.arm.52
i64 6, label %match.arm.52
i64 7, label %match.arm.52
i64 8, label %match.arm.52
i64 9, label %match.arm.52
i64 16, label %match.arm.52
i64 15, label %match.arm.52
i64 12, label %match.arm.53
i64 1, label %match.arm.54
i64 10, label %match.arm.55
i64 11, label %match.arm.55
i64 19, label %match.arm.56
i64 20, label %match.arm.56
i64 21, label %match.arm.56
i64 23, label %match.arm.56
i64 25, label %match.arm.56
i64 27, label %match.arm.56
i64 30, label %match.arm.56
i64 32, label %match.arm.56
i64 34, label %match.arm.56
i64 37, label %match.arm.56
i64 38, label %match.arm.56
i64 39, label %match.arm.56
i64 40, label %match.arm.56
i64 54, label %match.arm.60
i64 35, label %match.arm.61
i64 46, label %match.arm.61
i64 18, label %match.arm.62
i64 22, label %match.arm.62
i64 24, label %match.arm.62
i64 26, label %match.arm.62
i64 28, label %match.arm.62
i64 29, label %match.arm.62
i64 31, label %match.arm.62
i64 33, label %match.arm.62
i64 41, label %match.arm.62
i64 42, label %match.arm.62
i64 43, label %match.arm.62
i64 44, label %match.arm.62
i64 45, label %match.arm.62
i64 47, label %match.arm.62
i64 48, label %match.arm.62
i64 49, label %match.arm.62
i64 50, label %match.arm.62
i64 51, label %match.arm.62
i64 52, label %match.arm.62
i64 53, label %match.arm.62
i64 55, label %match.arm.62
i64 56, label %match.arm.62
i64 57, label %match.arm.62
i64 58, label %match.arm.62
i64 36, label %match.arm.63
i64 13, label %match.arm.64
]
match.merge.50: ; preds = %dispatch.merge.303, %dispatch.merge.184, %dispatch.merge.170, %dispatch.merge.162, %dispatch.merge.82, %float.merge.71, %match.unr.65, %match.arm.64, %match.arm.54, %match.arm.53, %match.arm.52, %match.arm.51
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
ret { ptr, i64 } %loadN
match.arm.51: ; preds = %entry
store { ptr, i64 } { ptr @str.5, i64 0 }, ptr %allocaN, align 8
br label %match.merge.50
match.arm.52: ; preds = %entry, %entry, %entry, %entry, %entry, %entry, %entry, %entry, %entry, %entry
%loadN = load { i64, i64 }, ptr %alloca, align 8
%ua.raw6 = extractvalue { i64, i64 } %loadN, 1
%call = call { ptr, i64 } @int_to_string(ptr %0, i64 %ua.raw6)
store { ptr, i64 } %call, ptr %allocaN, align 8
br label %match.merge.50
match.arm.53: ; preds = %entry
%allocaN = alloca { ptr, i64 }, align 8
%loadN = load { i64, i64 }, ptr %alloca, align 8
%ua.raw9 = extractvalue { i64, i64 } %loadN, 1
%ua.ptr = inttoptr i64 %ua.raw9 to ptr
%ua.load = load { ptr, i64 }, ptr %ua.ptr, align 8
store { ptr, i64 } %ua.load, ptr %allocaN, align 8
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
store { ptr, i64 } %loadN, ptr %allocaN, align 8
br label %match.merge.50
match.arm.54: ; preds = %entry
%loadN = load { i64, i64 }, ptr %alloca, align 8
%ua.raw12 = extractvalue { i64, i64 } %loadN, 1
%tr = trunc i64 %ua.raw12 to i1
%callN = call { ptr, i64 } @bool_to_string(ptr %0, i1 %tr)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %match.merge.50
match.arm.55: ; preds = %entry, %entry
%loadN = load { i64, i64 }, ptr %alloca, align 8
%allocaN = alloca double, align 8
%sgN = extractvalue { i64, i64 } %loadN, 0
%icmp = icmp eq i64 %sgN, 10
br i1 %icmp, label %fN.unbox.69, label %fN.unbox.70
match.arm.56: ; preds = %entry, %entry, %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
%allocaN = alloca { ptr, i64 }, align 8
switch i64 %ua.raw18, label %dispatch.default.83 [
i64 19, label %dispatch.case.84
i64 20, label %dispatch.case.85
i64 21, label %dispatch.case.86
i64 23, label %dispatch.case.87
i64 25, label %dispatch.case.88
i64 27, label %dispatch.case.89
i64 30, label %dispatch.case.90
i64 32, label %dispatch.case.91
i64 34, label %dispatch.case.92
i64 37, label %dispatch.case.93
i64 38, label %dispatch.case.94
i64 39, label %dispatch.case.95
i64 40, label %dispatch.case.96
]
match.arm.57: ; No predecessors!
unreachable
match.arm.58: ; No predecessors!
unreachable
match.arm.59: ; No predecessors!
unreachable
match.arm.60: ; preds = %entry
%loadN = load { i64, i64 }, ptr %allocaN, align 8
%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.163 [
i64 54, label %dispatch.case.164
]
match.arm.61: ; preds = %entry, %entry
%loadN = load { i64, i64 }, ptr %allocaN, align 8
%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.171 [
i64 35, label %dispatch.case.172
i64 46, label %dispatch.case.173
]
match.arm.62: ; preds = %entry, %entry, %entry, %entry, %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.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.185 [
i64 18, label %dispatch.case.186
i64 22, label %dispatch.case.187
i64 24, label %dispatch.case.188
i64 26, label %dispatch.case.189
i64 28, label %dispatch.case.190
i64 29, label %dispatch.case.191
i64 31, label %dispatch.case.192
i64 33, label %dispatch.case.193
i64 41, label %dispatch.case.194
i64 42, label %dispatch.case.195
i64 43, label %dispatch.case.196
i64 44, label %dispatch.case.197
i64 45, label %dispatch.case.198
i64 47, label %dispatch.case.199
i64 48, label %dispatch.case.200
i64 49, label %dispatch.case.201
i64 50, label %dispatch.case.202
i64 51, label %dispatch.case.203
i64 52, label %dispatch.case.204
i64 53, label %dispatch.case.205
i64 55, label %dispatch.case.206
i64 56, label %dispatch.case.207
i64 57, label %dispatch.case.208
i64 58, label %dispatch.case.209
]
match.arm.63: ; preds = %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.304 [
i64 36, label %dispatch.case.305
]
match.arm.64: ; preds = %entry
%loadN = load { i64, i64 }, ptr %alloca, align 8
%tn.tid = extractvalue { i64, i64 } %loadN, 1
%tn.gep = getelementptr inbounds [85 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.50
match.unr.65: ; preds = %entry
br label %match.merge.50
f32.unbox.69: ; preds = %match.arm.55
%ua.raw38 = extractvalue { i64, i64 } %loadN, 1
%trN = trunc i64 %ua.raw38 to i32
%iNf = bitcast i32 %trN to float
%fpext = fpext float %iNf to double
store double %fpext, ptr %allocaN, align 8
br label %float.merge.71
f64.unbox.70: ; preds = %match.arm.55
%ua.raw39 = extractvalue { i64, i64 } %loadN, 1
%iNd = bitcast i64 %ua.raw39 to double
store double %iNd, ptr %allocaN, align 8
br label %float.merge.71
float.merge.71: ; preds = %fN.unbox.70, %fN.unbox.69
%loadN = load double, ptr %allocaN, align 8
%callN = call { ptr, i64 } @float_to_string(ptr %0, double %loadN)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %match.merge.50
dispatch.merge.82: ; preds = %dispatch.case.96, %dispatch.case.95, %dispatch.case.94, %dispatch.case.93, %dispatch.case.92, %dispatch.case.91, %dispatch.case.90, %dispatch.case.89, %dispatch.case.88, %dispatch.case.87, %dispatch.case.86, %dispatch.case.85, %dispatch.case.84, %dispatch.default.83
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
store { ptr, i64 } %loadN, ptr %allocaN, align 8
br label %match.merge.50
dispatch.default.83: ; preds = %match.arm.56
store { ptr, i64 } { ptr @str.90, i64 0 }, ptr %allocaN, align 8
br label %dispatch.merge.82
dispatch.case.84: ; preds = %match.arm.56
%ua.raw43 = extractvalue { i64, i64 } %loadN, 1
%ua.ptr44 = inttoptr i64 %ua.raw43 to ptr
%ua.load45 = load { { ptr, i64 }, i32, i32, { ptr, i64 } }, ptr %ua.ptr44, align 8
%callN = call { ptr, i64 } @struct_to_string__Source_Location(ptr %0, { { ptr, i64 }, i32, i32, { ptr, i64 } } %ua.load45)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %dispatch.merge.82
dispatch.case.85: ; preds = %match.arm.56
%ua.raw47 = extractvalue { i64, i64 } %loadN, 1
%ua.ptr48 = inttoptr i64 %ua.raw47 to ptr
%ua.load49 = load { ptr, ptr, ptr }, ptr %ua.ptr48, align 8
%callN = call { ptr, i64 } @struct_to_string__Allocator(ptr %0, { ptr, ptr, ptr } %ua.load49)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %dispatch.merge.82
dispatch.case.86: ; preds = %match.arm.56
%ua.raw51 = extractvalue { i64, i64 } %loadN, 1
%ua.ptr52 = inttoptr i64 %ua.raw51 to ptr
%ua.load53 = load {}, ptr %ua.ptr52, align 1
%callN = call { ptr, i64 } @struct_to_string__CAllocator(ptr %0, {} %ua.load53)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %dispatch.merge.82
dispatch.case.87: ; preds = %match.arm.56
%ua.raw55 = extractvalue { i64, i64 } %loadN, 1
%ua.ptr56 = inttoptr i64 %ua.raw55 to ptr
%ua.load57 = load { i64 }, ptr %ua.ptr56, align 8
%callN = call { ptr, i64 } @struct_to_string__GPA(ptr %0, { i64 } %ua.load57)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %dispatch.merge.82
dispatch.case.88: ; preds = %match.arm.56
%ua.raw59 = extractvalue { i64, i64 } %loadN, 1
%ua.ptr60 = inttoptr i64 %ua.raw59 to ptr
%ua.load61 = load { ptr, i64 }, ptr %ua.ptr60, align 8
%callN = call { ptr, i64 } @struct_to_string__ArenaChunk(ptr %0, { ptr, i64 } %ua.load61)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %dispatch.merge.82
dispatch.case.89: ; preds = %match.arm.56
%ua.raw63 = extractvalue { i64, i64 } %loadN, 1
%ua.ptr64 = inttoptr i64 %ua.raw63 to ptr
%ua.load65 = load { ptr, i64, { ptr, ptr, ptr } }, ptr %ua.ptr64, align 8
%callN = call { ptr, i64 } @struct_to_string__Arena(ptr %0, { ptr, i64, { ptr, ptr, ptr } } %ua.load65)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %dispatch.merge.82
dispatch.case.90: ; preds = %match.arm.56
%ua.raw67 = extractvalue { i64, i64 } %loadN, 1
%ua.ptr68 = inttoptr i64 %ua.raw67 to ptr
%ua.load69 = load { ptr, i64, i64 }, ptr %ua.ptr68, align 8
%callN = call { ptr, i64 } @struct_to_string__BufAlloc(ptr %0, { ptr, i64, i64 } %ua.load69)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %dispatch.merge.82
dispatch.case.91: ; preds = %match.arm.56
%ua.raw71 = extractvalue { i64, i64 } %loadN, 1
%ua.ptr72 = inttoptr i64 %ua.raw71 to ptr
%ua.load73 = load { { ptr, ptr, ptr }, i64, i64, i64 }, ptr %ua.ptr72, align 8
%callN = call { ptr, i64 } @struct_to_string__TrackingAllocator(ptr %0, { { ptr, ptr, ptr }, i64, i64, i64 } %ua.load73)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %dispatch.merge.82
dispatch.case.92: ; preds = %match.arm.56
%ua.raw75 = extractvalue { i64, i64 } %loadN, 1
%ua.ptr76 = inttoptr i64 %ua.raw75 to ptr
%ua.load77 = load { { ptr, ptr, ptr }, ptr }, ptr %ua.ptr76, align 8
%callN = call { ptr, i64 } @struct_to_string__Context(ptr %0, { { ptr, ptr, ptr }, ptr } %ua.load77)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %dispatch.merge.82
dispatch.case.93: ; preds = %match.arm.56
%ua.raw79 = extractvalue { i64, i64 } %loadN, 1
%ua.ptr80 = inttoptr i64 %ua.raw79 to ptr
%ua.load81 = load { { float, i1 }, { float, i1 } }, ptr %ua.ptr80, align 4
%callN = call { ptr, i64 } @struct_to_string__ProposedSize(ptr %0, { { float, i1 }, { float, i1 } } %ua.load81)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %dispatch.merge.82
dispatch.case.94: ; preds = %match.arm.56
%ua.raw83 = extractvalue { i64, i64 } %loadN, 1
%ua.ptr84 = inttoptr i64 %ua.raw83 to ptr
%ua.load85 = load { ptr, ptr }, ptr %ua.ptr84, align 8
%callN = call { ptr, i64 } @struct_to_string__Sizable(ptr %0, { ptr, ptr } %ua.load85)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %dispatch.merge.82
dispatch.case.95: ; preds = %match.arm.56
%ua.raw87 = extractvalue { i64, i64 } %loadN, 1
%ua.ptr88 = inttoptr i64 %ua.raw87 to ptr
%ua.load89 = load { ptr }, ptr %ua.ptr88, align 8
%callN = call { ptr, i64 } @struct_to_string____Sizable__Vtable(ptr %0, { ptr } %ua.load89)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %dispatch.merge.82
dispatch.case.96: ; preds = %match.arm.56
%ua.raw91 = extractvalue { i64, i64 } %loadN, 1
%ua.ptr92 = inttoptr i64 %ua.raw91 to ptr
%ua.load93 = load {}, ptr %ua.ptr92, align 1
%callN = call { ptr, i64 } @struct_to_string__Widget(ptr %0, {} %ua.load93)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %dispatch.merge.82
dispatch.merge.162: ; preds = %dispatch.case.164, %dispatch.default.163
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
store { ptr, i64 } %loadN, ptr %allocaN, align 8
br label %match.merge.50
dispatch.default.163: ; preds = %match.arm.60
store { ptr, i64 } { ptr @str.91, i64 0 }, ptr %allocaN, align 8
br label %dispatch.merge.162
dispatch.case.164: ; preds = %match.arm.60
%ua.raw96 = extractvalue { i64, i64 } %loadN, 1
%ua.ptr97 = inttoptr i64 %ua.raw96 to ptr
%ua.load98 = load [1 x { i64, i64 }], ptr %ua.ptr97, align 8
%callN = call { ptr, i64 } @array_to_string__AR_1_Any(ptr %0, [1 x { i64, i64 }] %ua.load98)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %dispatch.merge.162
dispatch.merge.170: ; preds = %dispatch.case.173, %dispatch.case.172, %dispatch.default.171
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
store { ptr, i64 } %loadN, ptr %allocaN, align 8
br label %match.merge.50
dispatch.default.171: ; preds = %match.arm.61
store { ptr, i64 } { ptr @str.92, i64 0 }, ptr %allocaN, align 8
br label %dispatch.merge.170
dispatch.case.172: ; preds = %match.arm.61
%ua.raw101 = extractvalue { i64, i64 } %loadN, 1
%ua.ptr102 = inttoptr i64 %ua.raw101 to ptr
%ua.load103 = load { ptr, i64 }, ptr %ua.ptr102, align 8
%callN = call { ptr, i64 } @slice_to_string__string(ptr %0, { ptr, i64 } %ua.load103)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %dispatch.merge.170
dispatch.case.173: ; preds = %match.arm.61
%ua.raw105 = extractvalue { i64, i64 } %loadN, 1
%ua.ptr106 = inttoptr i64 %ua.raw105 to ptr
%ua.load107 = load { ptr, i64 }, ptr %ua.ptr106, align 8
%callN = call { ptr, i64 } @slice_to_string__Any(ptr %0, { ptr, i64 } %ua.load107)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %dispatch.merge.170
dispatch.merge.184: ; preds = %dispatch.case.209, %dispatch.case.208, %dispatch.case.207, %dispatch.case.206, %dispatch.case.205, %dispatch.case.204, %dispatch.case.203, %dispatch.case.202, %dispatch.case.201, %dispatch.case.200, %dispatch.case.199, %dispatch.case.198, %dispatch.case.197, %dispatch.case.196, %dispatch.case.195, %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.default.185
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
store { ptr, i64 } %loadN, ptr %allocaN, align 8
br label %match.merge.50
dispatch.default.185: ; preds = %match.arm.62
store { ptr, i64 } { ptr @str.93, i64 0 }, ptr %allocaN, align 8
br label %dispatch.merge.184
dispatch.case.186: ; preds = %match.arm.62
%ua.raw110 = extractvalue { i64, i64 } %loadN, 1
%iNp = inttoptr i64 %ua.raw110 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.184
dispatch.case.187: ; preds = %match.arm.62
%ua.raw112 = extractvalue { i64, i64 } %loadN, 1
%iNp113 = inttoptr i64 %ua.raw112 to ptr
%callN = call { ptr, i64 } @pointer_to_string__ptr_CAllocator(ptr %0, ptr %iNp113)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %dispatch.merge.184
dispatch.case.188: ; preds = %match.arm.62
%ua.raw115 = extractvalue { i64, i64 } %loadN, 1
%iNp116 = inttoptr i64 %ua.raw115 to ptr
%callN = call { ptr, i64 } @pointer_to_string__ptr_GPA(ptr %0, ptr %iNp116)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %dispatch.merge.184
dispatch.case.189: ; preds = %match.arm.62
%ua.raw118 = extractvalue { i64, i64 } %loadN, 1
%iNp119 = inttoptr i64 %ua.raw118 to ptr
%callN = call { ptr, i64 } @pointer_to_string__ptr_ArenaChunk(ptr %0, ptr %iNp119)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %dispatch.merge.184
dispatch.case.190: ; preds = %match.arm.62
%ua.raw121 = extractvalue { i64, i64 } %loadN, 1
%iNp122 = inttoptr i64 %ua.raw121 to ptr
%callN = call { ptr, i64 } @pointer_to_string__ptr_Arena(ptr %0, ptr %iNp122)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %dispatch.merge.184
dispatch.case.191: ; preds = %match.arm.62
%ua.raw124 = extractvalue { i64, i64 } %loadN, 1
%iNp125 = inttoptr i64 %ua.raw124 to ptr
%callN = call { ptr, i64 } @pointer_to_string__mptr_u8(ptr %0, ptr %iNp125)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %dispatch.merge.184
dispatch.case.192: ; preds = %match.arm.62
%ua.raw127 = extractvalue { i64, i64 } %loadN, 1
%iNp128 = inttoptr i64 %ua.raw127 to ptr
%callN = call { ptr, i64 } @pointer_to_string__ptr_BufAlloc(ptr %0, ptr %iNp128)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %dispatch.merge.184
dispatch.case.193: ; preds = %match.arm.62
%ua.raw130 = extractvalue { i64, i64 } %loadN, 1
%iNp131 = inttoptr i64 %ua.raw130 to ptr
%callN = call { ptr, i64 } @pointer_to_string__ptr_TrackingAllocator(ptr %0, ptr %iNp131)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %dispatch.merge.184
dispatch.case.194: ; preds = %match.arm.62
%ua.raw133 = extractvalue { i64, i64 } %loadN, 1
%iNp134 = inttoptr i64 %ua.raw133 to ptr
%callN = call { ptr, i64 } @pointer_to_string__ptr_Widget(ptr %0, ptr %iNp134)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %dispatch.merge.184
dispatch.case.195: ; preds = %match.arm.62
%ua.raw136 = extractvalue { i64, i64 } %loadN, 1
%iNp137 = inttoptr i64 %ua.raw136 to ptr
%callN = call { ptr, i64 } @pointer_to_string__ptr_ptr_CAllocator(ptr %0, ptr %iNp137)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %dispatch.merge.184
dispatch.case.196: ; preds = %match.arm.62
%ua.raw139 = extractvalue { i64, i64 } %loadN, 1
%iNp140 = inttoptr i64 %ua.raw139 to ptr
%callN = call { ptr, i64 } @pointer_to_string__ptr_s64(ptr %0, ptr %iNp140)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %dispatch.merge.184
dispatch.case.197: ; preds = %match.arm.62
%ua.raw142 = extractvalue { i64, i64 } %loadN, 1
%iNp143 = inttoptr i64 %ua.raw142 to ptr
%callN = call { ptr, i64 } @pointer_to_string__ptr_ptr_void(ptr %0, ptr %iNp143)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %dispatch.merge.184
dispatch.case.198: ; preds = %match.arm.62
%ua.raw145 = extractvalue { i64, i64 } %loadN, 1
%iNp146 = inttoptr i64 %ua.raw145 to ptr
%callN = call { ptr, i64 } @pointer_to_string__ptr_string(ptr %0, ptr %iNp146)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %dispatch.merge.184
dispatch.case.199: ; preds = %match.arm.62
%ua.raw148 = extractvalue { i64, i64 } %loadN, 1
%iNp149 = inttoptr i64 %ua.raw148 to ptr
%callN = call { ptr, i64 } @pointer_to_string__ptr_Any(ptr %0, ptr %iNp149)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %dispatch.merge.184
dispatch.case.200: ; preds = %match.arm.62
%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)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %dispatch.merge.184
dispatch.case.201: ; preds = %match.arm.62
%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)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %dispatch.merge.184
dispatch.case.202: ; preds = %match.arm.62
%ua.raw157 = extractvalue { i64, i64 } %loadN, 1
%iNp158 = inttoptr i64 %ua.raw157 to ptr
%callN = call { ptr, i64 } @pointer_to_string__ptr_bool(ptr %0, ptr %iNp158)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %dispatch.merge.184
dispatch.case.203: ; preds = %match.arm.62
%ua.raw160 = extractvalue { i64, i64 } %loadN, 1
%iNp161 = inttoptr i64 %ua.raw160 to ptr
%callN = call { ptr, i64 } @pointer_to_string__ptr_ProposedSize(ptr %0, ptr %iNp161)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %dispatch.merge.184
dispatch.case.204: ; preds = %match.arm.62
%ua.raw163 = extractvalue { i64, i64 } %loadN, 1
%iNp164 = inttoptr i64 %ua.raw163 to ptr
%callN = call { ptr, i64 } @pointer_to_string__ptr_f32(ptr %0, ptr %iNp164)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %dispatch.merge.184
dispatch.case.205: ; preds = %match.arm.62
%ua.raw166 = extractvalue { i64, i64 } %loadN, 1
%iNp167 = inttoptr i64 %ua.raw166 to ptr
%callN = call { ptr, i64 } @pointer_to_string__ptr_f64(ptr %0, ptr %iNp167)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %dispatch.merge.184
dispatch.case.206: ; preds = %match.arm.62
%ua.raw169 = extractvalue { i64, i64 } %loadN, 1
%iNp170 = inttoptr i64 %ua.raw169 to ptr
%callN = call { ptr, i64 } @pointer_to_string__ptr_AR_1_Any(ptr %0, ptr %iNp170)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %dispatch.merge.184
dispatch.case.207: ; preds = %match.arm.62
%ua.raw172 = extractvalue { i64, i64 } %loadN, 1
%iNp173 = inttoptr i64 %ua.raw172 to ptr
%callN = call { ptr, i64 } @pointer_to_string__ptr_Sizable(ptr %0, ptr %iNp173)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %dispatch.merge.184
dispatch.case.208: ; preds = %match.arm.62
%ua.raw175 = extractvalue { i64, i64 } %loadN, 1
%iNp176 = inttoptr i64 %ua.raw175 to ptr
%callN = call { ptr, i64 } @pointer_to_string__ptr_ptr_Widget(ptr %0, ptr %iNp176)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %dispatch.merge.184
dispatch.case.209: ; preds = %match.arm.62
%ua.raw178 = extractvalue { i64, i64 } %loadN, 1
%iNp179 = inttoptr i64 %ua.raw178 to ptr
%callN = call { ptr, i64 } @pointer_to_string__ptr___Sizable__Vtable(ptr %0, ptr %iNp179)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %dispatch.merge.184
dispatch.merge.303: ; preds = %dispatch.case.305, %dispatch.default.304
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
store { ptr, i64 } %loadN, ptr %allocaN, align 8
br label %match.merge.50
dispatch.default.304: ; preds = %match.arm.63
store { ptr, i64 } { ptr @str.94, i64 0 }, ptr %allocaN, align 8
br label %dispatch.merge.303
dispatch.case.305: ; preds = %match.arm.63
%ua.raw182 = extractvalue { i64, i64 } %loadN, 1
%ua.ptr183 = inttoptr i64 %ua.raw182 to ptr
%ua.load184 = load { float, i1 }, ptr %ua.ptr183, align 4
%callN = call { ptr, i64 } @optional_to_string__opt_f32(ptr %0, { float, i1 } %ua.load184)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %dispatch.merge.303
}
; Function Attrs: nounwind
define internal { ptr, i64 } @build_format(ptr %0, { ptr, i64 } %1) #0 {
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.95, i64 14 }, ptr %allocaN, align 8
%allocaN = alloca i64, align 8
store i64 0, ptr %allocaN, align 8
%allocaN = alloca i64, align 8
store i64 0, ptr %allocaN, align 8
%allocaN = alloca i64, align 8
store i64 0, ptr %allocaN, align 8
br label %while.hdr.0
while.hdr.0: ; preds = %if.merge.5, %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.1, label %while.exit.2
while.body.1: ; preds = %while.hdr.0
%loadN = load { ptr, i64 }, ptr %alloca, align 8
%loadN = load i64, ptr %allocaN, align 8
%ig.data = extractvalue { ptr, i64 } %loadN, 0
%ig.ptr = getelementptr i8, ptr %ig.data, i64 %loadN
%ig.val = load i8, ptr %ig.ptr, align 1
%cmp.ext = zext i8 %ig.val to i64
%icmpN = icmp eq i64 %cmp.ext, 123
br i1 %icmpN, label %if.then.3, label %if.else.4
while.exit.2: ; preds = %while.hdr.0
%loadN = load i64, ptr %allocaN, align 8
%loadN = load { ptr, i64 }, ptr %alloca, align 8
%lenN = extractvalue { ptr, i64 } %loadN, 1
%icmpN = icmp slt i64 %loadN, %lenN
br i1 %icmpN, label %if.then.36, label %if.merge.37
if.then.3: ; preds = %while.body.1
%loadN = load i64, ptr %allocaN, align 8
%add = add i64 %loadN, 1
%loadN = load { ptr, i64 }, ptr %alloca, align 8
%lenN = extractvalue { ptr, i64 } %loadN, 1
%icmpN = icmp slt i64 %add, %lenN
br i1 %icmpN, label %if.then.6, label %if.else.7
if.else.4: ; preds = %while.body.1
%loadN = load { ptr, i64 }, ptr %alloca, align 8
%loadN = load i64, ptr %allocaN, align 8
%ig.data19 = extractvalue { ptr, i64 } %loadN, 0
%ig.ptr20 = getelementptr i8, ptr %ig.data19, i64 %loadN
%ig.val21 = load i8, ptr %ig.ptr20, align 1
%cmp.ext22 = zext i8 %ig.val21 to i64
%icmpN = icmp eq i64 %cmp.ext22, 125
br i1 %icmpN, label %if.then.27, label %if.else.28
if.merge.5: ; preds = %if.merge.29, %if.merge.8
br label %while.hdr.0
if.then.6: ; preds = %if.then.3
%loadN = load { ptr, i64 }, ptr %alloca, align 8
%loadN = load i64, ptr %allocaN, align 8
%addN = add i64 %loadN, 1
%ig.data27 = extractvalue { ptr, i64 } %loadN, 0
%ig.ptr28 = getelementptr i8, ptr %ig.data27, i64 %addN
%ig.val29 = load i8, ptr %ig.ptr28, align 1
%cmp.ext30 = zext i8 %ig.val29 to i64
%icmpN = icmp eq i64 %cmp.ext30, 125
br i1 %icmpN, label %if.then.9, label %if.else.10
if.else.7: ; preds = %if.then.3
%loadN = load i64, ptr %allocaN, align 8
%addN = add i64 %loadN, 1
store i64 %addN, ptr %allocaN, align 8
br label %if.merge.8
if.merge.8: ; preds = %if.merge.11, %if.else.7
br label %if.merge.5
if.then.9: ; preds = %if.then.6
%loadN = load i64, ptr %allocaN, align 8
%loadN = load i64, ptr %allocaN, align 8
%icmpN = icmp sgt i64 %loadN, %loadN
br i1 %icmpN, label %if.then.12, label %if.merge.13
if.else.10: ; preds = %if.then.6
%loadN = load { ptr, i64 }, ptr %alloca, align 8
%loadN = load i64, ptr %allocaN, align 8
%addN = add i64 %loadN, 1
%ig.data40 = extractvalue { ptr, i64 } %loadN, 0
%ig.ptr41 = getelementptr i8, ptr %ig.data40, i64 %addN
%ig.val42 = load i8, ptr %ig.ptr41, align 1
%cmp.ext43 = zext i8 %ig.val42 to i64
%icmpN = icmp eq i64 %cmp.ext43, 123
br i1 %icmpN, label %if.then.24, label %if.else.25
if.merge.11: ; preds = %if.merge.26, %if.merge.13
br label %if.merge.8
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.96, 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
%callN = call { ptr, i64 } @int_to_string(ptr %0, i64 %loadN)
%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 2 })
store { ptr, i64 } %callN, ptr %allocaN, align 8
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%loadN = load i64, ptr %allocaN, align 8
%loadN = load i64, ptr %allocaN, align 8
%sub = sub i64 %loadN, %loadN
%callN = call { ptr, i64 } @int_to_string(ptr %0, i64 %sub)
%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.98, 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.99, 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
%callN = call { ptr, i64 } @int_to_string(ptr %0, i64 %loadN)
%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 5 })
store { ptr, i64 } %callN, ptr %allocaN, align 8
%loadN = load i64, ptr %allocaN, align 8
%addN = add i64 %loadN, 1
store i64 %addN, ptr %allocaN, align 8
%loadN = load i64, ptr %allocaN, align 8
%addN = add i64 %loadN, 2
store i64 %addN, ptr %allocaN, align 8
%loadN = load i64, ptr %allocaN, align 8
store i64 %loadN, ptr %allocaN, align 8
br label %if.merge.11
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.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
%callN = call { ptr, i64 } @int_to_string(ptr %0, i64 %loadN)
%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 })
store { ptr, i64 } %callN, ptr %allocaN, align 8
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%loadN = load i64, ptr %allocaN, align 8
%loadN = load i64, ptr %allocaN, align 8
%subN = sub i64 %loadN, %loadN
%addN = add i64 %subN, 1
%callN = call { ptr, i64 } @int_to_string(ptr %0, i64 %addN)
%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 })
store { ptr, i64 } %callN, ptr %allocaN, align 8
%loadN = load i64, ptr %allocaN, align 8
%addN = add i64 %loadN, 2
store i64 %addN, ptr %allocaN, align 8
%loadN = load i64, ptr %allocaN, align 8
store i64 %loadN, ptr %allocaN, align 8
br label %if.merge.26
if.else.25: ; preds = %if.else.10
%loadN = load i64, ptr %allocaN, align 8
%addN = add i64 %loadN, 1
store i64 %addN, ptr %allocaN, align 8
br label %if.merge.26
if.merge.26: ; preds = %if.else.25, %if.then.24
br label %if.merge.11
if.then.27: ; preds = %if.else.4
%loadN = load i64, ptr %allocaN, align 8
%addN = add i64 %loadN, 1
%loadN = load { ptr, i64 }, ptr %alloca, align 8
%lenN = extractvalue { ptr, i64 } %loadN, 1
%icmpN = icmp slt i64 %addN, %lenN
br i1 %icmpN, label %if.then.30, label %if.else.31
if.else.28: ; preds = %if.else.4
%loadN = load i64, ptr %allocaN, align 8
%addN = add i64 %loadN, 1
store i64 %addN, ptr %allocaN, align 8
br label %if.merge.29
if.merge.29: ; preds = %if.merge.32, %if.else.28
br label %if.merge.5
if.then.30: ; preds = %if.then.27
%loadN = load { ptr, i64 }, ptr %alloca, align 8
%loadN = load i64, ptr %allocaN, align 8
%addN = add i64 %loadN, 1
%ig.data104 = extractvalue { ptr, i64 } %loadN, 0
%ig.ptr105 = getelementptr i8, ptr %ig.data104, i64 %addN
%ig.val106 = load i8, ptr %ig.ptr105, align 1
%cmp.ext107 = zext i8 %ig.val106 to i64
%icmpN = icmp eq i64 %cmp.ext107, 125
br i1 %icmpN, label %if.then.33, label %if.else.34
if.else.31: ; preds = %if.then.27
%loadN = load i64, ptr %allocaN, align 8
%addN = add i64 %loadN, 1
store i64 %addN, ptr %allocaN, align 8
br label %if.merge.32
if.merge.32: ; preds = %if.merge.35, %if.else.31
br label %if.merge.29
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.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
%callN = call { ptr, i64 } @int_to_string(ptr %0, i64 %loadN)
%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.105, 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
%loadN = load i64, ptr %allocaN, align 8
%subN = sub i64 %loadN, %loadN
%addN = add i64 %subN, 1
%callN = call { ptr, i64 } @int_to_string(ptr %0, i64 %addN)
%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.106, i64 4 })
store { ptr, i64 } %callN, ptr %allocaN, align 8
%loadN = load i64, ptr %allocaN, align 8
%addN = add i64 %loadN, 2
store i64 %addN, ptr %allocaN, align 8
%loadN = load i64, ptr %allocaN, align 8
store i64 %loadN, ptr %allocaN, align 8
br label %if.merge.35
if.else.34: ; preds = %if.then.30
%loadN = load i64, ptr %allocaN, align 8
%addN = add i64 %loadN, 1
store i64 %addN, ptr %allocaN, align 8
br label %if.merge.35
if.merge.35: ; preds = %if.else.34, %if.then.33
br label %if.merge.32
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.107, 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
%callN = call { ptr, i64 } @int_to_string(ptr %0, i64 %loadN)
%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.108, 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
%lenN = extractvalue { ptr, i64 } %loadN, 1
%loadN = load i64, ptr %allocaN, align 8
%subN = sub i64 %lenN, %loadN
%callN = call { ptr, i64 } @int_to_string(ptr %0, i64 %subN)
%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.109, i64 4 })
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %if.merge.37
if.merge.37: ; preds = %if.then.36, %while.exit.2
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
ret { ptr, i64 } %loadN
}
; Function Attrs: nounwind
define internal float @direct_size(ptr %0, { { float, i1 }, { float, i1 } } %1) #0 {
entry:
%alloca = alloca { { float, i1 }, { float, i1 } }, align 8
store { { float, i1 }, { float, i1 } } %1, ptr %alloca, align 4
%load = load { { float, i1 }, { float, i1 } }, ptr %alloca, align 4
%sg = extractvalue { { float, i1 }, { float, i1 } } %load, 0
%oh.has = extractvalue { float, i1 } %sg, 1
br i1 %oh.has, label %if.then.38, label %if.else.39
if.then.38: ; preds = %entry
%ou.val = extractvalue { float, i1 } %sg, 0
%allocaN = alloca float, align 4
store float %ou.val, ptr %allocaN, align 4
%loadN = load float, ptr %allocaN, align 4
%fpext = fpext float %loadN to double
br label %if.merge.40
if.else.39: ; preds = %entry
br label %if.merge.40
if.merge.40: ; preds = %if.else.39, %if.then.38
%bp = phi double [ %fpext, %if.then.38 ], [ 1.000000e+02, %if.else.39 ]
%allocaN = alloca double, align 8
store double %bp, ptr %allocaN, align 8
%loadN = load { { float, i1 }, { float, i1 } }, ptr %alloca, align 4
%sgN = extractvalue { { float, i1 }, { float, i1 } } %loadN, 1
%oh.has6 = extractvalue { float, i1 } %sgN, 1
br i1 %oh.has6, label %if.then.41, label %if.else.42
if.then.41: ; preds = %if.merge.40
%ou.val7 = extractvalue { float, i1 } %sgN, 0
%allocaN = alloca float, align 4
store float %ou.val7, ptr %allocaN, align 4
%loadN = load float, ptr %allocaN, align 4
%fpextN = fpext float %loadN to double
br label %if.merge.43
if.else.42: ; preds = %if.merge.40
br label %if.merge.43
if.merge.43: ; preds = %if.else.42, %if.then.41
%bpN = phi double [ %fpextN, %if.then.41 ], [ 1.000000e+02, %if.else.42 ]
%allocaN = alloca double, align 8
store double %bpN, ptr %allocaN, align 8
%loadN = load double, ptr %allocaN, align 8
%loadN = load double, ptr %allocaN, align 8
%fadd = fadd double %loadN, %loadN
%fptrunc = fptrunc double %fadd to float
ret float %fptrunc
}
; Function Attrs: nounwind
define internal float @Widget.size(ptr %0, ptr %1, { { float, i1 }, { float, i1 } } %2) #0 {
entry:
%alloca = alloca ptr, align 8
store ptr %1, ptr %alloca, align 8
%allocaN = alloca { { float, i1 }, { float, i1 } }, align 8
store { { float, i1 }, { float, i1 } } %2, ptr %allocaN, align 4
%load = load { { float, i1 }, { float, i1 } }, ptr %allocaN, align 4
%sg = extractvalue { { float, i1 }, { float, i1 } } %load, 0
%oh.has = extractvalue { float, i1 } %sg, 1
br i1 %oh.has, label %if.then.44, label %if.else.45
if.then.44: ; preds = %entry
%ou.val = extractvalue { float, i1 } %sg, 0
%allocaN = alloca float, align 4
store float %ou.val, ptr %allocaN, align 4
%loadN = load float, ptr %allocaN, align 4
%fpext = fpext float %loadN to double
br label %if.merge.46
if.else.45: ; preds = %entry
br label %if.merge.46
if.merge.46: ; preds = %if.else.45, %if.then.44
%bp = phi double [ %fpext, %if.then.44 ], [ 1.000000e+02, %if.else.45 ]
%allocaN = alloca double, align 8
store double %bp, ptr %allocaN, align 8
%loadN = load { { float, i1 }, { float, i1 } }, ptr %allocaN, align 4
%sgN = extractvalue { { float, i1 }, { float, i1 } } %loadN, 1
%oh.has7 = extractvalue { float, i1 } %sgN, 1
br i1 %oh.has7, label %if.then.47, label %if.else.48
if.then.47: ; preds = %if.merge.46
%ou.val8 = extractvalue { float, i1 } %sgN, 0
%allocaN = alloca float, align 4
store float %ou.val8, ptr %allocaN, align 4
%loadN = load float, ptr %allocaN, align 4
%fpextN = fpext float %loadN to double
br label %if.merge.49
if.else.48: ; preds = %if.merge.46
br label %if.merge.49
if.merge.49: ; preds = %if.else.48, %if.then.47
%bpN = phi double [ %fpextN, %if.then.47 ], [ 1.000000e+02, %if.else.48 ]
%allocaN = alloca double, align 8
store double %bpN, ptr %allocaN, align 8
%loadN = load double, ptr %allocaN, align 8
%loadN = load double, ptr %allocaN, align 8
%fadd = fadd double %loadN, %loadN
%fptrunc = fptrunc double %fadd to float
ret float %fptrunc
}
; Function Attrs: nounwind
define i32 @main() #0 {
entry:
call void @print__ct_safaf8808e13137c9__pack(ptr @__sx_default_context)
%call = call float @direct_size(ptr @__sx_default_context, { { float, i1 }, { float, i1 } } { { float, i1 } { float 5.000000e+01, i1 true }, { float, i1 } zeroinitializer })
%alloca = alloca float, align 4
store float %call, ptr %alloca, align 4
%load = load float, ptr %alloca, align 4
call void @print__ct_sa9ba8ae6123c77ba__pack_f32(ptr @__sx_default_context, float %load)
%callN = call float @direct_size(ptr @__sx_default_context, { { float, i1 }, { float, i1 } } { { float, i1 } zeroinitializer, { float, i1 } { float 5.000000e+01, i1 true } })
%allocaN = alloca float, align 4
store float %callN, ptr %allocaN, align 4
%loadN = load float, ptr %allocaN, align 4
call void @print__ct_s9af257f36f17eef5__pack_f32(ptr @__sx_default_context, float %loadN)
%callN = call float @direct_size(ptr @__sx_default_context, { { float, i1 }, { float, i1 } } zeroinitializer)
%allocaN = alloca float, align 4
store float %callN, ptr %allocaN, align 4
%loadN = load float, ptr %allocaN, align 4
call void @print__ct_scf4d64fa60dbbfb4__pack_f32(ptr @__sx_default_context, float %loadN)
%callN = call float @direct_size(ptr @__sx_default_context, { { float, i1 }, { float, i1 } } { { float, i1 } { float 5.000000e+01, i1 true }, { float, i1 } { float 6.000000e+01, i1 true } })
%allocaN = alloca float, align 4
store float %callN, ptr %allocaN, align 4
%loadN = load float, ptr %allocaN, align 4
call void @print__ct_s1c39af9abf6a4a07__pack_f32(ptr @__sx_default_context, float %loadN)
call void @print__ct_s1982bb0332b7dace__pack(ptr @__sx_default_context)
%allocaN = alloca {}, align 8
store {} undef, ptr %allocaN, align 1
%allocaN = alloca { ptr, ptr }, align 8
%loadN = load {}, ptr %allocaN, align 1
%si = insertvalue { ptr, ptr } undef, ptr %allocaN, 0
%siN = insertvalue { ptr, ptr } %si, ptr @__Sizable__Widget__vtable, 1
store { ptr, ptr } %siN, ptr %allocaN, align 8
%loadN = load { ptr, ptr }, ptr %allocaN, align 8
%sg = extractvalue { ptr, ptr } %loadN, 0
%sgN = extractvalue { ptr, ptr } %loadN, 1
%deref = load { ptr }, ptr %sgN, align 8
%sgN = extractvalue { ptr } %deref, 0
%icall = call float %sgN(ptr @__sx_default_context, ptr %sg, { { float, i1 }, { float, i1 } } { { float, i1 } { float 5.000000e+01, i1 true }, { float, i1 } zeroinitializer })
%allocaN = alloca float, align 4
store float %icall, ptr %allocaN, align 4
%loadN = load float, ptr %allocaN, align 4
call void @print__ct_s328a3cec2430526b__pack_f32(ptr @__sx_default_context, float %loadN)
%loadN = load { ptr, ptr }, ptr %allocaN, align 8
%sgN = extractvalue { ptr, ptr } %loadN, 0
%sgN = extractvalue { ptr, ptr } %loadN, 1
%derefN = load { ptr }, ptr %sgN, align 8
%sgN = extractvalue { ptr } %derefN, 0
%icallN = call float %sgN(ptr @__sx_default_context, ptr %sgN, { { float, i1 }, { float, i1 } } { { float, i1 } zeroinitializer, { float, i1 } { float 5.000000e+01, i1 true } })
%allocaN = alloca float, align 4
store float %icallN, ptr %allocaN, align 4
%loadN = load float, ptr %allocaN, align 4
call void @print__ct_sad2d86d80b81462__pack_f32(ptr @__sx_default_context, float %loadN)
%loadN = load { ptr, ptr }, ptr %allocaN, align 8
%sgN = extractvalue { ptr, ptr } %loadN, 0
%sgN = extractvalue { ptr, ptr } %loadN, 1
%derefN = load { ptr }, ptr %sgN, align 8
%sgN = extractvalue { ptr } %derefN, 0
%icallN = call float %sgN(ptr @__sx_default_context, ptr %sgN, { { float, i1 }, { float, i1 } } zeroinitializer)
%allocaN = alloca float, align 4
store float %icallN, ptr %allocaN, align 4
%loadN = load float, ptr %allocaN, align 4
call void @print__ct_s356f7a97ffec319e__pack_f32(ptr @__sx_default_context, float %loadN)
%loadN = load { ptr, ptr }, ptr %allocaN, align 8
%sgN = extractvalue { ptr, ptr } %loadN, 0
%sgN = extractvalue { ptr, ptr } %loadN, 1
%derefN = load { ptr }, ptr %sgN, align 8
%sgN = extractvalue { ptr } %derefN, 0
%icallN = call float %sgN(ptr @__sx_default_context, ptr %sgN, { { float, i1 }, { float, i1 } } { { float, i1 } { float 5.000000e+01, i1 true }, { float, i1 } { float 6.000000e+01, i1 true } })
%allocaN = alloca float, align 4
store float %icallN, ptr %allocaN, align 4
%loadN = load float, ptr %allocaN, align 4
call void @print__ct_sc1a70412aecae073__pack_f32(ptr @__sx_default_context, float %loadN)
ret i32 0
}
; Function Attrs: nounwind
define internal ptr @__thunk_CAllocator_Allocator_alloc(ptr %0, ptr %1, i64 %2) #0 {
entry:
%call = call ptr @CAllocator.alloc(ptr %0, ptr %1, i64 %2)
ret ptr %call
}
; Function Attrs: nounwind
define internal void @__thunk_CAllocator_Allocator_dealloc(ptr %0, ptr %1, ptr %2) #0 {
entry:
call void @CAllocator.dealloc(ptr %0, ptr %1, ptr %2)
ret void
}
; Function Attrs: nounwind
define internal void @print__ct_safaf8808e13137c9__pack(ptr %0) #0 {
entry:
%alloca = alloca { ptr, i64 }, align 8
store { ptr, i64 } { ptr @str.110, i64 21 }, ptr %alloca, align 8
%allocaN = alloca { ptr, i64 }, align 8
%gep = getelementptr inbounds { ptr, i64 }, ptr %allocaN, i32 0, i32 0
store ptr null, ptr %gep, align 8
%gepN = getelementptr inbounds { ptr, i64 }, ptr %allocaN, i32 0, i32 1
store i64 0, ptr %gepN, align 8
%allocaN = alloca { ptr, i64 }, align 8
store { ptr, i64 } { ptr @str.111, i64 0 }, ptr %allocaN, align 8
%load = 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 21)
%callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %load, { ptr, i64 } %call)
store { ptr, i64 } %callN, ptr %allocaN, align 8
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%str.ptr = extractvalue { ptr, i64 } %loadN, 0
%str.len = extractvalue { ptr, i64 } %loadN, 1
%1 = call i64 @write(i32 1, ptr %str.ptr, i64 %str.len)
ret void
}
; 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.112, i64 21 })
ret { ptr, i64 } %call
}
; Function Attrs: nounwind
define internal void @print__ct_sa9ba8ae6123c77ba__pack_f32(ptr %0, float %1) #0 {
entry:
%alloca = alloca { ptr, i64 }, align 8
store { ptr, i64 } { ptr @str.113, i64 8 }, ptr %alloca, align 8
%allocaN = alloca float, align 4
store float %1, ptr %allocaN, align 4
%allocaN = alloca [1 x { i64, i64 }], align 8
%load = load float, ptr %allocaN, align 4
%fNi32 = bitcast float %load to i32
%zN = zext i32 %fNi32 to i64
%ba.val = insertvalue { i64, i64 } { i64 10, i64 undef }, i64 %zN, 1
%igp.ptr = getelementptr { i64, i64 }, ptr %allocaN, i64 0
store { i64, i64 } %ba.val, ptr %igp.ptr, align 8
%allocaN = alloca { ptr, i64 }, align 8
%igp.ptr4 = getelementptr { i64, i64 }, ptr %allocaN, i64 0
%gep = getelementptr inbounds { ptr, i64 }, ptr %allocaN, i32 0, i32 0
store ptr %igp.ptr4, ptr %gep, align 8
%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.114, 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 5)
%callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %call)
store { ptr, i64 } %callN, ptr %allocaN, align 8
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%loadN = load float, ptr %allocaN, align 4
%fNi3212 = bitcast float %loadN to i32
%zN = zext i32 %fNi3212 to i64
%ba.val14 = insertvalue { i64, i64 } { i64 10, i64 undef }, i64 %zN, 1
%callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %ba.val14)
%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
%loadN = load { ptr, i64 }, ptr %alloca, align 8
%callN = call { ptr, i64 } @substr(ptr %0, { ptr, i64 } %loadN, i64 7, i64 1)
%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
%str.ptr = extractvalue { ptr, i64 } %loadN, 0
%str.len = extractvalue { ptr, i64 } %loadN, 1
%2 = call i64 @write(i32 1, ptr %str.ptr, i64 %str.len)
ret void
}
; 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.115, i64 8 })
ret { ptr, i64 } %call
}
; Function Attrs: nounwind
define internal void @print__ct_s9af257f36f17eef5__pack_f32(ptr %0, float %1) #0 {
entry:
%alloca = alloca { ptr, i64 }, align 8
store { ptr, i64 } { ptr @str.116, i64 8 }, ptr %alloca, align 8
%allocaN = alloca float, align 4
store float %1, ptr %allocaN, align 4
%allocaN = alloca [1 x { i64, i64 }], align 8
%load = load float, ptr %allocaN, align 4
%fNi32 = bitcast float %load to i32
%zN = zext i32 %fNi32 to i64
%ba.val = insertvalue { i64, i64 } { i64 10, i64 undef }, i64 %zN, 1
%igp.ptr = getelementptr { i64, i64 }, ptr %allocaN, i64 0
store { i64, i64 } %ba.val, ptr %igp.ptr, align 8
%allocaN = alloca { ptr, i64 }, align 8
%igp.ptr4 = getelementptr { i64, i64 }, ptr %allocaN, i64 0
%gep = getelementptr inbounds { ptr, i64 }, ptr %allocaN, i32 0, i32 0
store ptr %igp.ptr4, ptr %gep, align 8
%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.117, 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 5)
%callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %call)
store { ptr, i64 } %callN, ptr %allocaN, align 8
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%loadN = load float, ptr %allocaN, align 4
%fNi3212 = bitcast float %loadN to i32
%zN = zext i32 %fNi3212 to i64
%ba.val14 = insertvalue { i64, i64 } { i64 10, i64 undef }, i64 %zN, 1
%callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %ba.val14)
%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
%loadN = load { ptr, i64 }, ptr %alloca, align 8
%callN = call { ptr, i64 } @substr(ptr %0, { ptr, i64 } %loadN, i64 7, i64 1)
%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
%str.ptr = extractvalue { ptr, i64 } %loadN, 0
%str.len = extractvalue { ptr, i64 } %loadN, 1
%2 = call i64 @write(i32 1, ptr %str.ptr, i64 %str.len)
ret void
}
; Function Attrs: nounwind
define internal { ptr, i64 } @__insert_2(ptr %0) #0 {
entry:
%call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.118, i64 8 })
ret { ptr, i64 } %call
}
; Function Attrs: nounwind
define internal void @print__ct_scf4d64fa60dbbfb4__pack_f32(ptr %0, float %1) #0 {
entry:
%alloca = alloca { ptr, i64 }, align 8
store { ptr, i64 } { ptr @str.119, i64 8 }, ptr %alloca, align 8
%allocaN = alloca float, align 4
store float %1, ptr %allocaN, align 4
%allocaN = alloca [1 x { i64, i64 }], align 8
%load = load float, ptr %allocaN, align 4
%fNi32 = bitcast float %load to i32
%zN = zext i32 %fNi32 to i64
%ba.val = insertvalue { i64, i64 } { i64 10, i64 undef }, i64 %zN, 1
%igp.ptr = getelementptr { i64, i64 }, ptr %allocaN, i64 0
store { i64, i64 } %ba.val, ptr %igp.ptr, align 8
%allocaN = alloca { ptr, i64 }, align 8
%igp.ptr4 = getelementptr { i64, i64 }, ptr %allocaN, i64 0
%gep = getelementptr inbounds { ptr, i64 }, ptr %allocaN, i32 0, i32 0
store ptr %igp.ptr4, ptr %gep, align 8
%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.120, 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 5)
%callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %call)
store { ptr, i64 } %callN, ptr %allocaN, align 8
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%loadN = load float, ptr %allocaN, align 4
%fNi3212 = bitcast float %loadN to i32
%zN = zext i32 %fNi3212 to i64
%ba.val14 = insertvalue { i64, i64 } { i64 10, i64 undef }, i64 %zN, 1
%callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %ba.val14)
%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
%loadN = load { ptr, i64 }, ptr %alloca, align 8
%callN = call { ptr, i64 } @substr(ptr %0, { ptr, i64 } %loadN, i64 7, i64 1)
%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
%str.ptr = extractvalue { ptr, i64 } %loadN, 0
%str.len = extractvalue { ptr, i64 } %loadN, 1
%2 = call i64 @write(i32 1, ptr %str.ptr, i64 %str.len)
ret void
}
; Function Attrs: nounwind
define internal { ptr, i64 } @__insert_3(ptr %0) #0 {
entry:
%call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.121, i64 8 })
ret { ptr, i64 } %call
}
; Function Attrs: nounwind
define internal void @print__ct_s1c39af9abf6a4a07__pack_f32(ptr %0, float %1) #0 {
entry:
%alloca = alloca { ptr, i64 }, align 8
store { ptr, i64 } { ptr @str.122, i64 8 }, ptr %alloca, align 8
%allocaN = alloca float, align 4
store float %1, ptr %allocaN, align 4
%allocaN = alloca [1 x { i64, i64 }], align 8
%load = load float, ptr %allocaN, align 4
%fNi32 = bitcast float %load to i32
%zN = zext i32 %fNi32 to i64
%ba.val = insertvalue { i64, i64 } { i64 10, i64 undef }, i64 %zN, 1
%igp.ptr = getelementptr { i64, i64 }, ptr %allocaN, i64 0
store { i64, i64 } %ba.val, ptr %igp.ptr, align 8
%allocaN = alloca { ptr, i64 }, align 8
%igp.ptr4 = getelementptr { i64, i64 }, ptr %allocaN, i64 0
%gep = getelementptr inbounds { ptr, i64 }, ptr %allocaN, i32 0, i32 0
store ptr %igp.ptr4, ptr %gep, align 8
%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.123, 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 5)
%callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %call)
store { ptr, i64 } %callN, ptr %allocaN, align 8
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%loadN = load float, ptr %allocaN, align 4
%fNi3212 = bitcast float %loadN to i32
%zN = zext i32 %fNi3212 to i64
%ba.val14 = insertvalue { i64, i64 } { i64 10, i64 undef }, i64 %zN, 1
%callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %ba.val14)
%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
%loadN = load { ptr, i64 }, ptr %alloca, align 8
%callN = call { ptr, i64 } @substr(ptr %0, { ptr, i64 } %loadN, i64 7, i64 1)
%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
%str.ptr = extractvalue { ptr, i64 } %loadN, 0
%str.len = extractvalue { ptr, i64 } %loadN, 1
%2 = call i64 @write(i32 1, ptr %str.ptr, i64 %str.len)
ret void
}
; Function Attrs: nounwind
define internal { ptr, i64 } @__insert_4(ptr %0) #0 {
entry:
%call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.124, i64 8 })
ret { ptr, i64 } %call
}
; Function Attrs: nounwind
define internal void @print__ct_s1982bb0332b7dace__pack(ptr %0) #0 {
entry:
%alloca = alloca { ptr, i64 }, align 8
store { ptr, i64 } { ptr @str.125, i64 26 }, ptr %alloca, align 8
%allocaN = alloca { ptr, i64 }, align 8
%gep = getelementptr inbounds { ptr, i64 }, ptr %allocaN, i32 0, i32 0
store ptr null, ptr %gep, align 8
%gepN = getelementptr inbounds { ptr, i64 }, ptr %allocaN, i32 0, i32 1
store i64 0, ptr %gepN, align 8
%allocaN = alloca { ptr, i64 }, align 8
store { ptr, i64 } { ptr @str.126, i64 0 }, ptr %allocaN, align 8
%load = 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 26)
%callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %load, { ptr, i64 } %call)
store { ptr, i64 } %callN, ptr %allocaN, align 8
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%str.ptr = extractvalue { ptr, i64 } %loadN, 0
%str.len = extractvalue { ptr, i64 } %loadN, 1
%1 = call i64 @write(i32 1, ptr %str.ptr, i64 %str.len)
ret void
}
; Function Attrs: nounwind
define internal { ptr, i64 } @__insert_5(ptr %0) #0 {
entry:
%call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.127, i64 26 })
ret { ptr, i64 } %call
}
; Function Attrs: nounwind
define internal float @__thunk_Widget_Sizable_size(ptr %0, ptr %1, { { float, i1 }, { float, i1 } } %2) #0 {
entry:
%call = call float @Widget.size(ptr %0, ptr %1, { { float, i1 }, { float, i1 } } %2)
ret float %call
}
; Function Attrs: nounwind
define internal void @print__ct_s328a3cec2430526b__pack_f32(ptr %0, float %1) #0 {
entry:
%alloca = alloca { ptr, i64 }, align 8
store { ptr, i64 } { ptr @str.128, i64 8 }, ptr %alloca, align 8
%allocaN = alloca float, align 4
store float %1, ptr %allocaN, align 4
%allocaN = alloca [1 x { i64, i64 }], align 8
%load = load float, ptr %allocaN, align 4
%fNi32 = bitcast float %load to i32
%zN = zext i32 %fNi32 to i64
%ba.val = insertvalue { i64, i64 } { i64 10, i64 undef }, i64 %zN, 1
%igp.ptr = getelementptr { i64, i64 }, ptr %allocaN, i64 0
store { i64, i64 } %ba.val, ptr %igp.ptr, align 8
%allocaN = alloca { ptr, i64 }, align 8
%igp.ptr4 = getelementptr { i64, i64 }, ptr %allocaN, i64 0
%gep = getelementptr inbounds { ptr, i64 }, ptr %allocaN, i32 0, i32 0
store ptr %igp.ptr4, ptr %gep, align 8
%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.129, 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 5)
%callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %call)
store { ptr, i64 } %callN, ptr %allocaN, align 8
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%loadN = load float, ptr %allocaN, align 4
%fNi3212 = bitcast float %loadN to i32
%zN = zext i32 %fNi3212 to i64
%ba.val14 = insertvalue { i64, i64 } { i64 10, i64 undef }, i64 %zN, 1
%callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %ba.val14)
%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
%loadN = load { ptr, i64 }, ptr %alloca, align 8
%callN = call { ptr, i64 } @substr(ptr %0, { ptr, i64 } %loadN, i64 7, i64 1)
%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
%str.ptr = extractvalue { ptr, i64 } %loadN, 0
%str.len = extractvalue { ptr, i64 } %loadN, 1
%2 = call i64 @write(i32 1, ptr %str.ptr, i64 %str.len)
ret void
}
; Function Attrs: nounwind
define internal { ptr, i64 } @__insert_6(ptr %0) #0 {
entry:
%call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.130, i64 8 })
ret { ptr, i64 } %call
}
; Function Attrs: nounwind
define internal void @print__ct_sad2d86d80b81462__pack_f32(ptr %0, float %1) #0 {
entry:
%alloca = alloca { ptr, i64 }, align 8
store { ptr, i64 } { ptr @str.131, i64 8 }, ptr %alloca, align 8
%allocaN = alloca float, align 4
store float %1, ptr %allocaN, align 4
%allocaN = alloca [1 x { i64, i64 }], align 8
%load = load float, ptr %allocaN, align 4
%fNi32 = bitcast float %load to i32
%zN = zext i32 %fNi32 to i64
%ba.val = insertvalue { i64, i64 } { i64 10, i64 undef }, i64 %zN, 1
%igp.ptr = getelementptr { i64, i64 }, ptr %allocaN, i64 0
store { i64, i64 } %ba.val, ptr %igp.ptr, align 8
%allocaN = alloca { ptr, i64 }, align 8
%igp.ptr4 = getelementptr { i64, i64 }, ptr %allocaN, i64 0
%gep = getelementptr inbounds { ptr, i64 }, ptr %allocaN, i32 0, i32 0
store ptr %igp.ptr4, ptr %gep, align 8
%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.132, 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 5)
%callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %call)
store { ptr, i64 } %callN, ptr %allocaN, align 8
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%loadN = load float, ptr %allocaN, align 4
%fNi3212 = bitcast float %loadN to i32
%zN = zext i32 %fNi3212 to i64
%ba.val14 = insertvalue { i64, i64 } { i64 10, i64 undef }, i64 %zN, 1
%callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %ba.val14)
%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
%loadN = load { ptr, i64 }, ptr %alloca, align 8
%callN = call { ptr, i64 } @substr(ptr %0, { ptr, i64 } %loadN, i64 7, i64 1)
%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
%str.ptr = extractvalue { ptr, i64 } %loadN, 0
%str.len = extractvalue { ptr, i64 } %loadN, 1
%2 = call i64 @write(i32 1, ptr %str.ptr, i64 %str.len)
ret void
}
; Function Attrs: nounwind
define internal { ptr, i64 } @__insert_7(ptr %0) #0 {
entry:
%call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.133, i64 8 })
ret { ptr, i64 } %call
}
; Function Attrs: nounwind
define internal void @print__ct_s356f7a97ffec319e__pack_f32(ptr %0, float %1) #0 {
entry:
%alloca = alloca { ptr, i64 }, align 8
store { ptr, i64 } { ptr @str.134, i64 8 }, ptr %alloca, align 8
%allocaN = alloca float, align 4
store float %1, ptr %allocaN, align 4
%allocaN = alloca [1 x { i64, i64 }], align 8
%load = load float, ptr %allocaN, align 4
%fNi32 = bitcast float %load to i32
%zN = zext i32 %fNi32 to i64
%ba.val = insertvalue { i64, i64 } { i64 10, i64 undef }, i64 %zN, 1
%igp.ptr = getelementptr { i64, i64 }, ptr %allocaN, i64 0
store { i64, i64 } %ba.val, ptr %igp.ptr, align 8
%allocaN = alloca { ptr, i64 }, align 8
%igp.ptr4 = getelementptr { i64, i64 }, ptr %allocaN, i64 0
%gep = getelementptr inbounds { ptr, i64 }, ptr %allocaN, i32 0, i32 0
store ptr %igp.ptr4, ptr %gep, align 8
%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.135, 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 5)
%callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %call)
store { ptr, i64 } %callN, ptr %allocaN, align 8
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%loadN = load float, ptr %allocaN, align 4
%fNi3212 = bitcast float %loadN to i32
%zN = zext i32 %fNi3212 to i64
%ba.val14 = insertvalue { i64, i64 } { i64 10, i64 undef }, i64 %zN, 1
%callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %ba.val14)
%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
%loadN = load { ptr, i64 }, ptr %alloca, align 8
%callN = call { ptr, i64 } @substr(ptr %0, { ptr, i64 } %loadN, i64 7, i64 1)
%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
%str.ptr = extractvalue { ptr, i64 } %loadN, 0
%str.len = extractvalue { ptr, i64 } %loadN, 1
%2 = call i64 @write(i32 1, ptr %str.ptr, i64 %str.len)
ret void
}
; Function Attrs: nounwind
define internal { ptr, i64 } @__insert_8(ptr %0) #0 {
entry:
%call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.136, i64 8 })
ret { ptr, i64 } %call
}
; Function Attrs: nounwind
define internal void @print__ct_sc1a70412aecae073__pack_f32(ptr %0, float %1) #0 {
entry:
%alloca = alloca { ptr, i64 }, align 8
store { ptr, i64 } { ptr @str.137, i64 8 }, ptr %alloca, align 8
%allocaN = alloca float, align 4
store float %1, ptr %allocaN, align 4
%allocaN = alloca [1 x { i64, i64 }], align 8
%load = load float, ptr %allocaN, align 4
%fNi32 = bitcast float %load to i32
%zN = zext i32 %fNi32 to i64
%ba.val = insertvalue { i64, i64 } { i64 10, i64 undef }, i64 %zN, 1
%igp.ptr = getelementptr { i64, i64 }, ptr %allocaN, i64 0
store { i64, i64 } %ba.val, ptr %igp.ptr, align 8
%allocaN = alloca { ptr, i64 }, align 8
%igp.ptr4 = getelementptr { i64, i64 }, ptr %allocaN, i64 0
%gep = getelementptr inbounds { ptr, i64 }, ptr %allocaN, i32 0, i32 0
store ptr %igp.ptr4, ptr %gep, align 8
%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.138, 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 5)
%callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %call)
store { ptr, i64 } %callN, ptr %allocaN, align 8
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%loadN = load float, ptr %allocaN, align 4
%fNi3212 = bitcast float %loadN to i32
%zN = zext i32 %fNi3212 to i64
%ba.val14 = insertvalue { i64, i64 } { i64 10, i64 undef }, i64 %zN, 1
%callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %ba.val14)
%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
%loadN = load { ptr, i64 }, ptr %alloca, align 8
%callN = call { ptr, i64 } @substr(ptr %0, { ptr, i64 } %loadN, i64 7, i64 1)
%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
%str.ptr = extractvalue { ptr, i64 } %loadN, 0
%str.len = extractvalue { ptr, i64 } %loadN, 1
%2 = call i64 @write(i32 1, ptr %str.ptr, i64 %str.len)
ret void
}
; Function Attrs: nounwind
define internal { ptr, i64 } @__insert_9(ptr %0) #0 {
entry:
%call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.139, i64 8 })
ret { ptr, i64 } %call
}
; Function Attrs: nounwind
define internal { ptr, i64 } @struct_to_string__Source_Location(ptr %0, { { ptr, i64 }, i32, i32, { ptr, i64 } } %1) #0 {
entry:
%alloca = alloca { { ptr, i64 }, i32, i32, { ptr, i64 } }, align 8
store { { ptr, i64 }, i32, i32, { ptr, i64 } } %1, ptr %alloca, align 8
%call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.140, i64 15 }, { ptr, i64 } { ptr @str.141, 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.97
while.hdr.97: ; preds = %fv.merge, %entry
%load = load i64, ptr %allocaN, align 8
%icmp = icmp slt i64 %load, 4
br i1 %icmp, label %while.body.98, label %while.exit.99
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.100, label %if.merge.101
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.142, i64 1 })
ret { ptr, i64 } %callN
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.143, i64 2 })
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %if.merge.101
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 [4 x { ptr, i64 }], ptr @field_names, 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.147, i64 2 })
store { ptr, i64 } %callN, ptr %allocaN, align 8
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%loadN = load { { ptr, i64 }, i32, i32, { ptr, i64 } }, ptr %alloca, align 8
%loadN = load i64, ptr %allocaN, align 8
switch i64 %loadN, label %fv.default [
i64 0, label %fv.case
i64 1, label %fv.case17
i64 2, label %fv.case20
i64 3, label %fv.case24
]
fv.merge: ; preds = %fv.default, %fv.case24, %fv.case20, %fv.case17, %fv.case
%fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ %fv.val23, %fv.case20 ], [ %fv.val28, %fv.case24 ], [ undef, %fv.default ]
%callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi)
%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.97
fv.default: ; preds = %if.merge.101
br label %fv.merge
fv.case: ; preds = %if.merge.101
%fv.field = extractvalue { { ptr, i64 }, i32, i32, { ptr, i64 } } %loadN, 0
%ba.tmp = alloca { ptr, i64 }, align 8
store { ptr, i64 } %fv.field, ptr %ba.tmp, align 8
%ba.p2i = ptrtoint ptr %ba.tmp to i64
%fv.val = insertvalue { i64, i64 } { i64 12, i64 undef }, i64 %ba.p2i, 1
br label %fv.merge
fv.case17: ; preds = %if.merge.101
%fv.field18 = extractvalue { { ptr, i64 }, i32, i32, { ptr, i64 } } %loadN, 1
%sN = sext i32 %fv.field18 to i64
%fv.val19 = insertvalue { i64, i64 } { i64 4, i64 undef }, i64 %sN, 1
br label %fv.merge
fv.case20: ; preds = %if.merge.101
%fv.field21 = extractvalue { { ptr, i64 }, i32, i32, { ptr, i64 } } %loadN, 2
%sN = sext i32 %fv.field21 to i64
%fv.val23 = insertvalue { i64, i64 } { i64 4, i64 undef }, i64 %sN, 1
br label %fv.merge
fv.case24: ; preds = %if.merge.101
%fv.field25 = extractvalue { { ptr, i64 }, i32, i32, { ptr, i64 } } %loadN, 3
%ba.tmp26 = alloca { ptr, i64 }, align 8
store { ptr, i64 } %fv.field25, ptr %ba.tmp26, align 8
%ba.p2i27 = ptrtoint ptr %ba.tmp26 to i64
%fv.val28 = insertvalue { i64, i64 } { i64 12, i64 undef }, i64 %ba.p2i27, 1
br label %fv.merge
}
; Function Attrs: nounwind
define internal { ptr, i64 } @struct_to_string__Allocator(ptr %0, { ptr, ptr, ptr } %1) #0 {
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.148, i64 9 }, { ptr, i64 } { ptr @str.149, 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.102
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.103, label %while.exit.104
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.105, label %if.merge.106
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.150, i64 1 })
ret { ptr, i64 } %callN
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.151, i64 2 })
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %if.merge.106
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.155, 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.156, 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
%loadN = load i64, ptr %allocaN, align 8
switch i64 %loadN, label %fv.default [
i64 0, label %fv.case
i64 1, label %fv.case17
i64 2, label %fv.case21
]
fv.merge: ; preds = %fv.default, %fv.case21, %fv.case17, %fv.case
%fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val20, %fv.case17 ], [ %fv.val24, %fv.case21 ], [ undef, %fv.default ]
%callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi)
%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.102
fv.default: ; preds = %if.merge.106
br label %fv.merge
fv.case: ; preds = %if.merge.106
%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.106
%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.106
%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
br label %fv.merge
}
; Function Attrs: nounwind
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.157, i64 10 }, { ptr, i64 } { ptr @str.158, 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.107
while.hdr.107: ; preds = %if.merge.111, %entry
%load = load i64, ptr %allocaN, align 8
%icmp = icmp slt i64 %load, 0
br i1 %icmp, label %while.body.108, label %while.exit.109
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.110, label %if.merge.111
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.159, i64 1 })
ret { ptr, i64 } %callN
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.160, i64 2 })
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %if.merge.111
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 [0 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.162, 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.107
}
; Function Attrs: nounwind
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.163, i64 3 }, { 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.112
while.hdr.112: ; preds = %fv.merge, %entry
%load = load i64, ptr %allocaN, align 8
%icmp = icmp slt i64 %load, 1
br i1 %icmp, label %while.body.113, label %while.exit.114
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.115, label %if.merge.116
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.165, i64 1 })
ret { ptr, i64 } %callN
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.166, i64 2 })
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %if.merge.116
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 [1 x { ptr, i64 }], ptr @field_names.168, 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 })
store { ptr, i64 } %callN, ptr %allocaN, align 8
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%loadN = load { i64 }, ptr %alloca, align 8
%loadN = load i64, ptr %allocaN, align 8
switch i64 %loadN, label %fv.default [
i64 0, label %fv.case
]
fv.merge: ; preds = %fv.default, %fv.case
%fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ undef, %fv.default ]
%callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi)
%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.112
fv.default: ; preds = %if.merge.116
br label %fv.merge
fv.case: ; preds = %if.merge.116
%fv.field = extractvalue { i64 } %loadN, 0
%fv.val = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field, 1
br label %fv.merge
}
; Function Attrs: nounwind
define internal { ptr, i64 } @struct_to_string__ArenaChunk(ptr %0, { ptr, i64 } %1) #0 {
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.170, i64 10 }, { ptr, i64 } { ptr @str.171, 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.117
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.118, label %while.exit.119
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.120, label %if.merge.121
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 })
ret { ptr, i64 } %callN
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 })
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %if.merge.121
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.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 })
store { ptr, i64 } %callN, ptr %allocaN, align 8
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%loadN = load { ptr, i64 }, ptr %alloca, align 8
%loadN = load i64, ptr %allocaN, align 8
switch i64 %loadN, label %fv.default [
i64 0, label %fv.case
i64 1, label %fv.case17
]
fv.merge: ; preds = %fv.default, %fv.case17, %fv.case
%fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ undef, %fv.default ]
%callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi)
%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.117
fv.default: ; preds = %if.merge.121
br label %fv.merge
fv.case: ; preds = %if.merge.121
%fv.field = extractvalue { ptr, i64 } %loadN, 0
%pNi = ptrtoint ptr %fv.field to i64
%fv.val = insertvalue { i64, i64 } { i64 26, i64 undef }, i64 %pNi, 1
br label %fv.merge
fv.case17: ; preds = %if.merge.121
%fv.field18 = extractvalue { ptr, i64 } %loadN, 1
%fv.val19 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field18, 1
br label %fv.merge
}
; Function Attrs: nounwind
define internal { ptr, i64 } @struct_to_string__Arena(ptr %0, { ptr, i64, { ptr, ptr, ptr } } %1) #0 {
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.178, i64 5 }, { ptr, i64 } { ptr @str.179, 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.122
while.hdr.122: ; preds = %fv.merge, %entry
%load = load i64, ptr %allocaN, align 8
%icmp = icmp slt i64 %load, 3
br i1 %icmp, label %while.body.123, label %while.exit.124
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.125, label %if.merge.126
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 })
ret { ptr, i64 } %callN
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 })
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %if.merge.126
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 [3 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.186, 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
%loadN = load i64, ptr %allocaN, align 8
switch i64 %loadN, label %fv.default [
i64 0, label %fv.case
i64 1, label %fv.case17
i64 2, label %fv.case20
]
fv.merge: ; preds = %fv.default, %fv.case20, %fv.case17, %fv.case
%fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ %fv.val22, %fv.case20 ], [ undef, %fv.default ]
%callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi)
%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.122
fv.default: ; preds = %if.merge.126
br label %fv.merge
fv.case: ; preds = %if.merge.126
%fv.field = extractvalue { ptr, i64, { ptr, ptr, ptr } } %loadN, 0
%pNi = ptrtoint ptr %fv.field to i64
%fv.val = insertvalue { i64, i64 } { i64 26, i64 undef }, i64 %pNi, 1
br label %fv.merge
fv.case17: ; preds = %if.merge.126
%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.126
%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
%ba.p2i = ptrtoint ptr %ba.tmp to i64
%fv.val22 = insertvalue { i64, i64 } { i64 20, i64 undef }, i64 %ba.p2i, 1
br label %fv.merge
}
; Function Attrs: nounwind
define internal { ptr, i64 } @struct_to_string__BufAlloc(ptr %0, { ptr, i64, i64 } %1) #0 {
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.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 = %fv.merge, %entry
%load = load i64, ptr %allocaN, align 8
%icmp = icmp slt i64 %load, 3
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 [3 x { ptr, i64 }], ptr @field_names.194, 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.195, 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
%loadN = load i64, ptr %allocaN, align 8
switch i64 %loadN, label %fv.default [
i64 0, label %fv.case
i64 1, label %fv.case17
i64 2, label %fv.case20
]
fv.merge: ; preds = %fv.default, %fv.case20, %fv.case17, %fv.case
%fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ %fv.val22, %fv.case20 ], [ undef, %fv.default ]
%callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi)
%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
fv.default: ; preds = %if.merge.131
br label %fv.merge
fv.case: ; preds = %if.merge.131
%fv.field = extractvalue { ptr, i64, i64 } %loadN, 0
%pNi = ptrtoint ptr %fv.field to i64
%fv.val = insertvalue { i64, i64 } { i64 29, i64 undef }, i64 %pNi, 1
br label %fv.merge
fv.case17: ; preds = %if.merge.131
%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.131
%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
}
; Function Attrs: nounwind
define internal { ptr, i64 } @struct_to_string__TrackingAllocator(ptr %0, { { ptr, ptr, ptr }, i64, i64, i64 } %1) #0 {
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.196, i64 17 }, { ptr, i64 } { ptr @str.197, 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.132
while.hdr.132: ; preds = %fv.merge, %entry
%load = load i64, ptr %allocaN, align 8
%icmp = icmp slt i64 %load, 4
br i1 %icmp, label %while.body.133, label %while.exit.134
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.135, label %if.merge.136
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.198, i64 1 })
ret { ptr, i64 } %callN
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.199, i64 2 })
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %if.merge.136
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 [4 x { ptr, i64 }], ptr @field_names.204, 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.205, 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
%loadN = load i64, ptr %allocaN, align 8
switch i64 %loadN, label %fv.default [
i64 0, label %fv.case
i64 1, label %fv.case17
i64 2, label %fv.case20
i64 3, label %fv.case23
]
fv.merge: ; preds = %fv.default, %fv.case23, %fv.case20, %fv.case17, %fv.case
%fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ %fv.val22, %fv.case20 ], [ %fv.val25, %fv.case23 ], [ undef, %fv.default ]
%callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi)
%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.132
fv.default: ; preds = %if.merge.136
br label %fv.merge
fv.case: ; preds = %if.merge.136
%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
%ba.p2i = ptrtoint ptr %ba.tmp to i64
%fv.val = insertvalue { i64, i64 } { i64 20, i64 undef }, i64 %ba.p2i, 1
br label %fv.merge
fv.case17: ; preds = %if.merge.136
%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.136
%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.136
%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
}
; Function Attrs: nounwind
define internal { ptr, i64 } @struct_to_string__Context(ptr %0, { { ptr, ptr, ptr }, ptr } %1) #0 {
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.206, i64 7 }, { ptr, i64 } { ptr @str.207, 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.137
while.hdr.137: ; preds = %fv.merge, %entry
%load = load i64, ptr %allocaN, align 8
%icmp = icmp slt i64 %load, 2
br i1 %icmp, label %while.body.138, label %while.exit.139
while.body.138: ; preds = %while.hdr.137
%loadN = load i64, ptr %allocaN, align 8
%icmpN = icmp sgt i64 %loadN, 0
br i1 %icmpN, label %if.then.140, label %if.merge.141
while.exit.139: ; preds = %while.hdr.137
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.208, i64 1 })
ret { ptr, i64 } %callN
if.then.140: ; preds = %while.body.138
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.209, i64 2 })
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %if.merge.141
if.merge.141: ; preds = %if.then.140, %while.body.138
%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.212, 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.213, 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
%loadN = load i64, ptr %allocaN, align 8
switch i64 %loadN, label %fv.default [
i64 0, label %fv.case
i64 1, label %fv.case17
]
fv.merge: ; preds = %fv.default, %fv.case17, %fv.case
%fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val19, %fv.case17 ], [ undef, %fv.default ]
%callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi)
%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.137
fv.default: ; preds = %if.merge.141
br label %fv.merge
fv.case: ; preds = %if.merge.141
%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
%ba.p2i = ptrtoint ptr %ba.tmp to i64
%fv.val = insertvalue { i64, i64 } { i64 20, i64 undef }, i64 %ba.p2i, 1
br label %fv.merge
fv.case17: ; preds = %if.merge.141
%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
br label %fv.merge
}
; Function Attrs: nounwind
define internal { ptr, i64 } @struct_to_string__ProposedSize(ptr %0, { { float, i1 }, { float, i1 } } %1) #0 {
entry:
%alloca = alloca { { float, i1 }, { float, i1 } }, align 8
store { { float, i1 }, { float, i1 } } %1, ptr %alloca, align 4
%call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.214, i64 12 }, { ptr, i64 } { ptr @str.215, 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.142
while.hdr.142: ; preds = %fv.merge, %entry
%load = load i64, ptr %allocaN, align 8
%icmp = icmp slt i64 %load, 2
br i1 %icmp, label %while.body.143, label %while.exit.144
while.body.143: ; preds = %while.hdr.142
%loadN = load i64, ptr %allocaN, align 8
%icmpN = icmp sgt i64 %loadN, 0
br i1 %icmpN, label %if.then.145, label %if.merge.146
while.exit.144: ; preds = %while.hdr.142
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.216, i64 1 })
ret { ptr, i64 } %callN
if.then.145: ; preds = %while.body.143
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.217, i64 2 })
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %if.merge.146
if.merge.146: ; preds = %if.then.145, %while.body.143
%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.220, 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.221, i64 2 })
store { ptr, i64 } %callN, ptr %allocaN, align 8
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%loadN = load { { float, i1 }, { float, i1 } }, ptr %alloca, align 4
%loadN = load i64, ptr %allocaN, align 8
switch i64 %loadN, label %fv.default [
i64 0, label %fv.case
i64 1, label %fv.case17
]
fv.merge: ; preds = %fv.default, %fv.case17, %fv.case
%fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val21, %fv.case17 ], [ undef, %fv.default ]
%callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi)
%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.142
fv.default: ; preds = %if.merge.146
br label %fv.merge
fv.case: ; preds = %if.merge.146
%fv.field = extractvalue { { float, i1 }, { float, i1 } } %loadN, 0
%ba.tmp = alloca { float, i1 }, align 8
store { float, i1 } %fv.field, ptr %ba.tmp, align 4
%ba.p2i = ptrtoint ptr %ba.tmp to i64
%fv.val = insertvalue { i64, i64 } { i64 36, i64 undef }, i64 %ba.p2i, 1
br label %fv.merge
fv.case17: ; preds = %if.merge.146
%fv.field18 = extractvalue { { float, i1 }, { float, i1 } } %loadN, 1
%ba.tmp19 = alloca { float, i1 }, align 8
store { float, i1 } %fv.field18, ptr %ba.tmp19, align 4
%ba.p2i20 = ptrtoint ptr %ba.tmp19 to i64
%fv.val21 = insertvalue { i64, i64 } { i64 36, i64 undef }, i64 %ba.p2i20, 1
br label %fv.merge
}
; Function Attrs: nounwind
define internal { ptr, i64 } @struct_to_string__Sizable(ptr %0, { ptr, ptr } %1) #0 {
entry:
%alloca = alloca { ptr, ptr }, align 8
store { ptr, ptr } %1, ptr %alloca, align 8
%call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.222, i64 7 }, { ptr, i64 } { ptr @str.223, 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.147
while.hdr.147: ; preds = %fv.merge, %entry
%load = load i64, ptr %allocaN, align 8
%icmp = icmp slt i64 %load, 2
br i1 %icmp, label %while.body.148, label %while.exit.149
while.body.148: ; preds = %while.hdr.147
%loadN = load i64, ptr %allocaN, align 8
%icmpN = icmp sgt i64 %loadN, 0
br i1 %icmpN, label %if.then.150, label %if.merge.151
while.exit.149: ; preds = %while.hdr.147
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.224, i64 1 })
ret { ptr, i64 } %callN
if.then.150: ; preds = %while.body.148
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.225, i64 2 })
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %if.merge.151
if.merge.151: ; preds = %if.then.150, %while.body.148
%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.228, 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.229, i64 2 })
store { ptr, i64 } %callN, ptr %allocaN, align 8
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%loadN = load { ptr, ptr }, ptr %alloca, align 8
%loadN = load i64, ptr %allocaN, align 8
switch i64 %loadN, label %fv.default [
i64 0, label %fv.case
i64 1, label %fv.case17
]
fv.merge: ; preds = %fv.default, %fv.case17, %fv.case
%fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val20, %fv.case17 ], [ undef, %fv.default ]
%callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi)
%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.147
fv.default: ; preds = %if.merge.151
br label %fv.merge
fv.case: ; preds = %if.merge.151
%fv.field = extractvalue { 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.151
%fv.field18 = extractvalue { 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
}
; Function Attrs: nounwind
define internal { ptr, i64 } @struct_to_string____Sizable__Vtable(ptr %0, { ptr } %1) #0 {
entry:
%alloca = alloca { ptr }, align 8
store { ptr } %1, ptr %alloca, align 8
%call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.230, i64 17 }, { ptr, i64 } { ptr @str.231, 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.152
while.hdr.152: ; preds = %fv.merge, %entry
%load = load i64, ptr %allocaN, align 8
%icmp = icmp slt i64 %load, 1
br i1 %icmp, label %while.body.153, label %while.exit.154
while.body.153: ; preds = %while.hdr.152
%loadN = load i64, ptr %allocaN, align 8
%icmpN = icmp sgt i64 %loadN, 0
br i1 %icmpN, label %if.then.155, label %if.merge.156
while.exit.154: ; preds = %while.hdr.152
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.232, i64 1 })
ret { ptr, i64 } %callN
if.then.155: ; preds = %while.body.153
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%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.156
if.merge.156: ; preds = %if.then.155, %while.body.153
%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.235, 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.236, i64 2 })
store { ptr, i64 } %callN, ptr %allocaN, align 8
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%loadN = load { ptr }, ptr %alloca, align 8
%loadN = load i64, ptr %allocaN, align 8
switch i64 %loadN, label %fv.default [
i64 0, label %fv.case
]
fv.merge: ; preds = %fv.default, %fv.case
%fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ undef, %fv.default ]
%callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %fv.phi)
%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.152
fv.default: ; preds = %if.merge.156
br label %fv.merge
fv.case: ; preds = %if.merge.156
%fv.field = extractvalue { 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
}
; Function Attrs: nounwind
define internal { ptr, i64 } @struct_to_string__Widget(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.237, i64 6 }, { ptr, i64 } { ptr @str.238, 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.157
while.hdr.157: ; preds = %if.merge.161, %entry
%load = load i64, ptr %allocaN, align 8
%icmp = icmp slt i64 %load, 0
br i1 %icmp, label %while.body.158, label %while.exit.159
while.body.158: ; preds = %while.hdr.157
%loadN = load i64, ptr %allocaN, align 8
%icmpN = icmp sgt i64 %loadN, 0
br i1 %icmpN, label %if.then.160, label %if.merge.161
while.exit.159: ; preds = %while.hdr.157
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.239, i64 1 })
ret { ptr, i64 } %callN
if.then.160: ; preds = %while.body.158
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.240, i64 2 })
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %if.merge.161
if.merge.161: ; preds = %if.then.160, %while.body.158
%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.241, 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.242, 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.157
}
; Function Attrs: nounwind
define internal { ptr, i64 } @array_to_string__AR_1_Any(ptr %0, [1 x { i64, i64 }] %1) #0 {
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.243, i64 1 }, ptr %allocaN, align 8
%allocaN = alloca i64, align 8
store i64 0, ptr %allocaN, align 8
br label %while.hdr.165
while.hdr.165: ; preds = %if.merge.169, %entry
%load = load i64, ptr %allocaN, align 8
%icmp = icmp slt i64 %load, 1
br i1 %icmp, label %while.body.166, label %while.exit.167
while.body.166: ; preds = %while.hdr.165
%loadN = load i64, ptr %allocaN, align 8
%icmpN = icmp sgt i64 %loadN, 0
br i1 %icmpN, label %if.then.168, label %if.merge.169
while.exit.167: ; preds = %while.hdr.165
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.244, i64 1 })
ret { ptr, i64 } %call
if.then.168: ; preds = %while.body.166
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.245, i64 2 })
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %if.merge.169
if.merge.169: ; preds = %if.then.168, %while.body.166
%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
%ig.tmp = alloca [1 x { i64, i64 }], align 8
store [1 x { i64, i64 }] %loadN, ptr %ig.tmp, align 8
%ig.ptr = getelementptr [1 x { i64, i64 }], ptr %ig.tmp, i64 0, i64 %loadN
%ig.val = load { i64, i64 }, ptr %ig.ptr, align 8
%ba.tmp = alloca { i64, i64 }, align 8
store { i64, i64 } %ig.val, ptr %ba.tmp, align 8
%ba.p2i = ptrtoint ptr %ba.tmp to i64
%ba.val = insertvalue { i64, i64 } { i64 13, i64 undef }, i64 %ba.p2i, 1
%callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %ba.val)
%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.165
}
; Function Attrs: nounwind
define internal { ptr, i64 } @slice_to_string__string(ptr %0, { ptr, i64 } %1) #0 {
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.246, i64 1 }, ptr %allocaN, align 8
%allocaN = alloca i64, align 8
store i64 0, ptr %allocaN, align 8
br label %while.hdr.174
while.hdr.174: ; preds = %if.merge.178, %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.175, label %while.exit.176
while.body.175: ; preds = %while.hdr.174
%loadN = load i64, ptr %allocaN, align 8
%icmpN = icmp sgt i64 %loadN, 0
br i1 %icmpN, label %if.then.177, label %if.merge.178
while.exit.176: ; preds = %while.hdr.174
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.247, i64 1 })
ret { ptr, i64 } %call
if.then.177: ; preds = %while.body.175
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.248, i64 2 })
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %if.merge.178
if.merge.178: ; preds = %if.then.177, %while.body.175
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%loadN = load { ptr, i64 }, ptr %alloca, align 8
%loadN = load i64, ptr %allocaN, align 8
%ig.data = extractvalue { ptr, i64 } %loadN, 0
%ig.ptr = getelementptr { ptr, i64 }, ptr %ig.data, i64 %loadN
%ig.val = load { ptr, i64 }, ptr %ig.ptr, align 8
%ba.tmp = alloca { ptr, i64 }, align 8
store { ptr, i64 } %ig.val, ptr %ba.tmp, align 8
%ba.p2i = ptrtoint ptr %ba.tmp to i64
%ba.val = insertvalue { i64, i64 } { i64 12, i64 undef }, i64 %ba.p2i, 1
%callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %ba.val)
%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.174
}
; Function Attrs: nounwind
define internal { ptr, i64 } @slice_to_string__Any(ptr %0, { ptr, i64 } %1) #0 {
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.249, i64 1 }, ptr %allocaN, align 8
%allocaN = alloca i64, align 8
store i64 0, ptr %allocaN, align 8
br label %while.hdr.179
while.hdr.179: ; preds = %if.merge.183, %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.180, label %while.exit.181
while.body.180: ; preds = %while.hdr.179
%loadN = load i64, ptr %allocaN, align 8
%icmpN = icmp sgt i64 %loadN, 0
br i1 %icmpN, label %if.then.182, label %if.merge.183
while.exit.181: ; preds = %while.hdr.179
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.250, i64 1 })
ret { ptr, i64 } %call
if.then.182: ; preds = %while.body.180
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.251, i64 2 })
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %if.merge.183
if.merge.183: ; preds = %if.then.182, %while.body.180
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%loadN = load { ptr, i64 }, ptr %alloca, align 8
%loadN = load i64, ptr %allocaN, align 8
%ig.data = extractvalue { ptr, i64 } %loadN, 0
%ig.ptr = getelementptr { i64, i64 }, ptr %ig.data, i64 %loadN
%ig.val = load { i64, i64 }, ptr %ig.ptr, align 8
%ba.tmp = alloca { i64, i64 }, align 8
store { i64, i64 } %ig.val, ptr %ba.tmp, align 8
%ba.p2i = ptrtoint ptr %ba.tmp to i64
%ba.val = insertvalue { i64, i64 } { i64 13, i64 undef }, i64 %ba.p2i, 1
%callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %ba.val)
%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.179
}
; Function Attrs: nounwind
define internal { ptr, i64 } @pointer_to_string__ptr_void(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.210, label %if.else.211
if.then.210: ; preds = %entry
br label %if.merge.212
if.else.211: ; 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 5 }, { ptr, i64 } %callN)
br label %if.merge.212
if.merge.212: ; preds = %if.else.211, %if.then.210
%bp = phi { ptr, i64 } [ { ptr @str.252, i64 4 }, %if.then.210 ], [ %callN, %if.else.211 ]
ret { ptr, i64 } %bp
}
; Function Attrs: nounwind
define internal { ptr, i64 } @pointer_to_string__ptr_CAllocator(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.234, label %if.else.235
if.then.234: ; preds = %entry
br label %if.merge.236
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.257, i64 3 }, { ptr, i64 } %call)
%callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.256, i64 11 }, { ptr, i64 } %callN)
br label %if.merge.236
if.merge.236: ; preds = %if.else.235, %if.then.234
%bp = phi { ptr, i64 } [ { ptr @str.255, i64 4 }, %if.then.234 ], [ %callN, %if.else.235 ]
ret { ptr, i64 } %bp
}
; Function Attrs: nounwind
define internal { ptr, i64 } @pointer_to_string__ptr_GPA(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.237, label %if.else.238
if.then.237: ; preds = %entry
br label %if.merge.239
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.260, i64 3 }, { ptr, i64 } %call)
%callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.259, i64 4 }, { ptr, i64 } %callN)
br label %if.merge.239
if.merge.239: ; preds = %if.else.238, %if.then.237
%bp = phi { ptr, i64 } [ { ptr @str.258, i64 4 }, %if.then.237 ], [ %callN, %if.else.238 ]
ret { ptr, i64 } %bp
}
; Function Attrs: nounwind
define internal { ptr, i64 } @pointer_to_string__ptr_ArenaChunk(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.263, i64 3 }, { ptr, i64 } %call)
%callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.262, i64 11 }, { ptr, i64 } %callN)
br label %if.merge.242
if.merge.242: ; preds = %if.else.241, %if.then.240
%bp = phi { ptr, i64 } [ { ptr @str.261, i64 4 }, %if.then.240 ], [ %callN, %if.else.241 ]
ret { ptr, i64 } %bp
}
; Function Attrs: nounwind
define internal { ptr, i64 } @pointer_to_string__ptr_Arena(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.243, label %if.else.244
if.then.243: ; preds = %entry
br label %if.merge.245
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.266, i64 3 }, { ptr, i64 } %call)
%callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.265, i64 6 }, { ptr, i64 } %callN)
br label %if.merge.245
if.merge.245: ; preds = %if.else.244, %if.then.243
%bp = phi { ptr, i64 } [ { ptr @str.264, i64 4 }, %if.then.243 ], [ %callN, %if.else.244 ]
ret { ptr, i64 } %bp
}
; Function Attrs: nounwind
define internal { ptr, i64 } @pointer_to_string__mptr_u8(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
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.246, label %if.else.247
if.then.246: ; preds = %entry
br label %if.merge.248
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.269, i64 3 }, { ptr, i64 } %call)
%callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.268, i64 5 }, { ptr, i64 } %callN)
br label %if.merge.248
if.merge.248: ; preds = %if.else.247, %if.then.246
%bp = phi { ptr, i64 } [ { ptr @str.267, i64 4 }, %if.then.246 ], [ %callN, %if.else.247 ]
ret { ptr, i64 } %bp
}
; Function Attrs: nounwind
define internal { ptr, i64 } @pointer_to_string__ptr_BufAlloc(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.249, label %if.else.250
if.then.249: ; preds = %entry
br label %if.merge.251
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.272, i64 3 }, { ptr, i64 } %call)
%callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.271, i64 9 }, { ptr, i64 } %callN)
br label %if.merge.251
if.merge.251: ; preds = %if.else.250, %if.then.249
%bp = phi { ptr, i64 } [ { ptr @str.270, i64 4 }, %if.then.249 ], [ %callN, %if.else.250 ]
ret { ptr, i64 } %bp
}
; Function Attrs: nounwind
define internal { ptr, i64 } @pointer_to_string__ptr_TrackingAllocator(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.252, label %if.else.253
if.then.252: ; preds = %entry
br label %if.merge.254
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.275, i64 3 }, { ptr, i64 } %call)
%callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.274, i64 18 }, { ptr, i64 } %callN)
br label %if.merge.254
if.merge.254: ; preds = %if.else.253, %if.then.252
%bp = phi { ptr, i64 } [ { ptr @str.273, i64 4 }, %if.then.252 ], [ %callN, %if.else.253 ]
ret { ptr, i64 } %bp
}
; Function Attrs: nounwind
define internal { ptr, i64 } @pointer_to_string__ptr_Widget(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.255, label %if.else.256
if.then.255: ; preds = %entry
br label %if.merge.257
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.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.257
if.merge.257: ; preds = %if.else.256, %if.then.255
%bp = phi { ptr, i64 } [ { ptr @str.276, i64 4 }, %if.then.255 ], [ %callN, %if.else.256 ]
ret { ptr, i64 } %bp
}
; Function Attrs: nounwind
define internal { ptr, i64 } @pointer_to_string__ptr_ptr_CAllocator(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.258, label %if.else.259
if.then.258: ; preds = %entry
br label %if.merge.260
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.281, i64 3 }, { ptr, i64 } %call)
%callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.280, i64 12 }, { ptr, i64 } %callN)
br label %if.merge.260
if.merge.260: ; preds = %if.else.259, %if.then.258
%bp = phi { ptr, i64 } [ { ptr @str.279, i64 4 }, %if.then.258 ], [ %callN, %if.else.259 ]
ret { ptr, i64 } %bp
}
; Function Attrs: nounwind
define internal { ptr, i64 } @pointer_to_string__ptr_s64(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.261, label %if.else.262
if.then.261: ; preds = %entry
br label %if.merge.263
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.284, i64 3 }, { ptr, i64 } %call)
%callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.283, i64 4 }, { ptr, i64 } %callN)
br label %if.merge.263
if.merge.263: ; preds = %if.else.262, %if.then.261
%bp = phi { ptr, i64 } [ { ptr @str.282, i64 4 }, %if.then.261 ], [ %callN, %if.else.262 ]
ret { ptr, i64 } %bp
}
; Function Attrs: nounwind
define internal { ptr, i64 } @pointer_to_string__ptr_ptr_void(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.264, label %if.else.265
if.then.264: ; preds = %entry
br label %if.merge.266
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.287, i64 3 }, { ptr, i64 } %call)
%callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.286, i64 6 }, { ptr, i64 } %callN)
br label %if.merge.266
if.merge.266: ; preds = %if.else.265, %if.then.264
%bp = phi { ptr, i64 } [ { ptr @str.285, i64 4 }, %if.then.264 ], [ %callN, %if.else.265 ]
ret { ptr, i64 } %bp
}
; Function Attrs: nounwind
define internal { ptr, i64 } @pointer_to_string__ptr_string(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.267, label %if.else.268
if.then.267: ; preds = %entry
br label %if.merge.269
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.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.269
if.merge.269: ; preds = %if.else.268, %if.then.267
%bp = phi { ptr, i64 } [ { ptr @str.288, i64 4 }, %if.then.267 ], [ %callN, %if.else.268 ]
ret { ptr, i64 } %bp
}
; Function Attrs: nounwind
define internal { ptr, i64 } @pointer_to_string__ptr_Any(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.270, label %if.else.271
if.then.270: ; preds = %entry
br label %if.merge.272
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.293, i64 3 }, { ptr, i64 } %call)
%callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.292, i64 4 }, { ptr, i64 } %callN)
br label %if.merge.272
if.merge.272: ; preds = %if.else.271, %if.then.270
%bp = phi { ptr, i64 } [ { ptr @str.291, i64 4 }, %if.then.270 ], [ %callN, %if.else.271 ]
ret { ptr, i64 } %bp
}
; Function Attrs: nounwind
define internal { ptr, i64 } @pointer_to_string__ptr_SL_Any(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.273, label %if.else.274
if.then.273: ; preds = %entry
br label %if.merge.275
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.296, i64 3 }, { ptr, i64 } %call)
%callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.295, i64 6 }, { ptr, i64 } %callN)
br label %if.merge.275
if.merge.275: ; preds = %if.else.274, %if.then.273
%bp = phi { ptr, i64 } [ { ptr @str.294, i64 4 }, %if.then.273 ], [ %callN, %if.else.274 ]
ret { ptr, i64 } %bp
}
; Function Attrs: nounwind
define internal { ptr, i64 } @pointer_to_string__ptr_u8(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.276, label %if.else.277
if.then.276: ; preds = %entry
br label %if.merge.278
if.else.277: ; 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.299, i64 3 }, { ptr, i64 } %call)
%callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.298, i64 3 }, { ptr, i64 } %callN)
br label %if.merge.278
if.merge.278: ; preds = %if.else.277, %if.then.276
%bp = phi { ptr, i64 } [ { ptr @str.297, i64 4 }, %if.then.276 ], [ %callN, %if.else.277 ]
ret { ptr, i64 } %bp
}
; Function Attrs: nounwind
define internal { ptr, i64 } @pointer_to_string__ptr_bool(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.279, label %if.else.280
if.then.279: ; preds = %entry
br label %if.merge.281
if.else.280: ; 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.302, i64 3 }, { ptr, i64 } %call)
%callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.301, i64 5 }, { ptr, i64 } %callN)
br label %if.merge.281
if.merge.281: ; preds = %if.else.280, %if.then.279
%bp = phi { ptr, i64 } [ { ptr @str.300, i64 4 }, %if.then.279 ], [ %callN, %if.else.280 ]
ret { ptr, i64 } %bp
}
; Function Attrs: nounwind
define internal { ptr, i64 } @pointer_to_string__ptr_ProposedSize(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.282, label %if.else.283
if.then.282: ; preds = %entry
br label %if.merge.284
if.else.283: ; 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.305, i64 3 }, { ptr, i64 } %call)
%callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.304, i64 13 }, { ptr, i64 } %callN)
br label %if.merge.284
if.merge.284: ; preds = %if.else.283, %if.then.282
%bp = phi { ptr, i64 } [ { ptr @str.303, i64 4 }, %if.then.282 ], [ %callN, %if.else.283 ]
ret { ptr, i64 } %bp
}
; Function Attrs: nounwind
define internal { ptr, i64 } @pointer_to_string__ptr_f32(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.285, label %if.else.286
if.then.285: ; preds = %entry
br label %if.merge.287
if.else.286: ; 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.308, i64 3 }, { ptr, i64 } %call)
%callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.307, i64 4 }, { ptr, i64 } %callN)
br label %if.merge.287
if.merge.287: ; preds = %if.else.286, %if.then.285
%bp = phi { ptr, i64 } [ { ptr @str.306, i64 4 }, %if.then.285 ], [ %callN, %if.else.286 ]
ret { ptr, i64 } %bp
}
; Function Attrs: nounwind
define internal { ptr, i64 } @pointer_to_string__ptr_f64(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.288, label %if.else.289
if.then.288: ; preds = %entry
br label %if.merge.290
if.else.289: ; 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.311, i64 3 }, { ptr, i64 } %call)
%callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.310, i64 4 }, { ptr, i64 } %callN)
br label %if.merge.290
if.merge.290: ; preds = %if.else.289, %if.then.288
%bp = phi { ptr, i64 } [ { ptr @str.309, i64 4 }, %if.then.288 ], [ %callN, %if.else.289 ]
ret { ptr, i64 } %bp
}
; Function Attrs: nounwind
define internal { ptr, i64 } @pointer_to_string__ptr_AR_1_Any(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.291, label %if.else.292
if.then.291: ; preds = %entry
br label %if.merge.293
if.else.292: ; 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.314, i64 3 }, { ptr, i64 } %call)
%callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.313, i64 7 }, { ptr, i64 } %callN)
br label %if.merge.293
if.merge.293: ; preds = %if.else.292, %if.then.291
%bp = phi { ptr, i64 } [ { ptr @str.312, i64 4 }, %if.then.291 ], [ %callN, %if.else.292 ]
ret { ptr, i64 } %bp
}
; Function Attrs: nounwind
define internal { ptr, i64 } @pointer_to_string__ptr_Sizable(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.294, label %if.else.295
if.then.294: ; preds = %entry
br label %if.merge.296
if.else.295: ; 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.317, i64 3 }, { ptr, i64 } %call)
%callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.316, i64 8 }, { ptr, i64 } %callN)
br label %if.merge.296
if.merge.296: ; preds = %if.else.295, %if.then.294
%bp = phi { ptr, i64 } [ { ptr @str.315, i64 4 }, %if.then.294 ], [ %callN, %if.else.295 ]
ret { ptr, i64 } %bp
}
; Function Attrs: nounwind
define internal { ptr, i64 } @pointer_to_string__ptr_ptr_Widget(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.297, label %if.else.298
if.then.297: ; preds = %entry
br label %if.merge.299
if.else.298: ; 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.320, i64 3 }, { ptr, i64 } %call)
%callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.319, i64 8 }, { ptr, i64 } %callN)
br label %if.merge.299
if.merge.299: ; preds = %if.else.298, %if.then.297
%bp = phi { ptr, i64 } [ { ptr @str.318, i64 4 }, %if.then.297 ], [ %callN, %if.else.298 ]
ret { ptr, i64 } %bp
}
; Function Attrs: nounwind
define internal { ptr, i64 } @pointer_to_string__ptr___Sizable__Vtable(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.300, label %if.else.301
if.then.300: ; preds = %entry
br label %if.merge.302
if.else.301: ; 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.323, i64 3 }, { ptr, i64 } %call)
%callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.322, i64 18 }, { ptr, i64 } %callN)
br label %if.merge.302
if.merge.302: ; preds = %if.else.301, %if.then.300
%bp = phi { ptr, i64 } [ { ptr @str.321, i64 4 }, %if.then.300 ], [ %callN, %if.else.301 ]
ret { ptr, i64 } %bp
}
; Function Attrs: nounwind
define internal { ptr, i64 } @optional_to_string__opt_f32(ptr %0, { float, i1 } %1) #0 {
entry:
%alloca = alloca { float, i1 }, align 8
store { float, i1 } %1, ptr %alloca, align 4
%load = load { float, i1 }, ptr %alloca, align 4
%oh.has = extractvalue { float, i1 } %load, 1
%lnot = xor i1 %oh.has, true
br i1 %lnot, label %if.then.306, label %if.merge.307
if.then.306: ; preds = %entry
ret { ptr, i64 } { ptr @str.324, i64 4 }
if.merge.307: ; preds = %entry
%loadN = load { float, i1 }, ptr %alloca, align 4
%ou.val = extractvalue { float, i1 } %loadN, 0
%fNi32 = bitcast float %ou.val to i32
%zN = zext i32 %fNi32 to i64
%ba.val = insertvalue { i64, i64 } { i64 10, i64 undef }, i64 %zN, 1
%call = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %ba.val)
ret { ptr, i64 } %call
}
declare i64 @write(i32, ptr, i64)