Files
sx/examples/expected/0201-generics-generic-struct.ir
agra 91e99f80c7 test(ir): lock generic substitution + mono keys before A4.1 extraction (A4.1 scaffolding step 1)
Test-first scaffolding ahead of extracting src/ir/generics.zig — no code change
to the refactor targets (buildTypeBindings / mangleGenericName / monomorphize* /
inferGenericReturnType / mangleTypeName).

Adds the first non-FFI generic/pack .ir snapshots (closing the ARCH-SAFETY §3
gap for this phase), each captured surgically via `sx ir | normalize_ir`,
path-free and idempotent:
- 0200-generics-generic            generic fn, type-param inference + mono
- 0201-generics-generic-struct     generic struct instantiation
- 0507-packs-pack-mono-dedup       mono-key dedup (same shape => one mono)
- 0518-packs-pack-value-dispatch   pack value dispatch (monomorphizePackFn)
- 0524-packs-generic-fn-pack-state-leak  pack-state isolation (issue-0048/0050
                                         class; guards the future scoped-env change)

Adds 2 unit tests via the existing public surface (no new pub exposure,
mirroring the A3.2 sub-step-1 cadence):
- mangleTypeName: pins the mono-key fragment encoding per type shape
  (s64 / ptr_X / opt_X / SL_X / mptr_X / AR_n_X / vec_n_X / struct-name / tu_X_Y).
- inferGenericReturnType: explicit type-arg path binds $T and resolves the
  -> T return (pair(s64,..) => s64, pair(f64,..) => f64).

The internal substitution/mono-key unit tests (comptime-value mangle,
buildTypeBindings strategies, scoped-env isolation) land with the generics.zig
extraction in sub-step 2, as A3.2's plan-object tests landed with CallPlan.

zig build, zig build test, tests/run_examples.sh (357/0) all green.
2026-06-02 21:05:33 +03:00

5030 lines
234 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 }
@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 [8 x i8] c"[16]f32\00"
@tn.str.42 = private constant [5 x i8] c"Mat4\00"
@tn.str.43 = private constant [5 x i8] c"Vec2\00"
@tn.str.44 = private constant [14 x i8] c"Vector(3,f32)\00"
@tn.str.45 = private constant [12 x i8] c"Vec__3__f32\00"
@tn.str.46 = private constant [5 x i8] c"Vec3\00"
@tn.str.47 = private constant [13 x i8] c"Complex__u32\00"
@tn.str.48 = private constant [4 x i8] c"Foo\00"
@tn.str.49 = private constant [13 x i8] c"**CAllocator\00"
@tn.str.50 = private constant [5 x i8] c"*s64\00"
@tn.str.51 = private constant [7 x i8] c"**void\00"
@tn.str.52 = private constant [6 x i8] c"*Vec3\00"
@tn.str.53 = private constant [8 x i8] c"*string\00"
@tn.str.54 = private constant [6 x i8] c"[]Any\00"
@tn.str.55 = private constant [5 x i8] c"*Any\00"
@tn.str.56 = private constant [7 x i8] c"[1]Any\00"
@tn.str.57 = private constant [8 x i8] c"*[1]Any\00"
@tn.str.58 = private constant [7 x i8] c"*[]Any\00"
@tn.str.59 = private constant [4 x i8] c"*u8\00"
@tn.str.60 = private constant [6 x i8] c"*bool\00"
@tn.str.61 = private constant [5 x i8] c"*f32\00"
@tn.str.62 = private constant [15 x i8] c"*Vector(3,f32)\00"
@tn.str.63 = private constant [7 x i8] c"[5]f32\00"
@tn.str.64 = private constant [8 x i8] c"*[5]f32\00"
@tn.str.65 = private constant [5 x i8] c"*Foo\00"
@tn.str.66 = private constant [5 x i8] c"*f64\00"
@tn.str.67 = private constant [8 x i8] c"Sx__f32\00"
@tn.str.68 = private constant [9 x i8] c"*Sx__f32\00"
@tn.str.69 = private constant [17 x i8] c"*Source_Location\00"
@tn.str.70 = private constant [11 x i8] c"*Allocator\00"
@tn.str.71 = private constant [9 x i8] c"*Context\00"
@tn.str.72 = private constant [6 x i8] c"*Mat4\00"
@tn.str.73 = private constant [6 x i8] c"*Vec2\00"
@tn.str.74 = private constant [13 x i8] c"*Vec__3__f32\00"
@tn.str.75 = private constant [14 x i8] c"*Complex__u32\00"
@tn.str.76 = private constant [9 x i8] c"*[16]f32\00"
@tn.str.77 = private constant [10 x i8] c"*[]string\00"
@tn.str.78 = private constant [6 x i8] c"**GPA\00"
@tn.str.79 = private constant [13 x i8] c"**ArenaChunk\00"
@tn.str.80 = private constant [8 x i8] c"**Arena\00"
@tn.str.81 = private constant [7 x i8] c"*[*]u8\00"
@tn.str.82 = private constant [11 x i8] c"**BufAlloc\00"
@tn.str.83 = private constant [20 x i8] c"**TrackingAllocator\00"
@tn.str.84 = private constant [14 x i8] c"***CAllocator\00"
@tn.str.85 = private constant [6 x i8] c"**s64\00"
@tn.str.86 = private constant [8 x i8] c"***void\00"
@tn.str.87 = private constant [7 x i8] c"**Vec3\00"
@tn.str.88 = private constant [9 x i8] c"**string\00"
@tn.str.89 = private constant [6 x i8] c"**Any\00"
@tn.str.90 = private constant [9 x i8] c"**[1]Any\00"
@tn.str.91 = private constant [8 x i8] c"**[]Any\00"
@tn.str.92 = private constant [5 x i8] c"**u8\00"
@tn.str.93 = private constant [7 x i8] c"**bool\00"
@tn.str.94 = private constant [6 x i8] c"**f32\00"
@tn.str.95 = private constant [16 x i8] c"**Vector(3,f32)\00"
@tn.str.96 = private constant [9 x i8] c"**[5]f32\00"
@tn.str.97 = private constant [6 x i8] c"**Foo\00"
@tn.str.98 = private constant [6 x i8] c"**f64\00"
@tn.str.99 = private constant [10 x i8] c"**Sx__f32\00"
@__sx_type_names = private constant [95 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 7 }, { ptr, i64 } { ptr @tn.str.42, i64 4 }, { ptr, i64 } { ptr @tn.str.43, i64 4 }, { ptr, i64 } { ptr @tn.str.44, i64 13 }, { ptr, i64 } { ptr @tn.str.45, i64 11 }, { ptr, i64 } { ptr @tn.str.46, i64 4 }, { ptr, i64 } { ptr @tn.str.47, i64 12 }, { ptr, i64 } { ptr @tn.str.48, i64 3 }, { ptr, i64 } { ptr @tn.str.49, i64 12 }, { ptr, i64 } { ptr @tn.str.50, i64 4 }, { ptr, i64 } { ptr @tn.str.51, i64 6 }, { ptr, i64 } { ptr @tn.str.52, i64 5 }, { ptr, i64 } { ptr @tn.str.53, i64 7 }, { ptr, i64 } { ptr @tn.str.54, i64 5 }, { ptr, i64 } { ptr @tn.str.55, i64 4 }, { ptr, i64 } { ptr @tn.str.56, i64 6 }, { ptr, i64 } { ptr @tn.str.57, i64 7 }, { ptr, i64 } { ptr @tn.str.58, i64 6 }, { ptr, i64 } { ptr @tn.str.59, i64 3 }, { ptr, i64 } { ptr @tn.str.60, i64 5 }, { ptr, i64 } { ptr @tn.str.61, i64 4 }, { ptr, i64 } { ptr @tn.str.62, i64 14 }, { ptr, i64 } { ptr @tn.str.63, i64 6 }, { ptr, i64 } { ptr @tn.str.64, i64 7 }, { ptr, i64 } { ptr @tn.str.65, i64 4 }, { ptr, i64 } { ptr @tn.str.66, i64 4 }, { ptr, i64 } { ptr @tn.str.67, i64 7 }, { ptr, i64 } { ptr @tn.str.68, i64 8 }, { ptr, i64 } { ptr @tn.str.69, i64 16 }, { ptr, i64 } { ptr @tn.str.70, i64 10 }, { ptr, i64 } { ptr @tn.str.71, i64 8 }, { ptr, i64 } { ptr @tn.str.72, i64 5 }, { ptr, i64 } { ptr @tn.str.73, i64 5 }, { ptr, i64 } { ptr @tn.str.74, i64 12 }, { ptr, i64 } { ptr @tn.str.75, i64 13 }, { ptr, i64 } { ptr @tn.str.76, i64 8 }, { ptr, i64 } { ptr @tn.str.77, i64 9 }, { ptr, i64 } { ptr @tn.str.78, i64 5 }, { ptr, i64 } { ptr @tn.str.79, i64 12 }, { ptr, i64 } { ptr @tn.str.80, i64 7 }, { ptr, i64 } { ptr @tn.str.81, i64 6 }, { ptr, i64 } { ptr @tn.str.82, i64 10 }, { ptr, i64 } { ptr @tn.str.83, i64 19 }, { ptr, i64 } { ptr @tn.str.84, i64 13 }, { ptr, i64 } { ptr @tn.str.85, i64 5 }, { ptr, i64 } { ptr @tn.str.86, i64 7 }, { ptr, i64 } { ptr @tn.str.87, i64 6 }, { ptr, i64 } { ptr @tn.str.88, i64 8 }, { ptr, i64 } { ptr @tn.str.89, i64 5 }, { ptr, i64 } { ptr @tn.str.90, i64 8 }, { ptr, i64 } { ptr @tn.str.91, i64 7 }, { ptr, i64 } { ptr @tn.str.92, i64 4 }, { ptr, i64 } { ptr @tn.str.93, i64 6 }, { ptr, i64 } { ptr @tn.str.94, i64 5 }, { ptr, i64 } { ptr @tn.str.95, i64 15 }, { ptr, i64 } { ptr @tn.str.96, i64 8 }, { ptr, i64 } { ptr @tn.str.97, i64 5 }, { ptr, i64 } { ptr @tn.str.98, i64 5 }, { ptr, i64 } { ptr @tn.str.99, i64 9 }]
@str.100 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1
@str.101 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1
@str.102 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1
@str.103 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1
@str.104 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1
@str.105 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1
@str.106 = private unnamed_addr constant [15 x i8] c"result := \22\22; \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 [44 x i8] c"result = concat(result, any_to_string(args[\00", align 1
@str.111 = private unnamed_addr constant [6 x i8] c"])); \00", align 1
@str.112 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1
@str.113 = private unnamed_addr constant [3 x i8] c", \00", align 1
@str.114 = private unnamed_addr constant [5 x i8] c")); \00", align 1
@str.115 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1
@str.116 = private unnamed_addr constant [3 x i8] c", \00", align 1
@str.117 = private unnamed_addr constant [5 x i8] c")); \00", align 1
@str.118 = private unnamed_addr constant [37 x i8] c"result = concat(result, substr(fmt, \00", align 1
@str.119 = private unnamed_addr constant [3 x i8] c", \00", align 1
@str.120 = private unnamed_addr constant [5 x i8] c")); \00", align 1
@str.121 = private unnamed_addr constant [8 x i8] c"v1: {}\0A\00", align 1
@str.122 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1
@str.123 = private unnamed_addr constant [8 x i8] c"v1: {}\0A\00", align 1
@str.124 = private unnamed_addr constant [8 x i8] c"v2: {}\0A\00", align 1
@str.125 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1
@str.126 = private unnamed_addr constant [8 x i8] c"v2: {}\0A\00", align 1
@str.127 = private unnamed_addr constant [10 x i8] c"buff: {}\0A\00", align 1
@str.128 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1
@str.129 = private unnamed_addr constant [10 x i8] c"buff: {}\0A\00", align 1
@str.130 = private unnamed_addr constant [10 x i8] c"comp: {}\0A\00", align 1
@str.131 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1
@str.132 = private unnamed_addr constant [10 x i8] c"comp: {}\0A\00", align 1
@str.133 = private unnamed_addr constant [9 x i8] c"add: {}\0A\00", align 1
@str.134 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1
@str.135 = private unnamed_addr constant [9 x i8] c"add: {}\0A\00", align 1
@str.136 = private unnamed_addr constant [10 x i8] c"v2.x: {}\0A\00", align 1
@str.137 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1
@str.138 = private unnamed_addr constant [10 x i8] c"v2.x: {}\0A\00", align 1
@str.139 = private unnamed_addr constant [11 x i8] c"v2[1]: {}\0A\00", align 1
@str.140 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1
@str.141 = private unnamed_addr constant [11 x i8] c"v2[1]: {}\0A\00", align 1
@str.142 = private unnamed_addr constant [12 x i8] c"scaled: {}\0A\00", align 1
@str.143 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1
@str.144 = private unnamed_addr constant [12 x i8] c"scaled: {}\0A\00", align 1
@str.145 = private unnamed_addr constant [9 x i8] c"neg: {}\0A\00", align 1
@str.146 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1
@str.147 = private unnamed_addr constant [9 x i8] c"neg: {}\0A\00", align 1
@str.148 = private unnamed_addr constant [13 x i8] c"sqrt(9): {}\0A\00", align 1
@str.149 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1
@str.150 = private unnamed_addr constant [13 x i8] c"sqrt(9): {}\0A\00", align 1
@str.151 = private unnamed_addr constant [4 x i8] c"{}\0A\00", align 1
@str.152 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1
@str.153 = private unnamed_addr constant [4 x i8] c"{}\0A\00", align 1
@str.154 = private unnamed_addr constant [4 x i8] c"{}\0A\00", align 1
@str.155 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1
@str.156 = private unnamed_addr constant [4 x i8] c"{}\0A\00", align 1
@str.157 = private unnamed_addr constant [16 x i8] c"Source_Location\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
@fld.str = private constant [5 x i8] c"file\00"
@fld.str.161 = private constant [5 x i8] c"line\00"
@fld.str.162 = private constant [4 x i8] c"col\00"
@fld.str.163 = 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.161, i64 4 }, { ptr, i64 } { ptr @fld.str.162, i64 3 }, { ptr, i64 } { ptr @fld.str.163, i64 4 }]
@str.164 = private unnamed_addr constant [3 x i8] c": \00", align 1
@str.165 = private unnamed_addr constant [10 x i8] c"Allocator\00", align 1
@str.166 = private unnamed_addr constant [2 x i8] c"{\00", align 1
@str.167 = private unnamed_addr constant [2 x i8] c"}\00", align 1
@str.168 = private unnamed_addr constant [3 x i8] c", \00", align 1
@fld.str.169 = private constant [4 x i8] c"ctx\00"
@fld.str.170 = private constant [6 x i8] c"alloc\00"
@fld.str.171 = private constant [8 x i8] c"dealloc\00"
@field_names.172 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.169, i64 3 }, { ptr, i64 } { ptr @fld.str.170, i64 5 }, { ptr, i64 } { ptr @fld.str.171, i64 7 }]
@str.173 = private unnamed_addr constant [3 x i8] c": \00", align 1
@str.174 = private unnamed_addr constant [11 x i8] c"CAllocator\00", align 1
@str.175 = private unnamed_addr constant [2 x i8] c"{\00", align 1
@str.176 = private unnamed_addr constant [2 x i8] c"}\00", align 1
@str.177 = private unnamed_addr constant [3 x i8] c", \00", align 1
@field_names.178 = private constant [0 x { ptr, i64 }] zeroinitializer
@str.179 = private unnamed_addr constant [3 x i8] c": \00", align 1
@str.180 = private unnamed_addr constant [4 x i8] c"GPA\00", align 1
@str.181 = private unnamed_addr constant [2 x i8] c"{\00", align 1
@str.182 = private unnamed_addr constant [2 x i8] c"}\00", align 1
@str.183 = private unnamed_addr constant [3 x i8] c", \00", align 1
@fld.str.184 = private constant [12 x i8] c"alloc_count\00"
@field_names.185 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.184, i64 11 }]
@str.186 = private unnamed_addr constant [3 x i8] c": \00", align 1
@str.187 = private unnamed_addr constant [11 x i8] c"ArenaChunk\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 [5 x i8] c"next\00"
@fld.str.192 = private constant [4 x i8] c"cap\00"
@field_names.193 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.191, i64 4 }, { ptr, i64 } { ptr @fld.str.192, i64 3 }]
@str.194 = private unnamed_addr constant [3 x i8] c": \00", align 1
@str.195 = private unnamed_addr constant [6 x i8] c"Arena\00", align 1
@str.196 = private unnamed_addr constant [2 x i8] c"{\00", align 1
@str.197 = private unnamed_addr constant [2 x i8] c"}\00", align 1
@str.198 = private unnamed_addr constant [3 x i8] c", \00", align 1
@fld.str.199 = private constant [6 x i8] c"first\00"
@fld.str.200 = private constant [10 x i8] c"end_index\00"
@fld.str.201 = private constant [7 x i8] c"parent\00"
@field_names.202 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.199, i64 5 }, { ptr, i64 } { ptr @fld.str.200, i64 9 }, { ptr, i64 } { ptr @fld.str.201, i64 6 }]
@str.203 = private unnamed_addr constant [3 x i8] c": \00", align 1
@str.204 = private unnamed_addr constant [9 x i8] c"BufAlloc\00", align 1
@str.205 = private unnamed_addr constant [2 x i8] c"{\00", align 1
@str.206 = private unnamed_addr constant [2 x i8] c"}\00", align 1
@str.207 = private unnamed_addr constant [3 x i8] c", \00", align 1
@fld.str.208 = private constant [4 x i8] c"buf\00"
@fld.str.209 = private constant [4 x i8] c"len\00"
@fld.str.210 = private constant [4 x i8] c"pos\00"
@field_names.211 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.208, i64 3 }, { ptr, i64 } { ptr @fld.str.209, i64 3 }, { ptr, i64 } { ptr @fld.str.210, i64 3 }]
@str.212 = private unnamed_addr constant [3 x i8] c": \00", align 1
@str.213 = private unnamed_addr constant [18 x i8] c"TrackingAllocator\00", align 1
@str.214 = private unnamed_addr constant [2 x i8] c"{\00", align 1
@str.215 = private unnamed_addr constant [2 x i8] c"}\00", align 1
@str.216 = private unnamed_addr constant [3 x i8] c", \00", align 1
@fld.str.217 = private constant [7 x i8] c"parent\00"
@fld.str.218 = private constant [12 x i8] c"alloc_count\00"
@fld.str.219 = private constant [14 x i8] c"dealloc_count\00"
@fld.str.220 = private constant [18 x i8] c"total_alloc_bytes\00"
@field_names.221 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.217, i64 6 }, { ptr, i64 } { ptr @fld.str.218, i64 11 }, { ptr, i64 } { ptr @fld.str.219, i64 13 }, { ptr, i64 } { ptr @fld.str.220, i64 17 }]
@str.222 = private unnamed_addr constant [3 x i8] c": \00", align 1
@str.223 = private unnamed_addr constant [8 x i8] c"Context\00", align 1
@str.224 = private unnamed_addr constant [2 x i8] c"{\00", align 1
@str.225 = private unnamed_addr constant [2 x i8] c"}\00", align 1
@str.226 = private unnamed_addr constant [3 x i8] c", \00", align 1
@fld.str.227 = private constant [10 x i8] c"allocator\00"
@fld.str.228 = private constant [5 x i8] c"data\00"
@field_names.229 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.227, i64 9 }, { ptr, i64 } { ptr @fld.str.228, i64 4 }]
@str.230 = private unnamed_addr constant [3 x i8] c": \00", align 1
@str.231 = private unnamed_addr constant [5 x i8] c"Mat4\00", align 1
@str.232 = private unnamed_addr constant [2 x i8] c"{\00", align 1
@str.233 = private unnamed_addr constant [2 x i8] c"}\00", align 1
@str.234 = private unnamed_addr constant [3 x i8] c", \00", align 1
@fld.str.235 = private constant [5 x i8] c"data\00"
@field_names.236 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.235, i64 4 }]
@str.237 = private unnamed_addr constant [3 x i8] c": \00", align 1
@str.238 = private unnamed_addr constant [5 x i8] c"Vec2\00", align 1
@str.239 = private unnamed_addr constant [2 x i8] c"{\00", align 1
@str.240 = private unnamed_addr constant [2 x i8] c"}\00", align 1
@str.241 = private unnamed_addr constant [3 x i8] c", \00", align 1
@fld.str.242 = private constant [2 x i8] c"x\00"
@fld.str.243 = private constant [2 x i8] c"y\00"
@field_names.244 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.242, i64 1 }, { ptr, i64 } { ptr @fld.str.243, i64 1 }]
@str.245 = private unnamed_addr constant [3 x i8] c": \00", align 1
@str.246 = private unnamed_addr constant [12 x i8] c"Vec__3__f32\00", align 1
@str.247 = private unnamed_addr constant [2 x i8] c"{\00", align 1
@str.248 = private unnamed_addr constant [2 x i8] c"}\00", align 1
@str.249 = private unnamed_addr constant [3 x i8] c", \00", align 1
@fld.str.250 = private constant [5 x i8] c"data\00"
@field_names.251 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.250, i64 4 }]
@str.252 = private unnamed_addr constant [3 x i8] c": \00", align 1
@str.253 = private unnamed_addr constant [5 x i8] c"Vec3\00", align 1
@str.254 = private unnamed_addr constant [2 x i8] c"{\00", align 1
@str.255 = private unnamed_addr constant [2 x i8] c"}\00", align 1
@str.256 = private unnamed_addr constant [3 x i8] c", \00", align 1
@fld.str.257 = private constant [5 x i8] c"data\00"
@field_names.258 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.257, i64 4 }]
@str.259 = private unnamed_addr constant [3 x i8] c": \00", align 1
@str.260 = private unnamed_addr constant [13 x i8] c"Complex__u32\00", align 1
@str.261 = private unnamed_addr constant [2 x i8] c"{\00", align 1
@str.262 = private unnamed_addr constant [2 x i8] c"}\00", align 1
@str.263 = private unnamed_addr constant [3 x i8] c", \00", align 1
@fld.str.264 = private constant [6 x i8] c"value\00"
@fld.str.265 = private constant [6 x i8] c"count\00"
@field_names.266 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.264, i64 5 }, { ptr, i64 } { ptr @fld.str.265, i64 5 }]
@str.267 = private unnamed_addr constant [3 x i8] c": \00", align 1
@str.268 = private unnamed_addr constant [4 x i8] c"Foo\00", align 1
@str.269 = private unnamed_addr constant [2 x i8] c"{\00", align 1
@str.270 = private unnamed_addr constant [2 x i8] c"}\00", align 1
@str.271 = private unnamed_addr constant [3 x i8] c", \00", align 1
@fld.str.272 = private constant [6 x i8] c"value\00"
@fld.str.273 = private constant [6 x i8] c"count\00"
@field_names.274 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.272, i64 5 }, { ptr, i64 } { ptr @fld.str.273, i64 5 }]
@str.275 = private unnamed_addr constant [3 x i8] c": \00", align 1
@str.276 = private unnamed_addr constant [2 x i8] c".\00", align 1
@fld.str.277 = private constant [8 x i8] c"counter\00"
@fld.str.278 = private constant [5 x i8] c"user\00"
@field_names.279 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.277, i64 7 }, { ptr, i64 } { ptr @fld.str.278, i64 4 }]
@str.280 = private unnamed_addr constant [2 x i8] c"(\00", align 1
@str.281 = private unnamed_addr constant [2 x i8] c")\00", align 1
@str.282 = private unnamed_addr constant [2 x i8] c"[\00", align 1
@str.283 = private unnamed_addr constant [2 x i8] c"]\00", align 1
@str.284 = private unnamed_addr constant [3 x i8] c", \00", align 1
@str.285 = private unnamed_addr constant [2 x i8] c"[\00", align 1
@str.286 = private unnamed_addr constant [2 x i8] c"]\00", align 1
@str.287 = private unnamed_addr constant [3 x i8] c", \00", align 1
@str.288 = private unnamed_addr constant [2 x i8] c"[\00", align 1
@str.289 = private unnamed_addr constant [2 x i8] c"]\00", align 1
@str.290 = private unnamed_addr constant [3 x i8] c", \00", align 1
@str.291 = private unnamed_addr constant [2 x i8] c"[\00", align 1
@str.292 = private unnamed_addr constant [2 x i8] c"]\00", align 1
@str.293 = private unnamed_addr constant [3 x i8] c", \00", align 1
@str.294 = private unnamed_addr constant [2 x i8] c"[\00", align 1
@str.295 = private unnamed_addr constant [2 x i8] c"]\00", align 1
@str.296 = private unnamed_addr constant [3 x i8] c", \00", align 1
@str.297 = private unnamed_addr constant [2 x i8] c"[\00", align 1
@str.298 = private unnamed_addr constant [2 x i8] c"]\00", align 1
@str.299 = private unnamed_addr constant [3 x i8] c", \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"*void\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 [12 x i8] c"*CAllocator\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"*GPA\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 [12 x i8] c"*ArenaChunk\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 [7 x i8] c"*Arena\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 [6 x i8] c"[*]u8\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 [10 x i8] c"*BufAlloc\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"*TrackingAllocator\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
@str.325 = private unnamed_addr constant [13 x i8] c"**CAllocator\00", align 1
@str.326 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1
@str.327 = private unnamed_addr constant [5 x i8] c"null\00", align 1
@str.328 = private unnamed_addr constant [5 x i8] c"*s64\00", align 1
@str.329 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1
@str.330 = private unnamed_addr constant [5 x i8] c"null\00", align 1
@str.331 = private unnamed_addr constant [7 x i8] c"**void\00", align 1
@str.332 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1
@str.333 = private unnamed_addr constant [5 x i8] c"null\00", align 1
@str.334 = private unnamed_addr constant [6 x i8] c"*Vec3\00", align 1
@str.335 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1
@str.336 = private unnamed_addr constant [5 x i8] c"null\00", align 1
@str.337 = private unnamed_addr constant [8 x i8] c"*string\00", align 1
@str.338 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1
@str.339 = private unnamed_addr constant [5 x i8] c"null\00", align 1
@str.340 = private unnamed_addr constant [5 x i8] c"*Any\00", align 1
@str.341 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1
@str.342 = private unnamed_addr constant [5 x i8] c"null\00", align 1
@str.343 = private unnamed_addr constant [8 x i8] c"*[1]Any\00", align 1
@str.344 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1
@str.345 = private unnamed_addr constant [5 x i8] c"null\00", align 1
@str.346 = private unnamed_addr constant [7 x i8] c"*[]Any\00", align 1
@str.347 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1
@str.348 = private unnamed_addr constant [5 x i8] c"null\00", align 1
@str.349 = private unnamed_addr constant [4 x i8] c"*u8\00", align 1
@str.350 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1
@str.351 = private unnamed_addr constant [5 x i8] c"null\00", align 1
@str.352 = private unnamed_addr constant [6 x i8] c"*bool\00", align 1
@str.353 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1
@str.354 = private unnamed_addr constant [5 x i8] c"null\00", align 1
@str.355 = private unnamed_addr constant [5 x i8] c"*f32\00", align 1
@str.356 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1
@str.357 = private unnamed_addr constant [5 x i8] c"null\00", align 1
@str.358 = private unnamed_addr constant [15 x i8] c"*Vector(3,f32)\00", align 1
@str.359 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1
@str.360 = private unnamed_addr constant [5 x i8] c"null\00", align 1
@str.361 = private unnamed_addr constant [8 x i8] c"*[5]f32\00", align 1
@str.362 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1
@str.363 = private unnamed_addr constant [5 x i8] c"null\00", align 1
@str.364 = private unnamed_addr constant [5 x i8] c"*Foo\00", align 1
@str.365 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1
@str.366 = private unnamed_addr constant [5 x i8] c"null\00", align 1
@str.367 = private unnamed_addr constant [5 x i8] c"*f64\00", align 1
@str.368 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1
@str.369 = private unnamed_addr constant [5 x i8] c"null\00", align 1
@str.370 = private unnamed_addr constant [9 x i8] c"*Sx__f32\00", align 1
@str.371 = private unnamed_addr constant [4 x i8] c"@0x\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.54, label %if.else.55
if.then.54: ; preds = %entry
br label %if.merge.56
if.else.55: ; preds = %entry
br label %if.merge.56
if.merge.56: ; preds = %if.else.55, %if.then.54
%bp = phi { ptr, i64 } [ { ptr @str.1, i64 4 }, %if.then.54 ], [ { ptr @str.2, i64 5 }, %if.else.55 ]
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.60, label %if.else.61
if.then.60: ; preds = %entry
%loadN = load double, ptr %alloca, align 8
%fsub = fsub double 0.000000e+00, %loadN
br label %if.merge.62
if.else.61: ; preds = %entry
%loadN = load double, ptr %alloca, align 8
br label %if.merge.62
if.merge.62: ; preds = %if.else.61, %if.then.60
%bp = phi double [ %fsub, %if.then.60 ], [ %loadN, %if.else.61 ]
%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.63, label %if.merge.64
if.then.63: ; preds = %if.merge.62
%loadN = load i64, ptr %allocaN, align 8
%sub = sub i64 0, %loadN
store i64 %sub, ptr %allocaN, align 8
br label %if.merge.64
if.merge.64: ; preds = %if.then.63, %if.merge.62
%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.65, label %if.else.66
if.then.65: ; preds = %if.merge.64
br label %if.merge.67
if.else.66: ; preds = %if.merge.64
br label %if.merge.67
if.merge.67: ; preds = %if.else.66, %if.then.65
%bpN = phi i64 [ 1, %if.then.65 ], [ 0, %if.else.66 ]
%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.68, label %if.merge.69
if.then.68: ; preds = %if.merge.67
%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.69
if.merge.69: ; preds = %if.then.68, %if.merge.67
%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.248
while.hdr.248: ; preds = %if.merge.253, %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.249, label %while.exit.250
while.body.249: ; preds = %while.hdr.248
%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.251, label %if.else.252
while.exit.250: ; preds = %while.hdr.248
ret void
if.then.251: ; preds = %while.body.249
%loadN = load i64, ptr %allocaN, align 8
%addN = add i64 %loadN, 48
br label %if.merge.253
if.else.252: ; preds = %while.body.249
%loadN = load i64, ptr %allocaN, align 8
%sub = sub i64 %loadN, 10
%addN = add i64 %sub, 97
br label %if.merge.253
if.merge.253: ; preds = %if.else.252, %if.then.251
%bp = phi i64 [ %addN, %if.then.251 ], [ %addN, %if.else.252 ]
%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.248
}
; 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.238, label %if.merge.239
if.then.238: ; preds = %entry
ret { ptr, i64 } { ptr @str.3, i64 1 }
if.merge.239: ; 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.240, label %if.merge.241
if.then.240: ; preds = %if.merge.239
%loadN = load i64, ptr %allocaN, align 8
%add = add i64 %loadN, 65536
store i64 %add, ptr %allocaN, align 8
br label %if.merge.241
if.merge.241: ; preds = %if.then.240, %if.merge.239
%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.242, label %if.merge.243
if.then.242: ; preds = %if.merge.241
%loadN = load i64, ptr %allocaN, align 8
%addN = add i64 %loadN, 65536
store i64 %addN, ptr %allocaN, align 8
br label %if.merge.243
if.merge.243: ; preds = %if.then.242, %if.merge.241
%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.244, label %if.merge.245
if.then.244: ; preds = %if.merge.243
%loadN = load i64, ptr %allocaN, align 8
%addN = add i64 %loadN, 65536
store i64 %addN, ptr %allocaN, align 8
br label %if.merge.245
if.merge.245: ; preds = %if.then.244, %if.merge.243
%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.246, label %if.merge.247
if.then.246: ; preds = %if.merge.245
%loadN = load i64, ptr %allocaN, align 8
%addN = add i64 %loadN, 65536
store i64 %addN, ptr %allocaN, align 8
br label %if.merge.247
if.merge.247: ; preds = %if.then.246, %if.merge.245
%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.254
while.hdr.254: ; preds = %if.merge.258, %if.merge.247
%loadN = load i64, ptr %allocaN, align 8
%icmpN = icmp slt i64 %loadN, 15
br i1 %icmpN, label %while.body.255, label %while.exit.256
while.body.255: ; preds = %while.hdr.254
%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.257, label %if.merge.258
while.exit.256: ; preds = %if.then.257, %while.hdr.254
%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.257: ; preds = %while.body.255
br label %while.exit.256
if.merge.258: ; preds = %while.body.255
%loadN = load i64, ptr %allocaN, align 8
%addN = add i64 %loadN, 1
store i64 %addN, ptr %allocaN, align 8
br label %while.hdr.254
}
; 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.53 [
i64 17, label %match.arm.39
i64 2, label %match.arm.40
i64 3, label %match.arm.40
i64 4, label %match.arm.40
i64 5, label %match.arm.40
i64 6, label %match.arm.40
i64 7, label %match.arm.40
i64 8, label %match.arm.40
i64 9, label %match.arm.40
i64 16, label %match.arm.40
i64 15, label %match.arm.40
i64 12, label %match.arm.41
i64 1, label %match.arm.42
i64 10, label %match.arm.43
i64 11, label %match.arm.43
i64 19, label %match.arm.44
i64 20, label %match.arm.44
i64 21, label %match.arm.44
i64 23, label %match.arm.44
i64 25, label %match.arm.44
i64 27, label %match.arm.44
i64 30, label %match.arm.44
i64 32, label %match.arm.44
i64 34, label %match.arm.44
i64 37, label %match.arm.44
i64 38, label %match.arm.44
i64 40, label %match.arm.44
i64 41, label %match.arm.44
i64 42, label %match.arm.44
i64 43, label %match.arm.44
i64 62, label %match.arm.45
i64 39, label %match.arm.47
i64 36, label %match.arm.48
i64 51, label %match.arm.48
i64 58, label %match.arm.48
i64 35, label %match.arm.49
i64 49, label %match.arm.49
i64 18, label %match.arm.50
i64 22, label %match.arm.50
i64 24, label %match.arm.50
i64 26, label %match.arm.50
i64 28, label %match.arm.50
i64 29, label %match.arm.50
i64 31, label %match.arm.50
i64 33, label %match.arm.50
i64 44, label %match.arm.50
i64 45, label %match.arm.50
i64 46, label %match.arm.50
i64 47, label %match.arm.50
i64 48, label %match.arm.50
i64 50, label %match.arm.50
i64 52, label %match.arm.50
i64 53, label %match.arm.50
i64 54, label %match.arm.50
i64 55, label %match.arm.50
i64 56, label %match.arm.50
i64 57, label %match.arm.50
i64 59, label %match.arm.50
i64 60, label %match.arm.50
i64 61, label %match.arm.50
i64 63, label %match.arm.50
i64 13, label %match.arm.52
]
match.merge.38: ; preds = %dispatch.merge.209, %dispatch.merge.195, %dispatch.merge.175, %dispatch.merge.167, %dispatch.merge.162, %dispatch.merge.70, %float.merge.59, %match.unr.53, %match.arm.52, %match.arm.42, %match.arm.41, %match.arm.40, %match.arm.39
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
ret { ptr, i64 } %loadN
match.arm.39: ; preds = %entry
store { ptr, i64 } { ptr @str.5, i64 0 }, ptr %allocaN, align 8
br label %match.merge.38
match.arm.40: ; 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.38
match.arm.41: ; 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.38
match.arm.42: ; 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.38
match.arm.43: ; 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.57, label %fN.unbox.58
match.arm.44: ; preds = %entry, %entry, %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.71 [
i64 19, label %dispatch.case.72
i64 20, label %dispatch.case.73
i64 21, label %dispatch.case.74
i64 23, label %dispatch.case.75
i64 25, label %dispatch.case.76
i64 27, label %dispatch.case.77
i64 30, label %dispatch.case.78
i64 32, label %dispatch.case.79
i64 34, label %dispatch.case.80
i64 37, label %dispatch.case.81
i64 38, label %dispatch.case.82
i64 40, label %dispatch.case.83
i64 41, label %dispatch.case.84
i64 42, label %dispatch.case.85
i64 43, label %dispatch.case.86
]
match.arm.45: ; 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 62, label %dispatch.case.164
]
match.arm.46: ; No predecessors!
unreachable
match.arm.47: ; preds = %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.168 [
i64 39, label %dispatch.case.169
]
match.arm.48: ; preds = %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.176 [
i64 36, label %dispatch.case.177
i64 51, label %dispatch.case.178
i64 58, label %dispatch.case.179
]
match.arm.49: ; preds = %entry, %entry
%loadN = load { i64, i64 }, ptr %allocaN, align 8
%ua.raw34 = extractvalue { i64, i64 } %loadN, 1
%loadN = load { i64, i64 }, ptr %alloca, align 8
%allocaN = alloca { ptr, i64 }, align 8
switch i64 %ua.raw34, label %dispatch.default.196 [
i64 35, label %dispatch.case.197
i64 49, label %dispatch.case.198
]
match.arm.50: ; 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.raw38 = extractvalue { i64, i64 } %loadN, 1
%loadN = load { i64, i64 }, ptr %alloca, align 8
%allocaN = alloca { ptr, i64 }, align 8
switch i64 %ua.raw38, label %dispatch.default.210 [
i64 18, label %dispatch.case.211
i64 22, label %dispatch.case.212
i64 24, label %dispatch.case.213
i64 26, label %dispatch.case.214
i64 28, label %dispatch.case.215
i64 29, label %dispatch.case.216
i64 31, label %dispatch.case.217
i64 33, label %dispatch.case.218
i64 44, label %dispatch.case.219
i64 45, label %dispatch.case.220
i64 46, label %dispatch.case.221
i64 47, label %dispatch.case.222
i64 48, label %dispatch.case.223
i64 50, label %dispatch.case.224
i64 52, label %dispatch.case.225
i64 53, label %dispatch.case.226
i64 54, label %dispatch.case.227
i64 55, label %dispatch.case.228
i64 56, label %dispatch.case.229
i64 57, label %dispatch.case.230
i64 59, label %dispatch.case.231
i64 60, label %dispatch.case.232
i64 61, label %dispatch.case.233
i64 63, label %dispatch.case.234
]
match.arm.51: ; No predecessors!
unreachable
match.arm.52: ; preds = %entry
%loadN = load { i64, i64 }, ptr %alloca, align 8
%tn.tid = extractvalue { i64, i64 } %loadN, 1
%tn.gep = getelementptr inbounds [95 x { ptr, i64 }], ptr @__sx_type_names, i64 0, i64 %tn.tid
%tn.load = load { ptr, i64 }, ptr %tn.gep, align 8
store { ptr, i64 } %tn.load, ptr %allocaN, align 8
br label %match.merge.38
match.unr.53: ; preds = %entry
br label %match.merge.38
f32.unbox.57: ; preds = %match.arm.43
%ua.raw42 = extractvalue { i64, i64 } %loadN, 1
%trN = trunc i64 %ua.raw42 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.59
f64.unbox.58: ; preds = %match.arm.43
%ua.raw43 = extractvalue { i64, i64 } %loadN, 1
%iNd = bitcast i64 %ua.raw43 to double
store double %iNd, ptr %allocaN, align 8
br label %float.merge.59
float.merge.59: ; preds = %fN.unbox.58, %fN.unbox.57
%loadN = load double, ptr %allocaN, align 8
%callN = call { ptr, i64 } @float_to_string(ptr %0, double %loadN)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %match.merge.38
dispatch.merge.70: ; preds = %dispatch.case.86, %dispatch.case.85, %dispatch.case.84, %dispatch.case.83, %dispatch.case.82, %dispatch.case.81, %dispatch.case.80, %dispatch.case.79, %dispatch.case.78, %dispatch.case.77, %dispatch.case.76, %dispatch.case.75, %dispatch.case.74, %dispatch.case.73, %dispatch.case.72, %dispatch.default.71
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
store { ptr, i64 } %loadN, ptr %allocaN, align 8
br label %match.merge.38
dispatch.default.71: ; preds = %match.arm.44
store { ptr, i64 } { ptr @str.100, i64 0 }, ptr %allocaN, align 8
br label %dispatch.merge.70
dispatch.case.72: ; preds = %match.arm.44
%ua.raw47 = extractvalue { i64, i64 } %loadN, 1
%ua.ptr48 = inttoptr i64 %ua.raw47 to ptr
%ua.load49 = load { { ptr, i64 }, i32, i32, { ptr, i64 } }, ptr %ua.ptr48, align 8
%callN = call { ptr, i64 } @struct_to_string__Source_Location(ptr %0, { { ptr, i64 }, i32, i32, { ptr, i64 } } %ua.load49)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %dispatch.merge.70
dispatch.case.73: ; preds = %match.arm.44
%ua.raw51 = extractvalue { i64, i64 } %loadN, 1
%ua.ptr52 = inttoptr i64 %ua.raw51 to ptr
%ua.load53 = load { ptr, ptr, ptr }, ptr %ua.ptr52, align 8
%callN = call { ptr, i64 } @struct_to_string__Allocator(ptr %0, { ptr, ptr, ptr } %ua.load53)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %dispatch.merge.70
dispatch.case.74: ; preds = %match.arm.44
%ua.raw55 = extractvalue { i64, i64 } %loadN, 1
%ua.ptr56 = inttoptr i64 %ua.raw55 to ptr
%ua.load57 = load {}, ptr %ua.ptr56, align 1
%callN = call { ptr, i64 } @struct_to_string__CAllocator(ptr %0, {} %ua.load57)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %dispatch.merge.70
dispatch.case.75: ; preds = %match.arm.44
%ua.raw59 = extractvalue { i64, i64 } %loadN, 1
%ua.ptr60 = inttoptr i64 %ua.raw59 to ptr
%ua.load61 = load { i64 }, ptr %ua.ptr60, align 8
%callN = call { ptr, i64 } @struct_to_string__GPA(ptr %0, { i64 } %ua.load61)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %dispatch.merge.70
dispatch.case.76: ; preds = %match.arm.44
%ua.raw63 = extractvalue { i64, i64 } %loadN, 1
%ua.ptr64 = inttoptr i64 %ua.raw63 to ptr
%ua.load65 = load { ptr, i64 }, ptr %ua.ptr64, align 8
%callN = call { ptr, i64 } @struct_to_string__ArenaChunk(ptr %0, { ptr, i64 } %ua.load65)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %dispatch.merge.70
dispatch.case.77: ; preds = %match.arm.44
%ua.raw67 = extractvalue { i64, i64 } %loadN, 1
%ua.ptr68 = inttoptr i64 %ua.raw67 to ptr
%ua.load69 = load { ptr, i64, { ptr, ptr, ptr } }, ptr %ua.ptr68, align 8
%callN = call { ptr, i64 } @struct_to_string__Arena(ptr %0, { ptr, i64, { ptr, ptr, ptr } } %ua.load69)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %dispatch.merge.70
dispatch.case.78: ; preds = %match.arm.44
%ua.raw71 = extractvalue { i64, i64 } %loadN, 1
%ua.ptr72 = inttoptr i64 %ua.raw71 to ptr
%ua.load73 = load { ptr, i64, i64 }, ptr %ua.ptr72, align 8
%callN = call { ptr, i64 } @struct_to_string__BufAlloc(ptr %0, { ptr, i64, i64 } %ua.load73)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %dispatch.merge.70
dispatch.case.79: ; preds = %match.arm.44
%ua.raw75 = extractvalue { i64, i64 } %loadN, 1
%ua.ptr76 = inttoptr i64 %ua.raw75 to ptr
%ua.load77 = load { { ptr, ptr, ptr }, i64, i64, i64 }, ptr %ua.ptr76, align 8
%callN = call { ptr, i64 } @struct_to_string__TrackingAllocator(ptr %0, { { ptr, ptr, ptr }, i64, i64, i64 } %ua.load77)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %dispatch.merge.70
dispatch.case.80: ; preds = %match.arm.44
%ua.raw79 = extractvalue { i64, i64 } %loadN, 1
%ua.ptr80 = inttoptr i64 %ua.raw79 to ptr
%ua.load81 = load { { ptr, ptr, ptr }, ptr }, ptr %ua.ptr80, align 8
%callN = call { ptr, i64 } @struct_to_string__Context(ptr %0, { { ptr, ptr, ptr }, ptr } %ua.load81)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %dispatch.merge.70
dispatch.case.81: ; preds = %match.arm.44
%ua.raw83 = extractvalue { i64, i64 } %loadN, 1
%ua.ptr84 = inttoptr i64 %ua.raw83 to ptr
%ua.load85 = load { [16 x float] }, ptr %ua.ptr84, align 4
%callN = call { ptr, i64 } @struct_to_string__Mat4(ptr %0, { [16 x float] } %ua.load85)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %dispatch.merge.70
dispatch.case.82: ; preds = %match.arm.44
%ua.raw87 = extractvalue { i64, i64 } %loadN, 1
%ua.ptr88 = inttoptr i64 %ua.raw87 to ptr
%ua.load89 = load { float, float }, ptr %ua.ptr88, align 4
%callN = call { ptr, i64 } @struct_to_string__Vec2(ptr %0, { float, float } %ua.load89)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %dispatch.merge.70
dispatch.case.83: ; preds = %match.arm.44
%ua.raw91 = extractvalue { i64, i64 } %loadN, 1
%ua.ptr92 = inttoptr i64 %ua.raw91 to ptr
%ua.load93 = load { <3 x float> }, ptr %ua.ptr92, align 16
%callN = call { ptr, i64 } @struct_to_string__Vec__3__f32(ptr %0, { <3 x float> } %ua.load93)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %dispatch.merge.70
dispatch.case.84: ; preds = %match.arm.44
%ua.raw95 = extractvalue { i64, i64 } %loadN, 1
%ua.ptr96 = inttoptr i64 %ua.raw95 to ptr
%ua.load97 = load { <3 x float> }, ptr %ua.ptr96, align 16
%callN = call { ptr, i64 } @struct_to_string__Vec3(ptr %0, { <3 x float> } %ua.load97)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %dispatch.merge.70
dispatch.case.85: ; preds = %match.arm.44
%ua.raw99 = extractvalue { i64, i64 } %loadN, 1
%ua.ptr100 = inttoptr i64 %ua.raw99 to ptr
%ua.load101 = load { i32, i32 }, ptr %ua.ptr100, align 4
%callN = call { ptr, i64 } @struct_to_string__Complex__u32(ptr %0, { i32, i32 } %ua.load101)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %dispatch.merge.70
dispatch.case.86: ; preds = %match.arm.44
%ua.raw103 = extractvalue { i64, i64 } %loadN, 1
%ua.ptr104 = inttoptr i64 %ua.raw103 to ptr
%ua.load105 = load { i32, i32 }, ptr %ua.ptr104, align 4
%callN = call { ptr, i64 } @struct_to_string__Foo(ptr %0, { i32, i32 } %ua.load105)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %dispatch.merge.70
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.38
dispatch.default.163: ; preds = %match.arm.45
store { ptr, i64 } { ptr @str.101, i64 0 }, ptr %allocaN, align 8
br label %dispatch.merge.162
dispatch.case.164: ; preds = %match.arm.45
%ua.raw108 = extractvalue { i64, i64 } %loadN, 1
%ua.ptr109 = inttoptr i64 %ua.raw108 to ptr
%ua.load110 = load { i64, [4 x i8] }, ptr %ua.ptr109, align 8
%callN = call { ptr, i64 } @enum_to_string__Sx__f32(ptr %0, { i64, [4 x i8] } %ua.load110)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %dispatch.merge.162
dispatch.merge.167: ; preds = %dispatch.case.169, %dispatch.default.168
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
store { ptr, i64 } %loadN, ptr %allocaN, align 8
br label %match.merge.38
dispatch.default.168: ; preds = %match.arm.47
store { ptr, i64 } { ptr @str.102, i64 0 }, ptr %allocaN, align 8
br label %dispatch.merge.167
dispatch.case.169: ; preds = %match.arm.47
%ua.raw113 = extractvalue { i64, i64 } %loadN, 1
%ua.ptr114 = inttoptr i64 %ua.raw113 to ptr
%ua.load115 = load <3 x float>, ptr %ua.ptr114, align 16
%callN = call { ptr, i64 } @vector_to_string__vec_3_f32(ptr %0, <3 x float> %ua.load115)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %dispatch.merge.167
dispatch.merge.175: ; preds = %dispatch.case.179, %dispatch.case.178, %dispatch.case.177, %dispatch.default.176
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
store { ptr, i64 } %loadN, ptr %allocaN, align 8
br label %match.merge.38
dispatch.default.176: ; preds = %match.arm.48
store { ptr, i64 } { ptr @str.103, i64 0 }, ptr %allocaN, align 8
br label %dispatch.merge.175
dispatch.case.177: ; preds = %match.arm.48
%ua.raw118 = extractvalue { i64, i64 } %loadN, 1
%ua.ptr119 = inttoptr i64 %ua.raw118 to ptr
%ua.load120 = load [16 x float], ptr %ua.ptr119, align 4
%callN = call { ptr, i64 } @array_to_string__AR_16_f32(ptr %0, [16 x float] %ua.load120)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %dispatch.merge.175
dispatch.case.178: ; preds = %match.arm.48
%ua.raw122 = extractvalue { i64, i64 } %loadN, 1
%ua.ptr123 = inttoptr i64 %ua.raw122 to ptr
%ua.load124 = load [1 x { i64, i64 }], ptr %ua.ptr123, align 8
%callN = call { ptr, i64 } @array_to_string__AR_1_Any(ptr %0, [1 x { i64, i64 }] %ua.load124)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %dispatch.merge.175
dispatch.case.179: ; preds = %match.arm.48
%ua.raw126 = extractvalue { i64, i64 } %loadN, 1
%ua.ptr127 = inttoptr i64 %ua.raw126 to ptr
%ua.load128 = load [5 x float], ptr %ua.ptr127, align 4
%callN = call { ptr, i64 } @array_to_string__AR_5_f32(ptr %0, [5 x float] %ua.load128)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %dispatch.merge.175
dispatch.merge.195: ; preds = %dispatch.case.198, %dispatch.case.197, %dispatch.default.196
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
store { ptr, i64 } %loadN, ptr %allocaN, align 8
br label %match.merge.38
dispatch.default.196: ; preds = %match.arm.49
store { ptr, i64 } { ptr @str.104, i64 0 }, ptr %allocaN, align 8
br label %dispatch.merge.195
dispatch.case.197: ; preds = %match.arm.49
%ua.raw131 = extractvalue { i64, i64 } %loadN, 1
%ua.ptr132 = inttoptr i64 %ua.raw131 to ptr
%ua.load133 = load { ptr, i64 }, ptr %ua.ptr132, align 8
%callN = call { ptr, i64 } @slice_to_string__string(ptr %0, { ptr, i64 } %ua.load133)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %dispatch.merge.195
dispatch.case.198: ; preds = %match.arm.49
%ua.raw135 = extractvalue { i64, i64 } %loadN, 1
%ua.ptr136 = inttoptr i64 %ua.raw135 to ptr
%ua.load137 = load { ptr, i64 }, ptr %ua.ptr136, align 8
%callN = call { ptr, i64 } @slice_to_string__Any(ptr %0, { ptr, i64 } %ua.load137)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %dispatch.merge.195
dispatch.merge.209: ; preds = %dispatch.case.234, %dispatch.case.233, %dispatch.case.232, %dispatch.case.231, %dispatch.case.230, %dispatch.case.229, %dispatch.case.228, %dispatch.case.227, %dispatch.case.226, %dispatch.case.225, %dispatch.case.224, %dispatch.case.223, %dispatch.case.222, %dispatch.case.221, %dispatch.case.220, %dispatch.case.219, %dispatch.case.218, %dispatch.case.217, %dispatch.case.216, %dispatch.case.215, %dispatch.case.214, %dispatch.case.213, %dispatch.case.212, %dispatch.case.211, %dispatch.default.210
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
store { ptr, i64 } %loadN, ptr %allocaN, align 8
br label %match.merge.38
dispatch.default.210: ; preds = %match.arm.50
store { ptr, i64 } { ptr @str.105, i64 0 }, ptr %allocaN, align 8
br label %dispatch.merge.209
dispatch.case.211: ; preds = %match.arm.50
%ua.raw140 = extractvalue { i64, i64 } %loadN, 1
%iNp = inttoptr i64 %ua.raw140 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.209
dispatch.case.212: ; preds = %match.arm.50
%ua.raw142 = extractvalue { i64, i64 } %loadN, 1
%iNp143 = inttoptr i64 %ua.raw142 to ptr
%callN = call { ptr, i64 } @pointer_to_string__ptr_CAllocator(ptr %0, ptr %iNp143)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %dispatch.merge.209
dispatch.case.213: ; preds = %match.arm.50
%ua.raw145 = extractvalue { i64, i64 } %loadN, 1
%iNp146 = inttoptr i64 %ua.raw145 to ptr
%callN = call { ptr, i64 } @pointer_to_string__ptr_GPA(ptr %0, ptr %iNp146)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %dispatch.merge.209
dispatch.case.214: ; preds = %match.arm.50
%ua.raw148 = extractvalue { i64, i64 } %loadN, 1
%iNp149 = inttoptr i64 %ua.raw148 to ptr
%callN = call { ptr, i64 } @pointer_to_string__ptr_ArenaChunk(ptr %0, ptr %iNp149)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %dispatch.merge.209
dispatch.case.215: ; preds = %match.arm.50
%ua.raw151 = extractvalue { i64, i64 } %loadN, 1
%iNp152 = inttoptr i64 %ua.raw151 to ptr
%callN = call { ptr, i64 } @pointer_to_string__ptr_Arena(ptr %0, ptr %iNp152)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %dispatch.merge.209
dispatch.case.216: ; preds = %match.arm.50
%ua.raw154 = extractvalue { i64, i64 } %loadN, 1
%iNp155 = inttoptr i64 %ua.raw154 to ptr
%callN = call { ptr, i64 } @pointer_to_string__mptr_u8(ptr %0, ptr %iNp155)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %dispatch.merge.209
dispatch.case.217: ; preds = %match.arm.50
%ua.raw157 = extractvalue { i64, i64 } %loadN, 1
%iNp158 = inttoptr i64 %ua.raw157 to ptr
%callN = call { ptr, i64 } @pointer_to_string__ptr_BufAlloc(ptr %0, ptr %iNp158)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %dispatch.merge.209
dispatch.case.218: ; preds = %match.arm.50
%ua.raw160 = extractvalue { i64, i64 } %loadN, 1
%iNp161 = inttoptr i64 %ua.raw160 to ptr
%callN = call { ptr, i64 } @pointer_to_string__ptr_TrackingAllocator(ptr %0, ptr %iNp161)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %dispatch.merge.209
dispatch.case.219: ; preds = %match.arm.50
%ua.raw163 = extractvalue { i64, i64 } %loadN, 1
%iNp164 = inttoptr i64 %ua.raw163 to ptr
%callN = call { ptr, i64 } @pointer_to_string__ptr_ptr_CAllocator(ptr %0, ptr %iNp164)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %dispatch.merge.209
dispatch.case.220: ; preds = %match.arm.50
%ua.raw166 = extractvalue { i64, i64 } %loadN, 1
%iNp167 = inttoptr i64 %ua.raw166 to ptr
%callN = call { ptr, i64 } @pointer_to_string__ptr_s64(ptr %0, ptr %iNp167)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %dispatch.merge.209
dispatch.case.221: ; preds = %match.arm.50
%ua.raw169 = extractvalue { i64, i64 } %loadN, 1
%iNp170 = inttoptr i64 %ua.raw169 to ptr
%callN = call { ptr, i64 } @pointer_to_string__ptr_ptr_void(ptr %0, ptr %iNp170)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %dispatch.merge.209
dispatch.case.222: ; preds = %match.arm.50
%ua.raw172 = extractvalue { i64, i64 } %loadN, 1
%iNp173 = inttoptr i64 %ua.raw172 to ptr
%callN = call { ptr, i64 } @pointer_to_string__ptr_Vec3(ptr %0, ptr %iNp173)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %dispatch.merge.209
dispatch.case.223: ; preds = %match.arm.50
%ua.raw175 = extractvalue { i64, i64 } %loadN, 1
%iNp176 = inttoptr i64 %ua.raw175 to ptr
%callN = call { ptr, i64 } @pointer_to_string__ptr_string(ptr %0, ptr %iNp176)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %dispatch.merge.209
dispatch.case.224: ; preds = %match.arm.50
%ua.raw178 = extractvalue { i64, i64 } %loadN, 1
%iNp179 = inttoptr i64 %ua.raw178 to ptr
%callN = call { ptr, i64 } @pointer_to_string__ptr_Any(ptr %0, ptr %iNp179)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %dispatch.merge.209
dispatch.case.225: ; preds = %match.arm.50
%ua.raw181 = extractvalue { i64, i64 } %loadN, 1
%iNp182 = inttoptr i64 %ua.raw181 to ptr
%callN = call { ptr, i64 } @pointer_to_string__ptr_AR_1_Any(ptr %0, ptr %iNp182)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %dispatch.merge.209
dispatch.case.226: ; preds = %match.arm.50
%ua.raw184 = extractvalue { i64, i64 } %loadN, 1
%iNp185 = inttoptr i64 %ua.raw184 to ptr
%callN = call { ptr, i64 } @pointer_to_string__ptr_SL_Any(ptr %0, ptr %iNp185)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %dispatch.merge.209
dispatch.case.227: ; preds = %match.arm.50
%ua.raw187 = extractvalue { i64, i64 } %loadN, 1
%iNp188 = inttoptr i64 %ua.raw187 to ptr
%callN = call { ptr, i64 } @pointer_to_string__ptr_u8(ptr %0, ptr %iNp188)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %dispatch.merge.209
dispatch.case.228: ; preds = %match.arm.50
%ua.raw190 = extractvalue { i64, i64 } %loadN, 1
%iNp191 = inttoptr i64 %ua.raw190 to ptr
%callN = call { ptr, i64 } @pointer_to_string__ptr_bool(ptr %0, ptr %iNp191)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %dispatch.merge.209
dispatch.case.229: ; preds = %match.arm.50
%ua.raw193 = extractvalue { i64, i64 } %loadN, 1
%iNp194 = inttoptr i64 %ua.raw193 to ptr
%callN = call { ptr, i64 } @pointer_to_string__ptr_f32(ptr %0, ptr %iNp194)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %dispatch.merge.209
dispatch.case.230: ; preds = %match.arm.50
%ua.raw196 = extractvalue { i64, i64 } %loadN, 1
%iNp197 = inttoptr i64 %ua.raw196 to ptr
%callN = call { ptr, i64 } @pointer_to_string__ptr_vec_3_f32(ptr %0, ptr %iNp197)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %dispatch.merge.209
dispatch.case.231: ; preds = %match.arm.50
%ua.raw199 = extractvalue { i64, i64 } %loadN, 1
%iNp200 = inttoptr i64 %ua.raw199 to ptr
%callN = call { ptr, i64 } @pointer_to_string__ptr_AR_5_f32(ptr %0, ptr %iNp200)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %dispatch.merge.209
dispatch.case.232: ; preds = %match.arm.50
%ua.raw202 = extractvalue { i64, i64 } %loadN, 1
%iNp203 = inttoptr i64 %ua.raw202 to ptr
%callN = call { ptr, i64 } @pointer_to_string__ptr_Foo(ptr %0, ptr %iNp203)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %dispatch.merge.209
dispatch.case.233: ; preds = %match.arm.50
%ua.raw205 = extractvalue { i64, i64 } %loadN, 1
%iNp206 = inttoptr i64 %ua.raw205 to ptr
%callN = call { ptr, i64 } @pointer_to_string__ptr_f64(ptr %0, ptr %iNp206)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %dispatch.merge.209
dispatch.case.234: ; preds = %match.arm.50
%ua.raw208 = extractvalue { i64, i64 } %loadN, 1
%iNp209 = inttoptr i64 %ua.raw208 to ptr
%callN = call { ptr, i64 } @pointer_to_string__ptr_Sx__f32(ptr %0, ptr %iNp209)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %dispatch.merge.209
}
; 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.106, 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.107, 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.108, 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.109, 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.110, 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.111, 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.112, 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.113, 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.114, 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.115, 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.116, 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.117, 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.118, 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.119, 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.120, 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
declare float @lerp(ptr, float, float, float) #0
; Function Attrs: nounwind
declare void @Mat4.identity(ptr sret({ [16 x float] }), ptr) #0
; Function Attrs: nounwind
declare void @Mat4.zero(ptr sret({ [16 x float] }), ptr) #0
; Function Attrs: nounwind
declare void @Mat4.mul(ptr sret({ [16 x float] }), ptr, ptr, ptr) #0
; Function Attrs: nounwind
declare void @Mat4.translate(ptr sret({ [16 x float] }), ptr, float, float, float) #0
; Function Attrs: nounwind
declare void @Mat4.scale(ptr sret({ [16 x float] }), ptr, float, float, float) #0
; Function Attrs: nounwind
declare void @Mat4.rotate_x(ptr sret({ [16 x float] }), ptr, float) #0
; Function Attrs: nounwind
declare void @Mat4.rotate_y(ptr sret({ [16 x float] }), ptr, float) #0
; Function Attrs: nounwind
declare void @Mat4.rotate_z(ptr sret({ [16 x float] }), ptr, float) #0
; Function Attrs: nounwind
declare void @Mat4.ortho(ptr sret({ [16 x float] }), ptr, float, float, float, float, float, float) #0
; Function Attrs: nounwind
declare void @Mat4.perspective(ptr sret({ [16 x float] }), ptr, float, float, float, float) #0
; Function Attrs: nounwind
declare { float, float } @Vec2.zero(ptr) #0
; Function Attrs: nounwind
declare { float, float } @Vec2.add(ptr, { float, float }, { float, float }) #0
; Function Attrs: nounwind
declare { float, float } @Vec2.sub(ptr, { float, float }, { float, float }) #0
; Function Attrs: nounwind
declare { float, float } @Vec2.scale(ptr, { float, float }, float) #0
; Function Attrs: nounwind
declare float @Vec2.dot(ptr, { float, float }, { float, float }) #0
; Function Attrs: nounwind
declare float @Vec2.length(ptr, { float, float }) #0
; Function Attrs: nounwind
declare { float, float } @Vec2.normalize(ptr, { float, float }) #0
; Function Attrs: nounwind
declare { float, float } @Vec2.lerp(ptr, { float, float }, { float, float }, float) #0
; Function Attrs: nounwind
declare float @Vec2.distance(ptr, { float, float }, { float, float }) #0
; Function Attrs: nounwind
declare { float, float } @Vec2.negate(ptr, { float, float }) #0
; Function Attrs: nounwind
declare i1 @Vec2.equals(ptr, { float, float }, { float, float }) #0
; Function Attrs: nounwind
define internal <3 x float> @vec3(ptr %0, float %1, float %2, float %3) #0 {
entry:
%alloca = alloca float, align 4
store float %1, ptr %alloca, align 4
%allocaN = alloca float, align 4
store float %2, ptr %allocaN, align 4
%allocaN = alloca float, align 4
store float %3, ptr %allocaN, align 4
%load = load float, ptr %alloca, align 4
%loadN = load float, ptr %allocaN, align 4
%loadN = load float, ptr %allocaN, align 4
%vi = insertelement <3 x float> undef, float %load, i32 0
%viN = insertelement <3 x float> %vi, float %loadN, i32 1
%viN = insertelement <3 x float> %viN, float %loadN, i32 2
ret <3 x float> %viN
}
; Function Attrs: nounwind
define i32 @main() #0 {
entry:
%alloca = alloca { <3 x float> }, align 16
store { <3 x float> } { <3 x float> <float 1.000000e+00, float 3.000000e+00, float 2.000000e+00> }, ptr %alloca, align 16
%load = load { <3 x float> }, ptr %alloca, align 16
call void @print__ct_saf3b53dfd1590ed__pack_Vec3(ptr @__sx_default_context, { <3 x float> } %load)
%call = call <3 x float> @vec3(ptr @__sx_default_context, float 1.000000e+00, float 3.000000e+00, float 2.000000e+00)
%allocaN = alloca <3 x float>, align 16
store <3 x float> %call, ptr %allocaN, align 16
%loadN = load <3 x float>, ptr %allocaN, align 16
call void @print__ct_s962c60eb1430613f__pack_vec_3_f32(ptr @__sx_default_context, <3 x float> %loadN)
%allocaN = alloca [5 x float], align 4
store [5 x float] [float 0.000000e+00, float 2.000000e+00, float 3.500000e+00, float 4.000000e+00, float 0.000000e+00], ptr %allocaN, align 4
%loadN = load [5 x float], ptr %allocaN, align 4
call void @print__ct_s549467baf058e667__pack_AR_5_f32(ptr @__sx_default_context, [5 x float] %loadN)
%allocaN = alloca { i32, i32 }, align 8
store { i32, i32 } { i32 42, i32 1 }, ptr %allocaN, align 4
%loadN = load { i32, i32 }, ptr %allocaN, align 4
call void @print__ct_sd91eb2e81c05dcd4__pack_Foo(ptr @__sx_default_context, { i32, i32 } %loadN)
%callN = call <3 x float> @vec3(ptr @__sx_default_context, float 3.000000e+00, float 2.000000e+00, float 1.000000e+00)
%allocaN = alloca <3 x float>, align 16
store <3 x float> %callN, ptr %allocaN, align 16
%loadN = load <3 x float>, ptr %allocaN, align 16
%loadN = load <3 x float>, ptr %allocaN, align 16
%fadd = fadd <3 x float> %loadN, %loadN
%allocaN = alloca <3 x float>, align 16
store <3 x float> %fadd, ptr %allocaN, align 16
%loadN = load <3 x float>, ptr %allocaN, align 16
call void @print__ct_s3038067ddd716595__pack_vec_3_f32(ptr @__sx_default_context, <3 x float> %loadN)
%loadN = load <3 x float>, ptr %allocaN, align 16
%ve = extractelement <3 x float> %loadN, i32 0
%allocaN = alloca float, align 4
store float %ve, ptr %allocaN, align 4
%loadN = load float, ptr %allocaN, align 4
call void @print__ct_sb50fffa856c31fe8__pack_f32(ptr @__sx_default_context, float %loadN)
%loadN = load <3 x float>, ptr %allocaN, align 16
%veN = extractelement <3 x float> %loadN, i32 1
%allocaN = alloca float, align 4
store float %veN, ptr %allocaN, align 4
%loadN = load float, ptr %allocaN, align 4
call void @print__ct_sd243afec30847211__pack_f32(ptr @__sx_default_context, float %loadN)
%loadN = load <3 x float>, ptr %allocaN, align 16
%fmul = fmul <3 x float> %loadN, <float 2.000000e+00, float 2.000000e+00, float 2.000000e+00>
%allocaN = alloca <3 x float>, align 16
store <3 x float> %fmul, ptr %allocaN, align 16
%loadN = load <3 x float>, ptr %allocaN, align 16
call void @print__ct_s1e80f4429411a63__pack_vec_3_f32(ptr @__sx_default_context, <3 x float> %loadN)
%loadN = load <3 x float>, ptr %allocaN, align 16
%fneg = fneg <3 x float> %loadN
%allocaN = alloca <3 x float>, align 16
store <3 x float> %fneg, ptr %allocaN, align 16
%loadN = load <3 x float>, ptr %allocaN, align 16
call void @print__ct_sd428128013c58f8b__pack_vec_3_f32(ptr @__sx_default_context, <3 x float> %loadN)
%callN = call double @sqrt__f64(double 9.000000e+00)
%allocaN = alloca double, align 8
store double %callN, ptr %allocaN, align 8
%loadN = load double, ptr %allocaN, align 8
call void @print__ct_sa2a846ee0ce9045d__pack_f64(ptr @__sx_default_context, double %loadN)
%ei.tmp = alloca { i64, [4 x i8] }, align 8
%ei.tagp = getelementptr inbounds { i64, [4 x i8] }, ptr %ei.tmp, i32 0, i32 0
store i64 1, ptr %ei.tagp, align 8
%ei.pp = getelementptr inbounds { i64, [4 x i8] }, ptr %ei.tmp, i32 0, i32 1
store float 5.000000e-01, ptr %ei.pp, align 4
%ei.val = load { i64, [4 x i8] }, ptr %ei.tmp, align 8
%allocaN = alloca { i64, [4 x i8] }, align 8
store { i64, [4 x i8] } %ei.val, ptr %allocaN, align 8
%loadN = load { i64, [4 x i8] }, ptr %allocaN, align 8
call void @print__ct_sbc6305862a3a863d__pack_Sx__f32(ptr @__sx_default_context, { i64, [4 x i8] } %loadN)
call void @print__ct_sbc6305862a3a863d__pack_s64(ptr @__sx_default_context, i64 4)
call void @print__ct_sbc6305862a3a863d__pack_s64(ptr @__sx_default_context, i64 16)
call void @print__ct_sbc6305862a3a863d__pack_s64(ptr @__sx_default_context, i64 8)
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_saf3b53dfd1590ed__pack_Vec3(ptr %0, { <3 x float> } %1) #0 {
entry:
%alloca = alloca { ptr, i64 }, align 8
store { ptr, i64 } { ptr @str.121, i64 7 }, ptr %alloca, align 8
%allocaN = alloca { <3 x float> }, align 16
store { <3 x float> } %1, ptr %allocaN, align 16
%allocaN = alloca [1 x { i64, i64 }], align 8
%load = load { <3 x float> }, ptr %allocaN, align 16
%ba.tmp = alloca { <3 x float> }, align 16
store { <3 x float> } %load, ptr %ba.tmp, align 16
%ba.p2i = ptrtoint ptr %ba.tmp to i64
%ba.val = insertvalue { i64, i64 } { i64 41, i64 undef }, i64 %ba.p2i, 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.122, 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 4)
%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 { <3 x float> }, ptr %allocaN, align 16
%ba.tmp12 = alloca { <3 x float> }, align 16
store { <3 x float> } %loadN, ptr %ba.tmp12, align 16
%ba.p2i13 = ptrtoint ptr %ba.tmp12 to i64
%ba.val14 = insertvalue { i64, i64 } { i64 41, i64 undef }, i64 %ba.p2i13, 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 6, 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_0(ptr %0) #0 {
entry:
%call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.123, i64 7 })
ret { ptr, i64 } %call
}
; Function Attrs: nounwind
define internal void @print__ct_s962c60eb1430613f__pack_vec_3_f32(ptr %0, <3 x float> %1) #0 {
entry:
%alloca = alloca { ptr, i64 }, align 8
store { ptr, i64 } { ptr @str.124, i64 7 }, ptr %alloca, align 8
%allocaN = alloca <3 x float>, align 16
store <3 x float> %1, ptr %allocaN, align 16
%allocaN = alloca [1 x { i64, i64 }], align 8
%load = load <3 x float>, ptr %allocaN, align 16
%ba.tmp = alloca <3 x float>, align 16
store <3 x float> %load, ptr %ba.tmp, align 16
%ba.p2i = ptrtoint ptr %ba.tmp to i64
%ba.val = insertvalue { i64, i64 } { i64 39, i64 undef }, i64 %ba.p2i, 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.125, 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 4)
%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 <3 x float>, ptr %allocaN, align 16
%ba.tmp12 = alloca <3 x float>, align 16
store <3 x float> %loadN, ptr %ba.tmp12, align 16
%ba.p2i13 = ptrtoint ptr %ba.tmp12 to i64
%ba.val14 = insertvalue { i64, i64 } { i64 39, i64 undef }, i64 %ba.p2i13, 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 6, 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.126, i64 7 })
ret { ptr, i64 } %call
}
; Function Attrs: nounwind
define internal void @print__ct_s549467baf058e667__pack_AR_5_f32(ptr %0, [5 x float] %1) #0 {
entry:
%alloca = alloca { ptr, i64 }, align 8
store { ptr, i64 } { ptr @str.127, i64 9 }, ptr %alloca, align 8
%allocaN = alloca [5 x float], align 4
store [5 x float] %1, ptr %allocaN, align 4
%allocaN = alloca [1 x { i64, i64 }], align 8
%load = load [5 x float], ptr %allocaN, align 4
%ba.tmp = alloca [5 x float], align 4
store [5 x float] %load, ptr %ba.tmp, align 4
%ba.p2i = ptrtoint ptr %ba.tmp to i64
%ba.val = insertvalue { i64, i64 } { i64 58, i64 undef }, i64 %ba.p2i, 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.128, 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 6)
%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 [5 x float], ptr %allocaN, align 4
%ba.tmp12 = alloca [5 x float], align 4
store [5 x float] %loadN, ptr %ba.tmp12, align 4
%ba.p2i13 = ptrtoint ptr %ba.tmp12 to i64
%ba.val14 = insertvalue { i64, i64 } { i64 58, i64 undef }, i64 %ba.p2i13, 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 8, 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.129, i64 9 })
ret { ptr, i64 } %call
}
; Function Attrs: nounwind
define internal void @print__ct_sd91eb2e81c05dcd4__pack_Foo(ptr %0, { i32, i32 } %1) #0 {
entry:
%alloca = alloca { ptr, i64 }, align 8
store { ptr, i64 } { ptr @str.130, i64 9 }, ptr %alloca, align 8
%allocaN = alloca { i32, i32 }, align 8
store { i32, i32 } %1, ptr %allocaN, align 4
%allocaN = alloca [1 x { i64, i64 }], align 8
%load = load { i32, i32 }, ptr %allocaN, align 4
%ba.tmp = alloca { i32, i32 }, align 8
store { i32, i32 } %load, ptr %ba.tmp, align 4
%ba.p2i = ptrtoint ptr %ba.tmp to i64
%ba.val = insertvalue { i64, i64 } { i64 43, i64 undef }, i64 %ba.p2i, 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.131, 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 6)
%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 { i32, i32 }, ptr %allocaN, align 4
%ba.tmp12 = alloca { i32, i32 }, align 8
store { i32, i32 } %loadN, ptr %ba.tmp12, align 4
%ba.p2i13 = ptrtoint ptr %ba.tmp12 to i64
%ba.val14 = insertvalue { i64, i64 } { i64 43, i64 undef }, i64 %ba.p2i13, 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 8, 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.132, i64 9 })
ret { ptr, i64 } %call
}
; Function Attrs: nounwind
define internal void @print__ct_s3038067ddd716595__pack_vec_3_f32(ptr %0, <3 x float> %1) #0 {
entry:
%alloca = alloca { ptr, i64 }, align 8
store { ptr, i64 } { ptr @str.133, i64 8 }, ptr %alloca, align 8
%allocaN = alloca <3 x float>, align 16
store <3 x float> %1, ptr %allocaN, align 16
%allocaN = alloca [1 x { i64, i64 }], align 8
%load = load <3 x float>, ptr %allocaN, align 16
%ba.tmp = alloca <3 x float>, align 16
store <3 x float> %load, ptr %ba.tmp, align 16
%ba.p2i = ptrtoint ptr %ba.tmp to i64
%ba.val = insertvalue { i64, i64 } { i64 39, i64 undef }, i64 %ba.p2i, 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.134, 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 <3 x float>, ptr %allocaN, align 16
%ba.tmp12 = alloca <3 x float>, align 16
store <3 x float> %loadN, ptr %ba.tmp12, align 16
%ba.p2i13 = ptrtoint ptr %ba.tmp12 to i64
%ba.val14 = insertvalue { i64, i64 } { i64 39, i64 undef }, i64 %ba.p2i13, 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.135, i64 8 })
ret { ptr, i64 } %call
}
; Function Attrs: nounwind
define internal void @print__ct_sb50fffa856c31fe8__pack_f32(ptr %0, float %1) #0 {
entry:
%alloca = alloca { ptr, i64 }, align 8
store { ptr, i64 } { ptr @str.136, i64 9 }, 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.137, 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 6)
%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 8, 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_5(ptr %0) #0 {
entry:
%call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.138, i64 9 })
ret { ptr, i64 } %call
}
; Function Attrs: nounwind
define internal void @print__ct_sd243afec30847211__pack_f32(ptr %0, float %1) #0 {
entry:
%alloca = alloca { ptr, i64 }, align 8
store { ptr, i64 } { ptr @str.139, i64 10 }, 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.140, 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 7)
%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 9, 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.141, i64 10 })
ret { ptr, i64 } %call
}
; Function Attrs: nounwind
define internal void @print__ct_s1e80f4429411a63__pack_vec_3_f32(ptr %0, <3 x float> %1) #0 {
entry:
%alloca = alloca { ptr, i64 }, align 8
store { ptr, i64 } { ptr @str.142, i64 11 }, ptr %alloca, align 8
%allocaN = alloca <3 x float>, align 16
store <3 x float> %1, ptr %allocaN, align 16
%allocaN = alloca [1 x { i64, i64 }], align 8
%load = load <3 x float>, ptr %allocaN, align 16
%ba.tmp = alloca <3 x float>, align 16
store <3 x float> %load, ptr %ba.tmp, align 16
%ba.p2i = ptrtoint ptr %ba.tmp to i64
%ba.val = insertvalue { i64, i64 } { i64 39, i64 undef }, i64 %ba.p2i, 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.143, 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 8)
%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 <3 x float>, ptr %allocaN, align 16
%ba.tmp12 = alloca <3 x float>, align 16
store <3 x float> %loadN, ptr %ba.tmp12, align 16
%ba.p2i13 = ptrtoint ptr %ba.tmp12 to i64
%ba.val14 = insertvalue { i64, i64 } { i64 39, i64 undef }, i64 %ba.p2i13, 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 10, 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.144, i64 11 })
ret { ptr, i64 } %call
}
; Function Attrs: nounwind
define internal void @print__ct_sd428128013c58f8b__pack_vec_3_f32(ptr %0, <3 x float> %1) #0 {
entry:
%alloca = alloca { ptr, i64 }, align 8
store { ptr, i64 } { ptr @str.145, i64 8 }, ptr %alloca, align 8
%allocaN = alloca <3 x float>, align 16
store <3 x float> %1, ptr %allocaN, align 16
%allocaN = alloca [1 x { i64, i64 }], align 8
%load = load <3 x float>, ptr %allocaN, align 16
%ba.tmp = alloca <3 x float>, align 16
store <3 x float> %load, ptr %ba.tmp, align 16
%ba.p2i = ptrtoint ptr %ba.tmp to i64
%ba.val = insertvalue { i64, i64 } { i64 39, i64 undef }, i64 %ba.p2i, 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.146, 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 <3 x float>, ptr %allocaN, align 16
%ba.tmp12 = alloca <3 x float>, align 16
store <3 x float> %loadN, ptr %ba.tmp12, align 16
%ba.p2i13 = ptrtoint ptr %ba.tmp12 to i64
%ba.val14 = insertvalue { i64, i64 } { i64 39, i64 undef }, i64 %ba.p2i13, 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.147, i64 8 })
ret { ptr, i64 } %call
}
; Function Attrs: nounwind
define internal double @sqrt__f64(double %0) #0 {
entry:
%alloca = alloca double, align 8
store double %0, ptr %alloca, align 8
%sqrt = call double @sqrt(double %0)
ret double %sqrt
}
; Function Attrs: nounwind
define internal void @print__ct_sa2a846ee0ce9045d__pack_f64(ptr %0, double %1) #0 {
entry:
%alloca = alloca { ptr, i64 }, align 8
store { ptr, i64 } { ptr @str.148, i64 12 }, ptr %alloca, align 8
%allocaN = alloca double, align 8
store double %1, ptr %allocaN, align 8
%allocaN = alloca [1 x { i64, i64 }], align 8
%load = load double, ptr %allocaN, align 8
%dNi = bitcast double %load to i64
%ba.val = insertvalue { i64, i64 } { i64 11, i64 undef }, i64 %dNi, 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.149, 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 9)
%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 double, ptr %allocaN, align 8
%dNi12 = bitcast double %loadN to i64
%ba.val13 = insertvalue { i64, i64 } { i64 11, i64 undef }, i64 %dNi12, 1
%callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %ba.val13)
%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 11, 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.150, i64 12 })
ret { ptr, i64 } %call
}
; Function Attrs: nounwind
define internal void @print__ct_sbc6305862a3a863d__pack_Sx__f32(ptr %0, { i64, [4 x i8] } %1) #0 {
entry:
%alloca = alloca { ptr, i64 }, align 8
store { ptr, i64 } { ptr @str.151, i64 3 }, ptr %alloca, align 8
%allocaN = alloca { i64, [4 x i8] }, align 8
store { i64, [4 x i8] } %1, ptr %allocaN, align 8
%allocaN = alloca [1 x { i64, i64 }], align 8
%load = load { i64, [4 x i8] }, ptr %allocaN, align 8
%ba.tmp = alloca { i64, [4 x i8] }, align 8
store { i64, [4 x i8] } %load, ptr %ba.tmp, align 8
%ba.p2i = ptrtoint ptr %ba.tmp to i64
%ba.val = insertvalue { i64, i64 } { i64 62, i64 undef }, i64 %ba.p2i, 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.152, i64 0 }, ptr %allocaN, align 8
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%loadN = load { i64, [4 x i8] }, ptr %allocaN, align 8
%ba.tmp9 = alloca { i64, [4 x i8] }, align 8
store { i64, [4 x i8] } %loadN, ptr %ba.tmp9, align 8
%ba.p2i10 = ptrtoint ptr %ba.tmp9 to i64
%ba.val11 = insertvalue { i64, i64 } { i64 62, i64 undef }, i64 %ba.p2i10, 1
%call = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %ba.val11)
%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 { ptr, i64 }, ptr %alloca, align 8
%callN = call { ptr, i64 } @substr(ptr %0, { ptr, i64 } %loadN, i64 2, 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_10(ptr %0) #0 {
entry:
%call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.153, i64 3 })
ret { ptr, i64 } %call
}
; Function Attrs: nounwind
define internal void @print__ct_sbc6305862a3a863d__pack_s64(ptr %0, i64 %1) #0 {
entry:
%alloca = alloca { ptr, i64 }, align 8
store { ptr, i64 } { ptr @str.154, i64 3 }, ptr %alloca, align 8
%allocaN = alloca i64, align 8
store i64 %1, ptr %allocaN, align 8
%allocaN = alloca [1 x { i64, i64 }], align 8
%load = load i64, ptr %allocaN, align 8
%ba.val = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %load, 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.155, i64 0 }, ptr %allocaN, align 8
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%loadN = load i64, ptr %allocaN, align 8
%ba.val9 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %loadN, 1
%call = call { ptr, i64 } @any_to_string(ptr %0, { i64, i64 } %ba.val9)
%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 { ptr, i64 }, ptr %alloca, align 8
%callN = call { ptr, i64 } @substr(ptr %0, { ptr, i64 } %loadN, i64 2, 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_11(ptr %0) #0 {
entry:
%call = call { ptr, i64 } @build_format(ptr %0, { ptr, i64 } { ptr @str.156, i64 3 })
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.157, i64 15 }, { 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.87
while.hdr.87: ; preds = %fv.merge, %entry
%load = load i64, ptr %allocaN, align 8
%icmp = icmp slt i64 %load, 4
br i1 %icmp, label %while.body.88, label %while.exit.89
while.body.88: ; preds = %while.hdr.87
%loadN = load i64, ptr %allocaN, align 8
%icmpN = icmp sgt i64 %loadN, 0
br i1 %icmpN, label %if.then.90, label %if.merge.91
while.exit.89: ; preds = %while.hdr.87
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.159, i64 1 })
ret { ptr, i64 } %callN
if.then.90: ; preds = %while.body.88
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.160, i64 2 })
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %if.merge.91
if.merge.91: ; preds = %if.then.90, %while.body.88
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%loadN = load i64, ptr %allocaN, align 8
%fn.gep = getelementptr inbounds [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.164, 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.87
fv.default: ; preds = %if.merge.91
br label %fv.merge
fv.case: ; preds = %if.merge.91
%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.91
%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.91
%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.91
%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.165, i64 9 }, { ptr, i64 } { ptr @str.166, 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.92
while.hdr.92: ; preds = %fv.merge, %entry
%load = load i64, ptr %allocaN, align 8
%icmp = icmp slt i64 %load, 3
br i1 %icmp, label %while.body.93, label %while.exit.94
while.body.93: ; preds = %while.hdr.92
%loadN = load i64, ptr %allocaN, align 8
%icmpN = icmp sgt i64 %loadN, 0
br i1 %icmpN, label %if.then.95, label %if.merge.96
while.exit.94: ; preds = %while.hdr.92
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.167, i64 1 })
ret { ptr, i64 } %callN
if.then.95: ; preds = %while.body.93
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.168, i64 2 })
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %if.merge.96
if.merge.96: ; preds = %if.then.95, %while.body.93
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%loadN = load i64, ptr %allocaN, align 8
%fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.172, 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.173, 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.92
fv.default: ; preds = %if.merge.96
br label %fv.merge
fv.case: ; preds = %if.merge.96
%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.96
%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.96
%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.174, i64 10 }, { ptr, i64 } { ptr @str.175, 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 = %if.merge.101, %entry
%load = load i64, ptr %allocaN, align 8
%icmp = icmp slt i64 %load, 0
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.176, 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.177, 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 [0 x { ptr, i64 }], ptr @field_names.178, 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.179, 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.97
}
; 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.180, i64 3 }, { ptr, i64 } { ptr @str.181, 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, 1
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.182, 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.183, 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 [1 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 { 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.102
fv.default: ; preds = %if.merge.106
br label %fv.merge
fv.case: ; preds = %if.merge.106
%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.187, i64 10 }, { 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.107
while.hdr.107: ; preds = %fv.merge, %entry
%load = load i64, ptr %allocaN, align 8
%icmp = icmp slt i64 %load, 2
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.189, 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.190, 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 [2 x { ptr, i64 }], ptr @field_names.193, 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.194, 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.107
fv.default: ; preds = %if.merge.111
br label %fv.merge
fv.case: ; preds = %if.merge.111
%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.111
%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.195, i64 5 }, { ptr, i64 } { ptr @str.196, 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, 3
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.197, 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.198, 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 [3 x { ptr, i64 }], ptr @field_names.202, 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.203, 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.112
fv.default: ; preds = %if.merge.116
br label %fv.merge
fv.case: ; preds = %if.merge.116
%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.116
%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.116
%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.204, i64 8 }, { ptr, i64 } { ptr @str.205, 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, 3
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.206, 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.207, 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 [3 x { ptr, i64 }], ptr @field_names.211, 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.212, 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.117
fv.default: ; preds = %if.merge.121
br label %fv.merge
fv.case: ; preds = %if.merge.121
%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.121
%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.121
%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.213, i64 17 }, { ptr, i64 } { ptr @str.214, 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, 4
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.215, 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.216, 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 [4 x { ptr, i64 }], ptr @field_names.221, 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.222, 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.122
fv.default: ; preds = %if.merge.126
br label %fv.merge
fv.case: ; preds = %if.merge.126
%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.126
%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.126
%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.126
%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.223, i64 7 }, { ptr, i64 } { ptr @str.224, 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, 2
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.225, 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.226, 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 [2 x { ptr, i64 }], ptr @field_names.229, 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.230, 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.127
fv.default: ; preds = %if.merge.131
br label %fv.merge
fv.case: ; preds = %if.merge.131
%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.131
%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__Mat4(ptr %0, { [16 x float] } %1) #0 {
entry:
%alloca = alloca { [16 x float] }, align 8
store { [16 x float] } %1, ptr %alloca, align 4
%call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.231, i64 4 }, { ptr, i64 } { ptr @str.232, 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, 1
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.233, 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.234, 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 [1 x { ptr, i64 }], ptr @field_names.236, 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.237, i64 2 })
store { ptr, i64 } %callN, ptr %allocaN, align 8
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%loadN = load { [16 x float] }, ptr %alloca, align 4
%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.132
fv.default: ; preds = %if.merge.136
br label %fv.merge
fv.case: ; preds = %if.merge.136
%fv.field = extractvalue { [16 x float] } %loadN, 0
%ba.tmp = alloca [16 x float], align 4
store [16 x float] %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
}
; Function Attrs: nounwind
define internal { ptr, i64 } @struct_to_string__Vec2(ptr %0, { float, float } %1) #0 {
entry:
%alloca = alloca { float, float }, align 8
store { float, float } %1, ptr %alloca, align 4
%call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.238, i64 4 }, { ptr, i64 } { ptr @str.239, 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.240, 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.241, 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.244, 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.245, i64 2 })
store { ptr, i64 } %callN, ptr %allocaN, align 8
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%loadN = load { float, float }, 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.137
fv.default: ; preds = %if.merge.141
br label %fv.merge
fv.case: ; preds = %if.merge.141
%fv.field = extractvalue { float, float } %loadN, 0
%fNi32 = bitcast float %fv.field to i32
%zN = zext i32 %fNi32 to i64
%fv.val = insertvalue { i64, i64 } { i64 10, i64 undef }, i64 %zN, 1
br label %fv.merge
fv.case17: ; preds = %if.merge.141
%fv.field18 = extractvalue { float, float } %loadN, 1
%fNi3219 = bitcast float %fv.field18 to i32
%zN = zext i32 %fNi3219 to i64
%fv.val21 = insertvalue { i64, i64 } { i64 10, i64 undef }, i64 %zN, 1
br label %fv.merge
}
; Function Attrs: nounwind
define internal { ptr, i64 } @struct_to_string__Vec__3__f32(ptr %0, { <3 x float> } %1) #0 {
entry:
%alloca = alloca { <3 x float> }, align 16
store { <3 x float> } %1, ptr %alloca, align 16
%call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.246, i64 11 }, { ptr, i64 } { ptr @str.247, 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, 1
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.248, 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.249, 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 [1 x { ptr, i64 }], ptr @field_names.251, 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.252, i64 2 })
store { ptr, i64 } %callN, ptr %allocaN, align 8
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%loadN = load { <3 x float> }, ptr %alloca, align 16
%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.142
fv.default: ; preds = %if.merge.146
br label %fv.merge
fv.case: ; preds = %if.merge.146
%fv.field = extractvalue { <3 x float> } %loadN, 0
%ba.tmp = alloca <3 x float>, align 16
store <3 x float> %fv.field, ptr %ba.tmp, align 16
%ba.p2i = ptrtoint ptr %ba.tmp to i64
%fv.val = insertvalue { i64, i64 } { i64 39, i64 undef }, i64 %ba.p2i, 1
br label %fv.merge
}
; Function Attrs: nounwind
define internal { ptr, i64 } @struct_to_string__Vec3(ptr %0, { <3 x float> } %1) #0 {
entry:
%alloca = alloca { <3 x float> }, align 16
store { <3 x float> } %1, ptr %alloca, align 16
%call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.253, i64 4 }, { ptr, i64 } { ptr @str.254, 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, 1
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.255, 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.256, 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 [1 x { ptr, i64 }], ptr @field_names.258, 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.259, i64 2 })
store { ptr, i64 } %callN, ptr %allocaN, align 8
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%loadN = load { <3 x float> }, ptr %alloca, align 16
%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.147
fv.default: ; preds = %if.merge.151
br label %fv.merge
fv.case: ; preds = %if.merge.151
%fv.field = extractvalue { <3 x float> } %loadN, 0
%ba.tmp = alloca <3 x float>, align 16
store <3 x float> %fv.field, ptr %ba.tmp, align 16
%ba.p2i = ptrtoint ptr %ba.tmp to i64
%fv.val = insertvalue { i64, i64 } { i64 39, i64 undef }, i64 %ba.p2i, 1
br label %fv.merge
}
; Function Attrs: nounwind
define internal { ptr, i64 } @struct_to_string__Complex__u32(ptr %0, { i32, i32 } %1) #0 {
entry:
%alloca = alloca { i32, i32 }, align 8
store { i32, i32 } %1, ptr %alloca, align 4
%call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.260, i64 12 }, { ptr, i64 } { ptr @str.261, 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, 2
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.262, 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.263, 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 [2 x { ptr, i64 }], ptr @field_names.266, 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.267, i64 2 })
store { ptr, i64 } %callN, ptr %allocaN, align 8
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%loadN = load { i32, i32 }, 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.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.152
fv.default: ; preds = %if.merge.156
br label %fv.merge
fv.case: ; preds = %if.merge.156
%fv.field = extractvalue { i32, i32 } %loadN, 0
%zN = zext i32 %fv.field to i64
%fv.val = insertvalue { i64, i64 } { i64 8, i64 undef }, i64 %zN, 1
br label %fv.merge
fv.case17: ; preds = %if.merge.156
%fv.field18 = extractvalue { i32, i32 } %loadN, 1
%zN = zext i32 %fv.field18 to i64
%fv.val20 = insertvalue { i64, i64 } { i64 8, i64 undef }, i64 %zN, 1
br label %fv.merge
}
; Function Attrs: nounwind
define internal { ptr, i64 } @struct_to_string__Foo(ptr %0, { i32, i32 } %1) #0 {
entry:
%alloca = alloca { i32, i32 }, align 8
store { i32, i32 } %1, ptr %alloca, align 4
%call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.268, i64 3 }, { ptr, i64 } { ptr @str.269, 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 = %fv.merge, %entry
%load = load i64, ptr %allocaN, align 8
%icmp = icmp slt i64 %load, 2
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.270, 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.271, 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 [2 x { ptr, i64 }], ptr @field_names.274, 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.275, i64 2 })
store { ptr, i64 } %callN, ptr %allocaN, align 8
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%loadN = load { i32, i32 }, 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.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.157
fv.default: ; preds = %if.merge.161
br label %fv.merge
fv.case: ; preds = %if.merge.161
%fv.field = extractvalue { i32, i32 } %loadN, 0
%zN = zext i32 %fv.field to i64
%fv.val = insertvalue { i64, i64 } { i64 8, i64 undef }, i64 %zN, 1
br label %fv.merge
fv.case17: ; preds = %if.merge.161
%fv.field18 = extractvalue { i32, i32 } %loadN, 1
%zN = zext i32 %fv.field18 to i64
%fv.val20 = insertvalue { i64, i64 } { i64 8, i64 undef }, i64 %zN, 1
br label %fv.merge
}
; Function Attrs: nounwind
define internal { ptr, i64 } @enum_to_string__Sx__f32(ptr %0, { i64, [4 x i8] } %1) #0 {
entry:
%alloca = alloca { i64, [4 x i8] }, align 8
store { i64, [4 x i8] } %1, ptr %alloca, align 8
%load = load { i64, [4 x i8] }, ptr %alloca, align 8
%etag = extractvalue { i64, [4 x i8] } %load, 0
%allocaN = alloca i64, align 8
store i64 %etag, ptr %allocaN, align 8
%loadN = load i64, ptr %allocaN, align 8
%fn.gep = getelementptr inbounds [2 x { ptr, i64 }], ptr @field_names.279, i64 0, i64 %loadN
%fn.load = load { ptr, i64 }, ptr %fn.gep, align 8
%call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.276, i64 1 }, { ptr, i64 } %fn.load)
%allocaN = alloca { ptr, i64 }, align 8
store { ptr, i64 } %call, ptr %allocaN, align 8
%loadN = load { i64, [4 x i8] }, 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.case6
]
if.then.165: ; preds = %fv.merge
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.281, i64 1 })
%callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.280, i64 1 }, { ptr, i64 } %callN)
%callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } %callN)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %if.merge.166
if.merge.166: ; preds = %if.then.165, %fv.merge
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
ret { ptr, i64 } %loadN
fv.merge: ; preds = %fv.default, %fv.case6, %fv.case
%fv.phi = phi { i64, i64 } [ %fv.val, %fv.case ], [ %fv.val10, %fv.case6 ], [ undef, %fv.default ]
%allocaN = alloca { i64, i64 }, align 8
store { i64, i64 } %fv.phi, ptr %allocaN, align 8
%loadN = load { i64, i64 }, ptr %allocaN, align 8
%callN = call { ptr, i64 } @any_to_string(ptr %0, { i64, 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
%icmp = icmp sgt i64 %len, 0
br i1 %icmp, label %if.then.165, label %if.merge.166
fv.default: ; preds = %entry
br label %fv.merge
fv.case: ; preds = %entry
%fv.utmp = alloca { i64, [4 x i8] }, align 8
store { i64, [4 x i8] } %loadN, ptr %fv.utmp, align 8
%fv.pp = getelementptr inbounds { i64, [4 x i8] }, ptr %fv.utmp, i32 0, i32 1
%fv.field = load i32, ptr %fv.pp, align 4
%sN = sext i32 %fv.field to i64
%fv.val = insertvalue { i64, i64 } { i64 4, i64 undef }, i64 %sN, 1
br label %fv.merge
fv.case6: ; preds = %entry
%fv.utmp7 = alloca { i64, [4 x i8] }, align 8
store { i64, [4 x i8] } %loadN, ptr %fv.utmp7, align 8
%fv.pp8 = getelementptr inbounds { i64, [4 x i8] }, ptr %fv.utmp7, i32 0, i32 1
%fv.field9 = load float, ptr %fv.pp8, align 4
%fNi32 = bitcast float %fv.field9 to i32
%zN = zext i32 %fNi32 to i64
%fv.val10 = insertvalue { i64, i64 } { i64 10, i64 undef }, i64 %zN, 1
br label %fv.merge
}
; Function Attrs: nounwind
define internal { ptr, i64 } @vector_to_string__vec_3_f32(ptr %0, <3 x float> %1) #0 {
entry:
%alloca = alloca <3 x float>, align 16
store <3 x float> %1, ptr %alloca, align 16
%allocaN = alloca { ptr, i64 }, align 8
store { ptr, i64 } { ptr @str.282, i64 1 }, ptr %allocaN, align 8
%allocaN = alloca i64, align 8
store i64 0, ptr %allocaN, align 8
br label %while.hdr.170
while.hdr.170: ; preds = %if.merge.174, %entry
%load = load i64, ptr %allocaN, align 8
%icmp = icmp slt i64 %load, 3
br i1 %icmp, label %while.body.171, label %while.exit.172
while.body.171: ; preds = %while.hdr.170
%loadN = load i64, ptr %allocaN, align 8
%icmpN = icmp sgt i64 %loadN, 0
br i1 %icmpN, label %if.then.173, label %if.merge.174
while.exit.172: ; preds = %while.hdr.170
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.283, i64 1 })
ret { ptr, i64 } %call
if.then.173: ; preds = %while.body.171
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.284, i64 2 })
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %if.merge.174
if.merge.174: ; preds = %if.then.173, %while.body.171
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%loadN = load <3 x float>, ptr %alloca, align 16
%loadN = load i64, ptr %allocaN, align 8
%ca.tr = trunc i64 %loadN to i32
%ve = extractelement <3 x float> %loadN, i32 %ca.tr
%fNi32 = bitcast float %ve to i32
%zN = zext i32 %fNi32 to i64
%ba.val = insertvalue { i64, i64 } { i64 10, i64 undef }, i64 %zN, 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.170
}
; Function Attrs: nounwind
define internal { ptr, i64 } @array_to_string__AR_16_f32(ptr %0, [16 x float] %1) #0 {
entry:
%alloca = alloca [16 x float], align 4
store [16 x float] %1, ptr %alloca, align 4
%allocaN = alloca { ptr, i64 }, align 8
store { ptr, i64 } { ptr @str.285, i64 1 }, ptr %allocaN, align 8
%allocaN = alloca i64, align 8
store i64 0, ptr %allocaN, align 8
br label %while.hdr.180
while.hdr.180: ; preds = %if.merge.184, %entry
%load = load i64, ptr %allocaN, align 8
%icmp = icmp slt i64 %load, 16
br i1 %icmp, label %while.body.181, label %while.exit.182
while.body.181: ; preds = %while.hdr.180
%loadN = load i64, ptr %allocaN, align 8
%icmpN = icmp sgt i64 %loadN, 0
br i1 %icmpN, label %if.then.183, label %if.merge.184
while.exit.182: ; preds = %while.hdr.180
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.286, i64 1 })
ret { ptr, i64 } %call
if.then.183: ; preds = %while.body.181
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.287, i64 2 })
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %if.merge.184
if.merge.184: ; preds = %if.then.183, %while.body.181
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%loadN = load [16 x float], ptr %alloca, align 4
%loadN = load i64, ptr %allocaN, align 8
%ig.tmp = alloca [16 x float], align 4
store [16 x float] %loadN, ptr %ig.tmp, align 4
%ig.ptr = getelementptr [16 x float], ptr %ig.tmp, i64 0, i64 %loadN
%ig.val = load float, ptr %ig.ptr, align 4
%fNi32 = bitcast float %ig.val to i32
%zN = zext i32 %fNi32 to i64
%ba.val = insertvalue { i64, i64 } { i64 10, i64 undef }, i64 %zN, 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.180
}
; 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.288, i64 1 }, ptr %allocaN, align 8
%allocaN = alloca i64, align 8
store i64 0, ptr %allocaN, align 8
br label %while.hdr.185
while.hdr.185: ; preds = %if.merge.189, %entry
%load = load i64, ptr %allocaN, align 8
%icmp = icmp slt i64 %load, 1
br i1 %icmp, label %while.body.186, label %while.exit.187
while.body.186: ; preds = %while.hdr.185
%loadN = load i64, ptr %allocaN, align 8
%icmpN = icmp sgt i64 %loadN, 0
br i1 %icmpN, label %if.then.188, label %if.merge.189
while.exit.187: ; preds = %while.hdr.185
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.289, i64 1 })
ret { ptr, i64 } %call
if.then.188: ; preds = %while.body.186
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.290, i64 2 })
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %if.merge.189
if.merge.189: ; preds = %if.then.188, %while.body.186
%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.185
}
; Function Attrs: nounwind
define internal { ptr, i64 } @array_to_string__AR_5_f32(ptr %0, [5 x float] %1) #0 {
entry:
%alloca = alloca [5 x float], align 4
store [5 x float] %1, ptr %alloca, align 4
%allocaN = alloca { ptr, i64 }, align 8
store { ptr, i64 } { ptr @str.291, i64 1 }, ptr %allocaN, align 8
%allocaN = alloca i64, align 8
store i64 0, ptr %allocaN, align 8
br label %while.hdr.190
while.hdr.190: ; preds = %if.merge.194, %entry
%load = load i64, ptr %allocaN, align 8
%icmp = icmp slt i64 %load, 5
br i1 %icmp, label %while.body.191, label %while.exit.192
while.body.191: ; preds = %while.hdr.190
%loadN = load i64, ptr %allocaN, align 8
%icmpN = icmp sgt i64 %loadN, 0
br i1 %icmpN, label %if.then.193, label %if.merge.194
while.exit.192: ; preds = %while.hdr.190
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.292, i64 1 })
ret { ptr, i64 } %call
if.then.193: ; preds = %while.body.191
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.293, i64 2 })
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %if.merge.194
if.merge.194: ; preds = %if.then.193, %while.body.191
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%loadN = load [5 x float], ptr %alloca, align 4
%loadN = load i64, ptr %allocaN, align 8
%ig.tmp = alloca [5 x float], align 4
store [5 x float] %loadN, ptr %ig.tmp, align 4
%ig.ptr = getelementptr [5 x float], ptr %ig.tmp, i64 0, i64 %loadN
%ig.val = load float, ptr %ig.ptr, align 4
%fNi32 = bitcast float %ig.val to i32
%zN = zext i32 %fNi32 to i64
%ba.val = insertvalue { i64, i64 } { i64 10, i64 undef }, i64 %zN, 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.190
}
; 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.294, i64 1 }, ptr %allocaN, align 8
%allocaN = alloca i64, align 8
store i64 0, ptr %allocaN, align 8
br label %while.hdr.199
while.hdr.199: ; preds = %if.merge.203, %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.200, label %while.exit.201
while.body.200: ; preds = %while.hdr.199
%loadN = load i64, ptr %allocaN, align 8
%icmpN = icmp sgt i64 %loadN, 0
br i1 %icmpN, label %if.then.202, label %if.merge.203
while.exit.201: ; preds = %while.hdr.199
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.295, i64 1 })
ret { ptr, i64 } %call
if.then.202: ; preds = %while.body.200
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.296, i64 2 })
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %if.merge.203
if.merge.203: ; preds = %if.then.202, %while.body.200
%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.199
}
; 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.297, i64 1 }, ptr %allocaN, align 8
%allocaN = alloca i64, align 8
store i64 0, ptr %allocaN, align 8
br label %while.hdr.204
while.hdr.204: ; preds = %if.merge.208, %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.205, label %while.exit.206
while.body.205: ; preds = %while.hdr.204
%loadN = load i64, ptr %allocaN, align 8
%icmpN = icmp sgt i64 %loadN, 0
br i1 %icmpN, label %if.then.207, label %if.merge.208
while.exit.206: ; preds = %while.hdr.204
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%call = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.298, i64 1 })
ret { ptr, i64 } %call
if.then.207: ; preds = %while.body.205
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } %loadN, { ptr, i64 } { ptr @str.299, i64 2 })
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %if.merge.208
if.merge.208: ; preds = %if.then.207, %while.body.205
%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.204
}
; 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.235, label %if.else.236
if.then.235: ; preds = %entry
br label %if.merge.237
if.else.236: ; 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.237
if.merge.237: ; preds = %if.else.236, %if.then.235
%bp = phi { ptr, i64 } [ { ptr @str.300, i64 4 }, %if.then.235 ], [ %callN, %if.else.236 ]
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.259, label %if.else.260
if.then.259: ; preds = %entry
br label %if.merge.261
if.else.260: ; 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 11 }, { ptr, i64 } %callN)
br label %if.merge.261
if.merge.261: ; preds = %if.else.260, %if.then.259
%bp = phi { ptr, i64 } [ { ptr @str.303, i64 4 }, %if.then.259 ], [ %callN, %if.else.260 ]
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.262, label %if.else.263
if.then.262: ; preds = %entry
br label %if.merge.264
if.else.263: ; 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.264
if.merge.264: ; preds = %if.else.263, %if.then.262
%bp = phi { ptr, i64 } [ { ptr @str.306, i64 4 }, %if.then.262 ], [ %callN, %if.else.263 ]
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.265, label %if.else.266
if.then.265: ; preds = %entry
br label %if.merge.267
if.else.266: ; 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 11 }, { ptr, i64 } %callN)
br label %if.merge.267
if.merge.267: ; preds = %if.else.266, %if.then.265
%bp = phi { ptr, i64 } [ { ptr @str.309, i64 4 }, %if.then.265 ], [ %callN, %if.else.266 ]
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.268, label %if.else.269
if.then.268: ; preds = %entry
br label %if.merge.270
if.else.269: ; 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 6 }, { ptr, i64 } %callN)
br label %if.merge.270
if.merge.270: ; preds = %if.else.269, %if.then.268
%bp = phi { ptr, i64 } [ { ptr @str.312, i64 4 }, %if.then.268 ], [ %callN, %if.else.269 ]
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.271, label %if.else.272
if.then.271: ; preds = %entry
br label %if.merge.273
if.else.272: ; 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 5 }, { ptr, i64 } %callN)
br label %if.merge.273
if.merge.273: ; preds = %if.else.272, %if.then.271
%bp = phi { ptr, i64 } [ { ptr @str.315, i64 4 }, %if.then.271 ], [ %callN, %if.else.272 ]
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.274, label %if.else.275
if.then.274: ; preds = %entry
br label %if.merge.276
if.else.275: ; 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 9 }, { ptr, i64 } %callN)
br label %if.merge.276
if.merge.276: ; preds = %if.else.275, %if.then.274
%bp = phi { ptr, i64 } [ { ptr @str.318, i64 4 }, %if.then.274 ], [ %callN, %if.else.275 ]
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.277, label %if.else.278
if.then.277: ; preds = %entry
br label %if.merge.279
if.else.278: ; 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.279
if.merge.279: ; preds = %if.else.278, %if.then.277
%bp = phi { ptr, i64 } [ { ptr @str.321, i64 4 }, %if.then.277 ], [ %callN, %if.else.278 ]
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.280, label %if.else.281
if.then.280: ; preds = %entry
br label %if.merge.282
if.else.281: ; 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.326, i64 3 }, { ptr, i64 } %call)
%callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.325, i64 12 }, { ptr, i64 } %callN)
br label %if.merge.282
if.merge.282: ; preds = %if.else.281, %if.then.280
%bp = phi { ptr, i64 } [ { ptr @str.324, i64 4 }, %if.then.280 ], [ %callN, %if.else.281 ]
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.283, label %if.else.284
if.then.283: ; preds = %entry
br label %if.merge.285
if.else.284: ; 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.329, i64 3 }, { ptr, i64 } %call)
%callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.328, i64 4 }, { ptr, i64 } %callN)
br label %if.merge.285
if.merge.285: ; preds = %if.else.284, %if.then.283
%bp = phi { ptr, i64 } [ { ptr @str.327, i64 4 }, %if.then.283 ], [ %callN, %if.else.284 ]
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.286, label %if.else.287
if.then.286: ; preds = %entry
br label %if.merge.288
if.else.287: ; 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.332, i64 3 }, { ptr, i64 } %call)
%callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.331, i64 6 }, { ptr, i64 } %callN)
br label %if.merge.288
if.merge.288: ; preds = %if.else.287, %if.then.286
%bp = phi { ptr, i64 } [ { ptr @str.330, i64 4 }, %if.then.286 ], [ %callN, %if.else.287 ]
ret { ptr, i64 } %bp
}
; Function Attrs: nounwind
define internal { ptr, i64 } @pointer_to_string__ptr_Vec3(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.289, label %if.else.290
if.then.289: ; preds = %entry
br label %if.merge.291
if.else.290: ; 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.335, i64 3 }, { ptr, i64 } %call)
%callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.334, i64 5 }, { ptr, i64 } %callN)
br label %if.merge.291
if.merge.291: ; preds = %if.else.290, %if.then.289
%bp = phi { ptr, i64 } [ { ptr @str.333, i64 4 }, %if.then.289 ], [ %callN, %if.else.290 ]
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.292, label %if.else.293
if.then.292: ; preds = %entry
br label %if.merge.294
if.else.293: ; 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.338, i64 3 }, { ptr, i64 } %call)
%callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.337, i64 7 }, { ptr, i64 } %callN)
br label %if.merge.294
if.merge.294: ; preds = %if.else.293, %if.then.292
%bp = phi { ptr, i64 } [ { ptr @str.336, i64 4 }, %if.then.292 ], [ %callN, %if.else.293 ]
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.295, label %if.else.296
if.then.295: ; preds = %entry
br label %if.merge.297
if.else.296: ; 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.341, i64 3 }, { ptr, i64 } %call)
%callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.340, i64 4 }, { ptr, i64 } %callN)
br label %if.merge.297
if.merge.297: ; preds = %if.else.296, %if.then.295
%bp = phi { ptr, i64 } [ { ptr @str.339, i64 4 }, %if.then.295 ], [ %callN, %if.else.296 ]
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.298, label %if.else.299
if.then.298: ; preds = %entry
br label %if.merge.300
if.else.299: ; 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.344, i64 3 }, { ptr, i64 } %call)
%callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.343, i64 7 }, { ptr, i64 } %callN)
br label %if.merge.300
if.merge.300: ; preds = %if.else.299, %if.then.298
%bp = phi { ptr, i64 } [ { ptr @str.342, i64 4 }, %if.then.298 ], [ %callN, %if.else.299 ]
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.301, label %if.else.302
if.then.301: ; preds = %entry
br label %if.merge.303
if.else.302: ; 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.347, i64 3 }, { ptr, i64 } %call)
%callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.346, i64 6 }, { ptr, i64 } %callN)
br label %if.merge.303
if.merge.303: ; preds = %if.else.302, %if.then.301
%bp = phi { ptr, i64 } [ { ptr @str.345, i64 4 }, %if.then.301 ], [ %callN, %if.else.302 ]
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.304, label %if.else.305
if.then.304: ; preds = %entry
br label %if.merge.306
if.else.305: ; 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.350, i64 3 }, { ptr, i64 } %call)
%callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.349, i64 3 }, { ptr, i64 } %callN)
br label %if.merge.306
if.merge.306: ; preds = %if.else.305, %if.then.304
%bp = phi { ptr, i64 } [ { ptr @str.348, i64 4 }, %if.then.304 ], [ %callN, %if.else.305 ]
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.307, label %if.else.308
if.then.307: ; preds = %entry
br label %if.merge.309
if.else.308: ; 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.353, i64 3 }, { ptr, i64 } %call)
%callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.352, i64 5 }, { ptr, i64 } %callN)
br label %if.merge.309
if.merge.309: ; preds = %if.else.308, %if.then.307
%bp = phi { ptr, i64 } [ { ptr @str.351, i64 4 }, %if.then.307 ], [ %callN, %if.else.308 ]
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.310, label %if.else.311
if.then.310: ; preds = %entry
br label %if.merge.312
if.else.311: ; 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.356, i64 3 }, { ptr, i64 } %call)
%callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.355, i64 4 }, { ptr, i64 } %callN)
br label %if.merge.312
if.merge.312: ; preds = %if.else.311, %if.then.310
%bp = phi { ptr, i64 } [ { ptr @str.354, i64 4 }, %if.then.310 ], [ %callN, %if.else.311 ]
ret { ptr, i64 } %bp
}
; Function Attrs: nounwind
define internal { ptr, i64 } @pointer_to_string__ptr_vec_3_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.313, label %if.else.314
if.then.313: ; preds = %entry
br label %if.merge.315
if.else.314: ; 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.359, i64 3 }, { ptr, i64 } %call)
%callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.358, i64 14 }, { ptr, i64 } %callN)
br label %if.merge.315
if.merge.315: ; preds = %if.else.314, %if.then.313
%bp = phi { ptr, i64 } [ { ptr @str.357, i64 4 }, %if.then.313 ], [ %callN, %if.else.314 ]
ret { ptr, i64 } %bp
}
; Function Attrs: nounwind
define internal { ptr, i64 } @pointer_to_string__ptr_AR_5_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.316, label %if.else.317
if.then.316: ; preds = %entry
br label %if.merge.318
if.else.317: ; 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.362, i64 3 }, { ptr, i64 } %call)
%callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.361, i64 7 }, { ptr, i64 } %callN)
br label %if.merge.318
if.merge.318: ; preds = %if.else.317, %if.then.316
%bp = phi { ptr, i64 } [ { ptr @str.360, i64 4 }, %if.then.316 ], [ %callN, %if.else.317 ]
ret { ptr, i64 } %bp
}
; Function Attrs: nounwind
define internal { ptr, i64 } @pointer_to_string__ptr_Foo(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.319, label %if.else.320
if.then.319: ; preds = %entry
br label %if.merge.321
if.else.320: ; 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.365, i64 3 }, { ptr, i64 } %call)
%callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.364, i64 4 }, { ptr, i64 } %callN)
br label %if.merge.321
if.merge.321: ; preds = %if.else.320, %if.then.319
%bp = phi { ptr, i64 } [ { ptr @str.363, i64 4 }, %if.then.319 ], [ %callN, %if.else.320 ]
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.322, label %if.else.323
if.then.322: ; preds = %entry
br label %if.merge.324
if.else.323: ; 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.368, i64 3 }, { ptr, i64 } %call)
%callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.367, i64 4 }, { ptr, i64 } %callN)
br label %if.merge.324
if.merge.324: ; preds = %if.else.323, %if.then.322
%bp = phi { ptr, i64 } [ { ptr @str.366, i64 4 }, %if.then.322 ], [ %callN, %if.else.323 ]
ret { ptr, i64 } %bp
}
; Function Attrs: nounwind
define internal { ptr, i64 } @pointer_to_string__ptr_Sx__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.325, label %if.else.326
if.then.325: ; preds = %entry
br label %if.merge.327
if.else.326: ; 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.371, i64 3 }, { ptr, i64 } %call)
%callN = call { ptr, i64 } @concat(ptr %0, { ptr, i64 } { ptr @str.370, i64 8 }, { ptr, i64 } %callN)
br label %if.merge.327
if.merge.327: ; preds = %if.else.326, %if.then.325
%bp = phi { ptr, i64 } [ { ptr @str.369, i64 4 }, %if.then.325 ], [ %callN, %if.else.326 ]
ret { ptr, i64 } %bp
}
declare i64 @write(i32, ptr, i64)
declare double @sqrt(double)