Files
sx/tests/expected/ffi-objc-call-06-sret-return.ir
agra 29784c22a8 mem: implicit-context foundation + many compiler fixes
The session-long set of changes that lay the groundwork for the
Jai-literal implicit-Context-parameter refactor. Lots of accumulated
work; the new arrival is the implicit-ctx foundation (steps 1+2 of
the plan in current/CHECKPOINT-MEM.md):

  Step 1 — `CAllocator :: struct {}` stateless allocator in
    library/modules/allocators.sx, delegating directly to
    libc_malloc/libc_free. `ConstantValue` in src/ir/inst.zig gains a
    `func_ref: FuncId` leaf so nested aggregates can carry function
    pointers (the inline Allocator value's fn-ptr fields). Switch
    sites updated in emit_llvm.zig, print.zig, interp.zig.

  Step 2 — `emitDefaultContextGlobal` in src/ir/lower.zig synthesises
    a static `__sx_default_context` global with a nested-aggregate
    init_val pointing at the CAllocator → Allocator thunks. The
    second-pass `initVtableGlobals` in emit_llvm.zig is generalised
    to handle `.aggregate` init_vals (re-emits after func_map is
    populated so func_ref leaves resolve to real symbols).

Also folded in from earlier work this session:

  - Phase 1.1: `xx value` heap-copy in `buildProtocolValue` routes
    through `context.allocator` via the new `allocViaContext` helper.
  - interp.zig: `marshalForeignArg` double-offset bug fixed —
    `heapSlice` already adds `hp.offset` to the slice ptr, so the
    extra `+ hp.offset` was scribbling memcpy/memset into adjacent
    heap state, corrupting `heap.items[0]`. Symptom: `build_format`
    at comptime produced zero bytes, all `print` calls failed.
  - Lazy lowering: `lazyLowerFunction` now declares foreign-body
    functions as extern stubs in the local (comptime) module so
    cross-module foreign calls resolve.
  - Allocator API: all stdlib allocators on one-line `init() -> *T`
    (CAllocator/GPA: libc-backed; Arena/TrackingAllocator: parent-
    backed; BufAlloc: embeds state at head of user buffer).
  - issues 0038 (transitive #import), 0039 (chess + stdlib migration
    fallout), 0040 (generic struct method dot-dispatch), 0041
    (pointer types as type-arg), 0042 (alias name resolution) — all
    fixed; regression tests in examples/.
  - Diagnostic: `emitError` now embeds the lowering's
    `current_source_file` and enclosing function in the literal
    message; SX_TRACE_UNRESOLVED=1 dumps a Zig stack trace at the
    emit site so misattributed spans can't hide where the failure
    is.
  - tools/verify-step.sh (all-platforms gate) and tools/scratch.sh
    (interp/codegen parity tester) added.

Test suite: 152 example tests pass; chess builds + screenshots on
macOS / iOS sim / Android.
2026-05-24 22:59:20 +03:00

3375 lines
146 KiB
Plaintext

@context = internal global { { ptr, ptr, ptr }, ptr } zeroinitializer
@OS = internal global i64 0
@ARCH = internal global i64 0
@POINTER_SIZE = internal global i64 8
@__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 }
@OBJC_SELECTOR_REFERENCES_tripleValue = internal global 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
@str.6 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1
@str.7 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1
@str.8 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1
@str.9 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1
@str.10 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1
@str.11 = private unnamed_addr constant [9 x i8] c"NSObject\00", align 1
@str.12 = private unnamed_addr constant [14 x i8] c"SxTripleProbe\00", align 1
@str.13 = private unnamed_addr constant [12 x i8] c"tripleValue\00", align 1
@str.14 = private unnamed_addr constant [15 x i8] c"{Triple=qqq}@:\00", align 1
@str.15 = private unnamed_addr constant [16 x i8] c"addMethod = {}\0A\00", align 1
@str.16 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1
@str.17 = private unnamed_addr constant [23 x i8] c"triple = ({}, {}, {})\0A\00", align 1
@str.18 = private unnamed_addr constant [1 x i8] zeroinitializer, align 1
@str.19 = private unnamed_addr constant [10 x i8] c"Allocator\00", align 1
@str.20 = private unnamed_addr constant [2 x i8] c"{\00", align 1
@str.21 = private unnamed_addr constant [2 x i8] c"}\00", align 1
@str.22 = private unnamed_addr constant [3 x i8] c", \00", align 1
@fld.str = private constant [4 x i8] c"ctx\00"
@fld.str.23 = private constant [6 x i8] c"alloc\00"
@fld.str.24 = private constant [8 x i8] c"dealloc\00"
@field_names = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str, i64 3 }, { ptr, i64 } { ptr @fld.str.23, i64 5 }, { ptr, i64 } { ptr @fld.str.24, i64 7 }]
@str.25 = private unnamed_addr constant [3 x i8] c": \00", align 1
@str.26 = private unnamed_addr constant [11 x i8] c"CAllocator\00", align 1
@str.27 = private unnamed_addr constant [2 x i8] c"{\00", align 1
@str.28 = private unnamed_addr constant [2 x i8] c"}\00", align 1
@str.29 = private unnamed_addr constant [3 x i8] c", \00", align 1
@field_names.30 = private constant [0 x { ptr, i64 }] zeroinitializer
@str.31 = private unnamed_addr constant [3 x i8] c": \00", align 1
@str.32 = private unnamed_addr constant [4 x i8] c"GPA\00", align 1
@str.33 = private unnamed_addr constant [2 x i8] c"{\00", align 1
@str.34 = private unnamed_addr constant [2 x i8] c"}\00", align 1
@str.35 = private unnamed_addr constant [3 x i8] c", \00", align 1
@fld.str.36 = private constant [12 x i8] c"alloc_count\00"
@field_names.37 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.36, i64 11 }]
@str.38 = private unnamed_addr constant [3 x i8] c": \00", align 1
@str.39 = private unnamed_addr constant [11 x i8] c"ArenaChunk\00", align 1
@str.40 = private unnamed_addr constant [2 x i8] c"{\00", align 1
@str.41 = private unnamed_addr constant [2 x i8] c"}\00", align 1
@str.42 = private unnamed_addr constant [3 x i8] c", \00", align 1
@fld.str.43 = private constant [5 x i8] c"next\00"
@fld.str.44 = private constant [4 x i8] c"cap\00"
@field_names.45 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.43, i64 4 }, { ptr, i64 } { ptr @fld.str.44, i64 3 }]
@str.46 = private unnamed_addr constant [3 x i8] c": \00", align 1
@str.47 = private unnamed_addr constant [6 x i8] c"Arena\00", align 1
@str.48 = private unnamed_addr constant [2 x i8] c"{\00", align 1
@str.49 = private unnamed_addr constant [2 x i8] c"}\00", align 1
@str.50 = private unnamed_addr constant [3 x i8] c", \00", align 1
@fld.str.51 = private constant [6 x i8] c"first\00"
@fld.str.52 = private constant [10 x i8] c"end_index\00"
@fld.str.53 = private constant [7 x i8] c"parent\00"
@field_names.54 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.51, i64 5 }, { ptr, i64 } { ptr @fld.str.52, i64 9 }, { ptr, i64 } { ptr @fld.str.53, i64 6 }]
@str.55 = private unnamed_addr constant [3 x i8] c": \00", align 1
@str.56 = private unnamed_addr constant [9 x i8] c"BufAlloc\00", align 1
@str.57 = private unnamed_addr constant [2 x i8] c"{\00", align 1
@str.58 = private unnamed_addr constant [2 x i8] c"}\00", align 1
@str.59 = private unnamed_addr constant [3 x i8] c", \00", align 1
@fld.str.60 = private constant [4 x i8] c"buf\00"
@fld.str.61 = private constant [4 x i8] c"len\00"
@fld.str.62 = private constant [4 x i8] c"pos\00"
@field_names.63 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.60, i64 3 }, { ptr, i64 } { ptr @fld.str.61, i64 3 }, { ptr, i64 } { ptr @fld.str.62, i64 3 }]
@str.64 = private unnamed_addr constant [3 x i8] c": \00", align 1
@str.65 = private unnamed_addr constant [18 x i8] c"TrackingAllocator\00", align 1
@str.66 = private unnamed_addr constant [2 x i8] c"{\00", align 1
@str.67 = private unnamed_addr constant [2 x i8] c"}\00", align 1
@str.68 = private unnamed_addr constant [3 x i8] c", \00", align 1
@fld.str.69 = private constant [7 x i8] c"parent\00"
@fld.str.70 = private constant [12 x i8] c"alloc_count\00"
@fld.str.71 = private constant [14 x i8] c"dealloc_count\00"
@fld.str.72 = private constant [18 x i8] c"total_alloc_bytes\00"
@field_names.73 = private constant [4 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.69, i64 6 }, { ptr, i64 } { ptr @fld.str.70, i64 11 }, { ptr, i64 } { ptr @fld.str.71, i64 13 }, { ptr, i64 } { ptr @fld.str.72, i64 17 }]
@str.74 = private unnamed_addr constant [3 x i8] c": \00", align 1
@str.75 = private unnamed_addr constant [8 x i8] c"Context\00", align 1
@str.76 = private unnamed_addr constant [2 x i8] c"{\00", align 1
@str.77 = private unnamed_addr constant [2 x i8] c"}\00", align 1
@str.78 = private unnamed_addr constant [3 x i8] c", \00", align 1
@fld.str.79 = private constant [10 x i8] c"allocator\00"
@fld.str.80 = private constant [5 x i8] c"data\00"
@field_names.81 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.79, i64 9 }, { ptr, i64 } { ptr @fld.str.80, i64 4 }]
@str.82 = private unnamed_addr constant [3 x i8] c": \00", align 1
@str.83 = private unnamed_addr constant [13 x i8] c"BuildOptions\00", align 1
@str.84 = private unnamed_addr constant [2 x i8] c"{\00", align 1
@str.85 = private unnamed_addr constant [2 x i8] c"}\00", align 1
@str.86 = private unnamed_addr constant [3 x i8] c", \00", align 1
@field_names.87 = private constant [0 x { ptr, i64 }] zeroinitializer
@str.88 = private unnamed_addr constant [3 x i8] c": \00", align 1
@str.89 = private unnamed_addr constant [7 x i8] c"Triple\00", align 1
@str.90 = private unnamed_addr constant [2 x i8] c"{\00", align 1
@str.91 = private unnamed_addr constant [2 x i8] c"}\00", align 1
@str.92 = private unnamed_addr constant [3 x i8] c", \00", align 1
@fld.str.93 = private constant [2 x i8] c"a\00"
@fld.str.94 = private constant [2 x i8] c"b\00"
@fld.str.95 = private constant [2 x i8] c"c\00"
@field_names.96 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.93, i64 1 }, { ptr, i64 } { ptr @fld.str.94, i64 1 }, { ptr, i64 } { ptr @fld.str.95, i64 1 }]
@str.97 = private unnamed_addr constant [3 x i8] c": \00", align 1
@str.98 = private unnamed_addr constant [2 x i8] c".\00", align 1
@fld.str.99 = private constant [6 x i8] c"macos\00"
@fld.str.100 = private constant [6 x i8] c"linux\00"
@fld.str.101 = private constant [8 x i8] c"windows\00"
@fld.str.102 = private constant [5 x i8] c"wasm\00"
@fld.str.103 = private constant [4 x i8] c"ios\00"
@fld.str.104 = private constant [8 x i8] c"android\00"
@fld.str.105 = private constant [8 x i8] c"unknown\00"
@field_names.106 = private constant [7 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.99, i64 5 }, { ptr, i64 } { ptr @fld.str.100, i64 5 }, { ptr, i64 } { ptr @fld.str.101, i64 7 }, { ptr, i64 } { ptr @fld.str.102, i64 4 }, { ptr, i64 } { ptr @fld.str.103, i64 3 }, { ptr, i64 } { ptr @fld.str.104, i64 7 }, { ptr, i64 } { ptr @fld.str.105, i64 7 }]
@str.107 = private unnamed_addr constant [2 x i8] c"(\00", align 1
@str.108 = private unnamed_addr constant [2 x i8] c")\00", align 1
@str.109 = private unnamed_addr constant [2 x i8] c".\00", align 1
@fld.str.110 = private constant [8 x i8] c"aarch64\00"
@fld.str.111 = private constant [7 x i8] c"x86_64\00"
@fld.str.112 = private constant [7 x i8] c"wasm32\00"
@fld.str.113 = private constant [7 x i8] c"wasm64\00"
@fld.str.114 = private constant [8 x i8] c"unknown\00"
@field_names.115 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.110, i64 7 }, { ptr, i64 } { ptr @fld.str.111, i64 6 }, { ptr, i64 } { ptr @fld.str.112, i64 6 }, { ptr, i64 } { ptr @fld.str.113, i64 6 }, { ptr, i64 } { ptr @fld.str.114, i64 7 }]
@str.116 = private unnamed_addr constant [2 x i8] c"(\00", align 1
@str.117 = private unnamed_addr constant [2 x i8] c")\00", align 1
@str.118 = private unnamed_addr constant [2 x i8] c"[\00", align 1
@str.119 = private unnamed_addr constant [2 x i8] c"]\00", align 1
@str.120 = private unnamed_addr constant [3 x i8] c", \00", align 1
@str.121 = private unnamed_addr constant [2 x i8] c"[\00", align 1
@str.122 = private unnamed_addr constant [2 x i8] c"]\00", align 1
@str.123 = private unnamed_addr constant [3 x i8] c", \00", align 1
@str.124 = private unnamed_addr constant [2 x i8] c"[\00", align 1
@str.125 = private unnamed_addr constant [2 x i8] c"]\00", align 1
@str.126 = private unnamed_addr constant [3 x i8] c", \00", align 1
@str.127 = private unnamed_addr constant [2 x i8] c"[\00", align 1
@str.128 = private unnamed_addr constant [2 x i8] c"]\00", align 1
@str.129 = private unnamed_addr constant [3 x i8] c", \00", align 1
@str.130 = private unnamed_addr constant [5 x i8] c"null\00", align 1
@str.131 = private unnamed_addr constant [6 x i8] c"*void\00", align 1
@str.132 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1
@str.133 = private unnamed_addr constant [5 x i8] c"null\00", align 1
@str.134 = private unnamed_addr constant [12 x i8] c"*CAllocator\00", align 1
@str.135 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1
@str.136 = private unnamed_addr constant [5 x i8] c"null\00", align 1
@str.137 = private unnamed_addr constant [5 x i8] c"*GPA\00", align 1
@str.138 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1
@str.139 = private unnamed_addr constant [5 x i8] c"null\00", align 1
@str.140 = private unnamed_addr constant [12 x i8] c"*ArenaChunk\00", align 1
@str.141 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1
@str.142 = private unnamed_addr constant [5 x i8] c"null\00", align 1
@str.143 = private unnamed_addr constant [7 x i8] c"*Arena\00", align 1
@str.144 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1
@str.145 = private unnamed_addr constant [5 x i8] c"null\00", align 1
@str.146 = private unnamed_addr constant [6 x i8] c"[*]u8\00", align 1
@str.147 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1
@str.148 = private unnamed_addr constant [5 x i8] c"null\00", align 1
@str.149 = private unnamed_addr constant [10 x i8] c"*BufAlloc\00", align 1
@str.150 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1
@str.151 = private unnamed_addr constant [5 x i8] c"null\00", align 1
@str.152 = private unnamed_addr constant [19 x i8] c"*TrackingAllocator\00", align 1
@str.153 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1
@str.154 = private unnamed_addr constant [5 x i8] c"null\00", align 1
@str.155 = private unnamed_addr constant [13 x i8] c"**CAllocator\00", align 1
@str.156 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1
@str.157 = private unnamed_addr constant [5 x i8] c"null\00", align 1
@str.158 = private unnamed_addr constant [5 x i8] c"*s64\00", align 1
@str.159 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1
@str.160 = private unnamed_addr constant [5 x i8] c"null\00", align 1
@str.161 = private unnamed_addr constant [7 x i8] c"**void\00", align 1
@str.162 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1
@str.163 = private unnamed_addr constant [5 x i8] c"null\00", align 1
@str.164 = private unnamed_addr constant [6 x i8] c"**GPA\00", align 1
@str.165 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1
@str.166 = private unnamed_addr constant [5 x i8] c"null\00", align 1
@str.167 = private unnamed_addr constant [6 x i8] c"*bool\00", align 1
@str.168 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1
@str.169 = private unnamed_addr constant [5 x i8] c"null\00", align 1
@str.170 = private unnamed_addr constant [8 x i8] c"*[1]Any\00", align 1
@str.171 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1
@str.172 = private unnamed_addr constant [5 x i8] c"null\00", align 1
@str.173 = private unnamed_addr constant [5 x i8] c"*Any\00", align 1
@str.174 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1
@str.175 = private unnamed_addr constant [5 x i8] c"null\00", align 1
@str.176 = private unnamed_addr constant [7 x i8] c"*[]Any\00", align 1
@str.177 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1
@str.178 = private unnamed_addr constant [5 x i8] c"null\00", align 1
@str.179 = private unnamed_addr constant [8 x i8] c"*string\00", align 1
@str.180 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1
@str.181 = private unnamed_addr constant [5 x i8] c"null\00", align 1
@str.182 = private unnamed_addr constant [4 x i8] c"*u8\00", align 1
@str.183 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1
@str.184 = private unnamed_addr constant [5 x i8] c"null\00", align 1
@str.185 = private unnamed_addr constant [8 x i8] c"*Triple\00", align 1
@str.186 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1
@str.187 = private unnamed_addr constant [5 x i8] c"null\00", align 1
@str.188 = private unnamed_addr constant [8 x i8] c"*[3]Any\00", align 1
@str.189 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1
@OBJC_METH_VAR_NAME_ = private unnamed_addr constant [12 x i8] c"tripleValue\00"
@llvm.global_ctors = appending global [1 x { i32, ptr, ptr }] [{ i32, ptr, ptr } { i32 65535, ptr @__sx_objc_selector_init, ptr null }]
; 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, i64 %1) #0 {
entry:
%alloca = alloca ptr, align 8
store ptr %0, ptr %alloca, align 8
%allocaN = alloca i64, align 8
store i64 %1, 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) #0 {
entry:
%alloca = alloca ptr, align 8
store ptr %0, ptr %alloca, align 8
%allocaN = alloca ptr, align 8
store ptr %1, ptr %allocaN, align 8
%load = load ptr, ptr %allocaN, align 8
call void @free(ptr %load)
ret void
}
; Function Attrs: nounwind
declare ptr @GPA.init() #0
; Function Attrs: nounwind
define internal ptr @GPA.alloc(ptr %0, i64 %1) #0 {
entry:
%alloca = alloca ptr, align 8
store ptr %0, ptr %alloca, align 8
%allocaN = alloca i64, align 8
store i64 %1, ptr %allocaN, align 8
%load = load ptr, ptr %alloca, align 8
%gep = getelementptr inbounds { i64 }, ptr %load, i32 0, i32 0
%loadN = load i64, ptr %gep, align 8
%add = add i64 %loadN, 1
store i64 %add, ptr %gep, align 8
%loadN = load i64, ptr %allocaN, align 8
%call = call ptr @malloc(i64 %loadN)
ret ptr %call
}
; Function Attrs: nounwind
define internal void @GPA.dealloc(ptr %0, ptr %1) #0 {
entry:
%alloca = alloca ptr, align 8
store ptr %0, ptr %alloca, align 8
%allocaN = alloca ptr, align 8
store ptr %1, ptr %allocaN, align 8
%load = load ptr, ptr %alloca, align 8
%gep = getelementptr inbounds { i64 }, ptr %load, i32 0, i32 0
%loadN = load i64, ptr %gep, align 8
%sub = sub i64 %loadN, 1
store i64 %sub, ptr %gep, align 8
%loadN = load ptr, ptr %allocaN, align 8
call void @free(ptr %loadN)
ret void
}
; Function Attrs: nounwind
declare void @Arena.add_chunk(ptr, i64) #0
; Function Attrs: nounwind
declare ptr @Arena.init(ptr, i64) #0
; Function Attrs: nounwind
declare void @Arena.reset(ptr) #0
; Function Attrs: nounwind
declare void @Arena.deinit(ptr) #0
; Function Attrs: nounwind
declare ptr @Arena.alloc(ptr, i64) #0
; Function Attrs: nounwind
declare void @Arena.dealloc(ptr, ptr) #0
; Function Attrs: nounwind
declare ptr @BufAlloc.init(ptr, i64) #0
; Function Attrs: nounwind
declare void @BufAlloc.reset(ptr) #0
; Function Attrs: nounwind
declare ptr @BufAlloc.alloc(ptr, i64) #0
; Function Attrs: nounwind
declare void @BufAlloc.dealloc(ptr, ptr) #0
; Function Attrs: nounwind
declare ptr @TrackingAllocator.init(ptr) #0
; Function Attrs: nounwind
declare i64 @TrackingAllocator.leak_count(ptr) #0
; Function Attrs: nounwind
declare void @TrackingAllocator.report(ptr) #0
; Function Attrs: nounwind
declare ptr @TrackingAllocator.alloc(ptr, i64) #0
; Function Attrs: nounwind
declare void @TrackingAllocator.dealloc(ptr, ptr) #0
; Function Attrs: nounwind
define internal { ptr, i64 } @cstring(i64 %0) #0 {
entry:
%alloca = alloca i64, align 8
store i64 %0, ptr %alloca, align 8
%load = load i64, ptr %alloca, align 8
%add = add i64 %load, 1
%heap = call ptr @malloc(i64 %add)
%allocaN = alloca ptr, align 8
store ptr %heap, ptr %allocaN, align 8
%loadN = load ptr, ptr %allocaN, align 8
%loadN = load i64, ptr %alloca, align 8
%addN = add i64 %loadN, 1
%1 = 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(i64 %0) #0 {
entry:
%alloca = alloca i64, align 8
store i64 %0, 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(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, i64 } %loadN, i64 %addN, i64 %subN)
ret { ptr, i64 } %callN
}
; Function Attrs: nounwind
define internal { ptr, i64 } @bool_to_string(i1 %0) #0 {
entry:
%alloca = alloca i1, align 1
store i1 %0, ptr %alloca, align 1
%load = load i1, ptr %alloca, align 1
br i1 %load, label %if.then.24, label %if.else.25
if.then.24: ; preds = %entry
br label %if.merge.26
if.else.25: ; preds = %entry
br label %if.merge.26
if.merge.26: ; preds = %if.else.25, %if.then.24
%bp = phi { ptr, i64 } [ { ptr @str.1, i64 4 }, %if.then.24 ], [ { ptr @str.2, i64 5 }, %if.else.25 ]
ret { ptr, i64 } %bp
}
; Function Attrs: nounwind
define internal { ptr, i64 } @float_to_string(double %0) #0 {
entry:
%alloca = alloca double, align 8
store double %0, 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.30, label %if.else.31
if.then.30: ; preds = %entry
%loadN = load double, ptr %alloca, align 8
%fsub = fsub double 0.000000e+00, %loadN
br label %if.merge.32
if.else.31: ; preds = %entry
%loadN = load double, ptr %alloca, align 8
br label %if.merge.32
if.merge.32: ; preds = %if.else.31, %if.then.30
%bp = phi double [ %fsub, %if.then.30 ], [ %loadN, %if.else.31 ]
%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.33, label %if.merge.34
if.then.33: ; preds = %if.merge.32
%loadN = load i64, ptr %allocaN, align 8
%sub = sub i64 0, %loadN
store i64 %sub, ptr %allocaN, align 8
br label %if.merge.34
if.merge.34: ; preds = %if.then.33, %if.merge.32
%loadN = load i64, ptr %allocaN, align 8
%call = call { ptr, i64 } @int_to_string(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(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.35, label %if.else.36
if.then.35: ; preds = %if.merge.34
br label %if.merge.37
if.else.36: ; preds = %if.merge.34
br label %if.merge.37
if.merge.37: ; preds = %if.else.36, %if.then.35
%bpN = phi i64 [ 1, %if.then.35 ], [ 0, %if.else.36 ]
%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(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.38, label %if.merge.39
if.then.38: ; preds = %if.merge.37
%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.39
if.merge.39: ; preds = %if.then.38, %if.merge.37
%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
%1 = 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, i64 } %0, i64 %1, i64 %2) #0 {
entry:
%alloca = alloca { ptr, i64 }, align 8
store { ptr, i64 } %0, ptr %alloca, align 8
%allocaN = alloca i64, align 8
store i64 %1, ptr %allocaN, align 8
%allocaN = alloca i64, align 8
store i64 %2, 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.173
while.hdr.173: ; preds = %if.merge.178, %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.174, label %while.exit.175
while.body.174: ; preds = %while.hdr.173
%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.176, label %if.else.177
while.exit.175: ; preds = %while.hdr.173
ret void
if.then.176: ; preds = %while.body.174
%loadN = load i64, ptr %allocaN, align 8
%addN = add i64 %loadN, 48
br label %if.merge.178
if.else.177: ; preds = %while.body.174
%loadN = load i64, ptr %allocaN, align 8
%sub = sub i64 %loadN, 10
%addN = add i64 %sub, 97
br label %if.merge.178
if.merge.178: ; preds = %if.else.177, %if.then.176
%bp = phi i64 [ %addN, %if.then.176 ], [ %addN, %if.else.177 ]
%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.173
}
; Function Attrs: nounwind
define internal { ptr, i64 } @int_to_hex_string(i64 %0) #0 {
entry:
%alloca = alloca i64, align 8
store i64 %0, ptr %alloca, align 8
%load = load i64, ptr %alloca, align 8
%icmp = icmp eq i64 %load, 0
br i1 %icmp, label %if.then.163, label %if.merge.164
if.then.163: ; preds = %entry
ret { ptr, i64 } { ptr @str.3, i64 1 }
if.merge.164: ; 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.165, label %if.merge.166
if.then.165: ; preds = %if.merge.164
%loadN = load i64, ptr %allocaN, align 8
%add = add i64 %loadN, 65536
store i64 %add, ptr %allocaN, align 8
br label %if.merge.166
if.merge.166: ; preds = %if.then.165, %if.merge.164
%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.167, label %if.merge.168
if.then.167: ; preds = %if.merge.166
%loadN = load i64, ptr %allocaN, align 8
%addN = add i64 %loadN, 65536
store i64 %addN, ptr %allocaN, align 8
br label %if.merge.168
if.merge.168: ; preds = %if.then.167, %if.merge.166
%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.169, label %if.merge.170
if.then.169: ; preds = %if.merge.168
%loadN = load i64, ptr %allocaN, align 8
%addN = add i64 %loadN, 65536
store i64 %addN, ptr %allocaN, align 8
br label %if.merge.170
if.merge.170: ; preds = %if.then.169, %if.merge.168
%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.171, label %if.merge.172
if.then.171: ; preds = %if.merge.170
%loadN = load i64, ptr %allocaN, align 8
%addN = add i64 %loadN, 65536
store i64 %addN, ptr %allocaN, align 8
br label %if.merge.172
if.merge.172: ; preds = %if.then.171, %if.merge.170
%call = call { ptr, i64 } @cstring(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, 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, 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, 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, i64 } %loadN, i64 12, i64 %loadN)
%allocaN = alloca i64, align 8
store i64 0, ptr %allocaN, align 8
br label %while.hdr.179
while.hdr.179: ; preds = %if.merge.183, %if.merge.172
%loadN = load i64, ptr %allocaN, align 8
%icmpN = icmp slt i64 %loadN, 15
br i1 %icmpN, label %while.body.180, label %while.exit.181
while.body.180: ; preds = %while.hdr.179
%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.182, label %if.merge.183
while.exit.181: ; preds = %if.then.182, %while.hdr.179
%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, i64 } %loadN, i64 %loadN, i64 %subN)
ret { ptr, i64 } %callN
if.then.182: ; preds = %while.body.180
br label %while.exit.181
if.merge.183: ; preds = %while.body.180
%loadN = load i64, ptr %allocaN, align 8
%addN = add i64 %loadN, 1
store i64 %addN, ptr %allocaN, align 8
br label %while.hdr.179
}
; Function Attrs: nounwind
define internal { ptr, i64 } @concat({ ptr, i64 } %0, { ptr, i64 } %1) #0 {
entry:
%alloca = alloca { ptr, i64 }, align 8
store { ptr, i64 } %0, ptr %alloca, align 8
%allocaN = alloca { ptr, i64 }, align 8
store { ptr, i64 } %1, 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(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, i64 } %0, i64 %1, i64 %2) #0 {
entry:
%alloca = alloca { ptr, i64 }, align 8
store { ptr, i64 } %0, ptr %alloca, align 8
%allocaN = alloca i64, align 8
store i64 %1, ptr %allocaN, align 8
%allocaN = alloca i64, align 8
store i64 %2, ptr %allocaN, align 8
%load = load i64, ptr %allocaN, align 8
%call = call { ptr, i64 } @cstring(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) #0
; Function Attrs: nounwind
declare ptr @path_join(ptr) #0
; Function Attrs: nounwind
define internal { ptr, i64 } @any_to_string({ i64, i64 } %0) #0 {
entry:
%alloca = alloca { i64, i64 }, align 8
store { i64, i64 } %0, 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
%allocaN = alloca i64, align 8
store i64 %sg, ptr %allocaN, align 8
%loadN = load i64, ptr %allocaN, align 8
switch i64 %loadN, label %match.unr.13 [
i64 0, label %match.arm.1
i64 2, label %match.arm.2
i64 3, label %match.arm.2
i64 4, label %match.arm.2
i64 5, label %match.arm.2
i64 6, label %match.arm.2
i64 7, label %match.arm.2
i64 8, label %match.arm.2
i64 9, label %match.arm.2
i64 16, label %match.arm.2
i64 15, label %match.arm.2
i64 12, label %match.arm.3
i64 1, label %match.arm.4
i64 10, label %match.arm.5
i64 11, label %match.arm.5
i64 18, label %match.arm.6
i64 19, label %match.arm.6
i64 21, label %match.arm.6
i64 23, label %match.arm.6
i64 25, label %match.arm.6
i64 28, label %match.arm.6
i64 30, label %match.arm.6
i64 32, label %match.arm.6
i64 36, label %match.arm.6
i64 38, label %match.arm.6
i64 34, label %match.arm.7
i64 35, label %match.arm.7
i64 45, label %match.arm.9
i64 52, label %match.arm.9
i64 33, label %match.arm.10
i64 44, label %match.arm.10
i64 17, label %match.arm.11
i64 20, label %match.arm.11
i64 22, label %match.arm.11
i64 24, label %match.arm.11
i64 26, label %match.arm.11
i64 27, label %match.arm.11
i64 29, label %match.arm.11
i64 31, label %match.arm.11
i64 39, label %match.arm.11
i64 40, label %match.arm.11
i64 41, label %match.arm.11
i64 42, label %match.arm.11
i64 43, label %match.arm.11
i64 46, label %match.arm.11
i64 47, label %match.arm.11
i64 48, label %match.arm.11
i64 49, label %match.arm.11
i64 50, label %match.arm.11
i64 51, label %match.arm.11
i64 53, label %match.arm.11
i64 13, label %match.arm.12
]
match.merge.0: ; preds = %dispatch.merge.138, %dispatch.merge.124, %dispatch.merge.110, %dispatch.merge.102, %dispatch.merge.40, %float.merge.29, %match.unr.13, %match.arm.12, %match.arm.4, %match.arm.3, %match.arm.2, %match.arm.1
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
ret { ptr, i64 } %loadN
match.arm.1: ; preds = %entry
store { ptr, i64 } { ptr @str.5, i64 0 }, ptr %allocaN, align 8
br label %match.merge.0
match.arm.2: ; preds = %entry, %entry, %entry, %entry, %entry, %entry, %entry, %entry, %entry, %entry
%loadN = load { i64, i64 }, ptr %alloca, align 8
%ua.raw = extractvalue { i64, i64 } %loadN, 1
%call = call { ptr, i64 } @int_to_string(i64 %ua.raw)
store { ptr, i64 } %call, ptr %allocaN, align 8
br label %match.merge.0
match.arm.3: ; preds = %entry
%allocaN = alloca { ptr, i64 }, align 8
%loadN = load { i64, i64 }, ptr %alloca, align 8
%ua.raw8 = extractvalue { i64, i64 } %loadN, 1
%ua.ptr = inttoptr i64 %ua.raw8 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.0
match.arm.4: ; preds = %entry
%loadN = load { i64, i64 }, ptr %alloca, align 8
%ua.raw11 = extractvalue { i64, i64 } %loadN, 1
%tr = trunc i64 %ua.raw11 to i1
%callN = call { ptr, i64 } @bool_to_string(i1 %tr)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %match.merge.0
match.arm.5: ; 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.27, label %fN.unbox.28
match.arm.6: ; preds = %entry, %entry, %entry, %entry, %entry, %entry, %entry, %entry, %entry, %entry
%loadN = load i64, ptr %allocaN, align 8
%loadN = load { i64, i64 }, ptr %alloca, align 8
%allocaN = alloca { ptr, i64 }, align 8
switch i64 %loadN, label %dispatch.default.41 [
i64 18, label %dispatch.case.42
i64 19, label %dispatch.case.43
i64 21, label %dispatch.case.44
i64 23, label %dispatch.case.45
i64 25, label %dispatch.case.46
i64 28, label %dispatch.case.47
i64 30, label %dispatch.case.48
i64 32, label %dispatch.case.49
i64 36, label %dispatch.case.50
i64 38, label %dispatch.case.51
]
match.arm.7: ; preds = %entry, %entry
%loadN = load i64, ptr %allocaN, align 8
%loadN = load { i64, i64 }, ptr %alloca, align 8
%allocaN = alloca { ptr, i64 }, align 8
switch i64 %loadN, label %dispatch.default.103 [
i64 34, label %dispatch.case.104
i64 35, label %dispatch.case.105
]
match.arm.8: ; No predecessors!
unreachable
match.arm.9: ; preds = %entry, %entry
%loadN = load i64, ptr %allocaN, align 8
%loadN = load { i64, i64 }, ptr %alloca, align 8
%allocaN = alloca { ptr, i64 }, align 8
switch i64 %loadN, label %dispatch.default.111 [
i64 45, label %dispatch.case.112
i64 52, label %dispatch.case.113
]
match.arm.10: ; preds = %entry, %entry
%loadN = load i64, ptr %allocaN, align 8
%loadN = load { i64, i64 }, ptr %alloca, align 8
%allocaN = alloca { ptr, i64 }, align 8
switch i64 %loadN, label %dispatch.default.125 [
i64 33, label %dispatch.case.126
i64 44, label %dispatch.case.127
]
match.arm.11: ; preds = %entry, %entry, %entry, %entry, %entry, %entry, %entry, %entry, %entry, %entry, %entry, %entry, %entry, %entry, %entry, %entry, %entry, %entry, %entry, %entry
%loadN = load i64, ptr %allocaN, align 8
%loadN = load { i64, i64 }, ptr %alloca, align 8
%allocaN = alloca { ptr, i64 }, align 8
switch i64 %loadN, label %dispatch.default.139 [
i64 17, label %dispatch.case.140
i64 20, label %dispatch.case.141
i64 22, label %dispatch.case.142
i64 24, label %dispatch.case.143
i64 26, label %dispatch.case.144
i64 27, label %dispatch.case.145
i64 29, label %dispatch.case.146
i64 31, label %dispatch.case.147
i64 39, label %dispatch.case.148
i64 40, label %dispatch.case.149
i64 41, label %dispatch.case.150
i64 42, label %dispatch.case.151
i64 43, label %dispatch.case.152
i64 46, label %dispatch.case.153
i64 47, label %dispatch.case.154
i64 48, label %dispatch.case.155
i64 49, label %dispatch.case.156
i64 50, label %dispatch.case.157
i64 51, label %dispatch.case.158
i64 53, label %dispatch.case.159
]
match.arm.12: ; preds = %entry
%allocaN = alloca { ptr, i64 }, align 8
%loadN = load { i64, i64 }, ptr %alloca, align 8
%ua.raw33 = extractvalue { i64, i64 } %loadN, 1
%ua.ptr34 = inttoptr i64 %ua.raw33 to ptr
%ua.load35 = load { ptr, i64 }, ptr %ua.ptr34, align 8
store { ptr, i64 } %ua.load35, ptr %allocaN, align 8
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
store { ptr, i64 } %loadN, ptr %allocaN, align 8
br label %match.merge.0
match.unr.13: ; preds = %entry
br label %match.merge.0
f32.unbox.27: ; preds = %match.arm.5
%ua.raw37 = extractvalue { i64, i64 } %loadN, 1
%trN = trunc i64 %ua.raw37 to i32
%iNf = bitcast i32 %trN to float
%fpext = fpext float %iNf to double
store double %fpext, ptr %allocaN, align 8
br label %float.merge.29
f64.unbox.28: ; preds = %match.arm.5
%ua.raw38 = extractvalue { i64, i64 } %loadN, 1
%iNd = bitcast i64 %ua.raw38 to double
store double %iNd, ptr %allocaN, align 8
br label %float.merge.29
float.merge.29: ; preds = %fN.unbox.28, %fN.unbox.27
%loadN = load double, ptr %allocaN, align 8
%callN = call { ptr, i64 } @float_to_string(double %loadN)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %match.merge.0
dispatch.merge.40: ; preds = %dispatch.case.51, %dispatch.case.50, %dispatch.case.49, %dispatch.case.48, %dispatch.case.47, %dispatch.case.46, %dispatch.case.45, %dispatch.case.44, %dispatch.case.43, %dispatch.case.42, %dispatch.default.41
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
store { ptr, i64 } %loadN, ptr %allocaN, align 8
br label %match.merge.0
dispatch.default.41: ; preds = %match.arm.6
store { ptr, i64 } { ptr @str.6, i64 0 }, ptr %allocaN, align 8
br label %dispatch.merge.40
dispatch.case.42: ; preds = %match.arm.6
%ua.raw42 = extractvalue { i64, i64 } %loadN, 1
%ua.ptr43 = inttoptr i64 %ua.raw42 to ptr
%ua.load44 = load { ptr, ptr, ptr }, ptr %ua.ptr43, align 8
%callN = call { ptr, i64 } @struct_to_string__Allocator({ ptr, ptr, ptr } %ua.load44)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %dispatch.merge.40
dispatch.case.43: ; preds = %match.arm.6
%ua.raw46 = extractvalue { i64, i64 } %loadN, 1
%ua.ptr47 = inttoptr i64 %ua.raw46 to ptr
%ua.load48 = load {}, ptr %ua.ptr47, align 1
%callN = call { ptr, i64 } @struct_to_string__CAllocator({} %ua.load48)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %dispatch.merge.40
dispatch.case.44: ; preds = %match.arm.6
%ua.raw50 = extractvalue { i64, i64 } %loadN, 1
%ua.ptr51 = inttoptr i64 %ua.raw50 to ptr
%ua.load52 = load { i64 }, ptr %ua.ptr51, align 8
%callN = call { ptr, i64 } @struct_to_string__GPA({ i64 } %ua.load52)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %dispatch.merge.40
dispatch.case.45: ; preds = %match.arm.6
%ua.raw54 = extractvalue { i64, i64 } %loadN, 1
%ua.ptr55 = inttoptr i64 %ua.raw54 to ptr
%ua.load56 = load { ptr, i64 }, ptr %ua.ptr55, align 8
%callN = call { ptr, i64 } @struct_to_string__ArenaChunk({ ptr, i64 } %ua.load56)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %dispatch.merge.40
dispatch.case.46: ; preds = %match.arm.6
%ua.raw58 = extractvalue { i64, i64 } %loadN, 1
%ua.ptr59 = inttoptr i64 %ua.raw58 to ptr
%ua.load60 = load { ptr, i64, { ptr, ptr, ptr } }, ptr %ua.ptr59, align 8
%callN = call { ptr, i64 } @struct_to_string__Arena({ ptr, i64, { ptr, ptr, ptr } } %ua.load60)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %dispatch.merge.40
dispatch.case.47: ; preds = %match.arm.6
%ua.raw62 = extractvalue { i64, i64 } %loadN, 1
%ua.ptr63 = inttoptr i64 %ua.raw62 to ptr
%ua.load64 = load { ptr, i64, i64 }, ptr %ua.ptr63, align 8
%callN = call { ptr, i64 } @struct_to_string__BufAlloc({ ptr, i64, i64 } %ua.load64)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %dispatch.merge.40
dispatch.case.48: ; preds = %match.arm.6
%ua.raw66 = extractvalue { i64, i64 } %loadN, 1
%ua.ptr67 = inttoptr i64 %ua.raw66 to ptr
%ua.load68 = load { { ptr, ptr, ptr }, i64, i64, i64 }, ptr %ua.ptr67, align 8
%callN = call { ptr, i64 } @struct_to_string__TrackingAllocator({ { ptr, ptr, ptr }, i64, i64, i64 } %ua.load68)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %dispatch.merge.40
dispatch.case.49: ; preds = %match.arm.6
%ua.raw70 = extractvalue { i64, i64 } %loadN, 1
%ua.ptr71 = inttoptr i64 %ua.raw70 to ptr
%ua.load72 = load { { ptr, ptr, ptr }, ptr }, ptr %ua.ptr71, align 8
%callN = call { ptr, i64 } @struct_to_string__Context({ { ptr, ptr, ptr }, ptr } %ua.load72)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %dispatch.merge.40
dispatch.case.50: ; preds = %match.arm.6
%ua.raw74 = extractvalue { i64, i64 } %loadN, 1
%ua.ptr75 = inttoptr i64 %ua.raw74 to ptr
%ua.load76 = load {}, ptr %ua.ptr75, align 1
%callN = call { ptr, i64 } @struct_to_string__BuildOptions({} %ua.load76)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %dispatch.merge.40
dispatch.case.51: ; preds = %match.arm.6
%ua.raw78 = extractvalue { i64, i64 } %loadN, 1
%ua.ptr79 = inttoptr i64 %ua.raw78 to ptr
%ua.load80 = load { i64, i64, i64 }, ptr %ua.ptr79, align 8
%callN = call { ptr, i64 } @struct_to_string__Triple({ i64, i64, i64 } %ua.load80)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %dispatch.merge.40
dispatch.merge.102: ; preds = %dispatch.case.105, %dispatch.case.104, %dispatch.default.103
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
store { ptr, i64 } %loadN, ptr %allocaN, align 8
br label %match.merge.0
dispatch.default.103: ; preds = %match.arm.7
store { ptr, i64 } { ptr @str.7, i64 0 }, ptr %allocaN, align 8
br label %dispatch.merge.102
dispatch.case.104: ; preds = %match.arm.7
%ua.raw83 = extractvalue { i64, i64 } %loadN, 1
%callN = call { ptr, i64 } @enum_to_string__OperatingSystem(i64 %ua.raw83)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %dispatch.merge.102
dispatch.case.105: ; preds = %match.arm.7
%ua.raw85 = extractvalue { i64, i64 } %loadN, 1
%callN = call { ptr, i64 } @enum_to_string__Architecture(i64 %ua.raw85)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %dispatch.merge.102
dispatch.merge.110: ; preds = %dispatch.case.113, %dispatch.case.112, %dispatch.default.111
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
store { ptr, i64 } %loadN, ptr %allocaN, align 8
br label %match.merge.0
dispatch.default.111: ; preds = %match.arm.9
store { ptr, i64 } { ptr @str.8, i64 0 }, ptr %allocaN, align 8
br label %dispatch.merge.110
dispatch.case.112: ; preds = %match.arm.9
%ua.raw88 = extractvalue { i64, i64 } %loadN, 1
%ua.ptr89 = inttoptr i64 %ua.raw88 to ptr
%ua.load90 = load [1 x { i64, i64 }], ptr %ua.ptr89, align 8
%callN = call { ptr, i64 } @array_to_string__AR_1_Any([1 x { i64, i64 }] %ua.load90)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %dispatch.merge.110
dispatch.case.113: ; preds = %match.arm.9
%ua.raw92 = extractvalue { i64, i64 } %loadN, 1
%ua.ptr93 = inttoptr i64 %ua.raw92 to ptr
%ua.load94 = load [3 x { i64, i64 }], ptr %ua.ptr93, align 8
%callN = call { ptr, i64 } @array_to_string__AR_3_Any([3 x { i64, i64 }] %ua.load94)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %dispatch.merge.110
dispatch.merge.124: ; preds = %dispatch.case.127, %dispatch.case.126, %dispatch.default.125
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
store { ptr, i64 } %loadN, ptr %allocaN, align 8
br label %match.merge.0
dispatch.default.125: ; preds = %match.arm.10
store { ptr, i64 } { ptr @str.9, i64 0 }, ptr %allocaN, align 8
br label %dispatch.merge.124
dispatch.case.126: ; preds = %match.arm.10
%ua.raw97 = extractvalue { i64, i64 } %loadN, 1
%ua.ptr98 = inttoptr i64 %ua.raw97 to ptr
%ua.load99 = load { ptr, i64 }, ptr %ua.ptr98, align 8
%callN = call { ptr, i64 } @slice_to_string__string({ ptr, i64 } %ua.load99)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %dispatch.merge.124
dispatch.case.127: ; preds = %match.arm.10
%ua.raw101 = extractvalue { i64, i64 } %loadN, 1
%ua.ptr102 = inttoptr i64 %ua.raw101 to ptr
%ua.load103 = load { ptr, i64 }, ptr %ua.ptr102, align 8
%callN = call { ptr, i64 } @slice_to_string__Any({ ptr, i64 } %ua.load103)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %dispatch.merge.124
dispatch.merge.138: ; preds = %dispatch.case.159, %dispatch.case.158, %dispatch.case.157, %dispatch.case.156, %dispatch.case.155, %dispatch.case.154, %dispatch.case.153, %dispatch.case.152, %dispatch.case.151, %dispatch.case.150, %dispatch.case.149, %dispatch.case.148, %dispatch.case.147, %dispatch.case.146, %dispatch.case.145, %dispatch.case.144, %dispatch.case.143, %dispatch.case.142, %dispatch.case.141, %dispatch.case.140, %dispatch.default.139
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
store { ptr, i64 } %loadN, ptr %allocaN, align 8
br label %match.merge.0
dispatch.default.139: ; preds = %match.arm.11
store { ptr, i64 } { ptr @str.10, i64 0 }, ptr %allocaN, align 8
br label %dispatch.merge.138
dispatch.case.140: ; preds = %match.arm.11
%ua.raw106 = extractvalue { i64, i64 } %loadN, 1
%iNp = inttoptr i64 %ua.raw106 to ptr
%callN = call { ptr, i64 } @pointer_to_string__ptr_void(ptr %iNp)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %dispatch.merge.138
dispatch.case.141: ; preds = %match.arm.11
%ua.raw108 = extractvalue { i64, i64 } %loadN, 1
%iNp109 = inttoptr i64 %ua.raw108 to ptr
%callN = call { ptr, i64 } @pointer_to_string__ptr_CAllocator(ptr %iNp109)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %dispatch.merge.138
dispatch.case.142: ; preds = %match.arm.11
%ua.raw111 = extractvalue { i64, i64 } %loadN, 1
%iNp112 = inttoptr i64 %ua.raw111 to ptr
%callN = call { ptr, i64 } @pointer_to_string__ptr_GPA(ptr %iNp112)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %dispatch.merge.138
dispatch.case.143: ; preds = %match.arm.11
%ua.raw114 = extractvalue { i64, i64 } %loadN, 1
%iNp115 = inttoptr i64 %ua.raw114 to ptr
%callN = call { ptr, i64 } @pointer_to_string__ptr_ArenaChunk(ptr %iNp115)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %dispatch.merge.138
dispatch.case.144: ; preds = %match.arm.11
%ua.raw117 = extractvalue { i64, i64 } %loadN, 1
%iNp118 = inttoptr i64 %ua.raw117 to ptr
%callN = call { ptr, i64 } @pointer_to_string__ptr_Arena(ptr %iNp118)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %dispatch.merge.138
dispatch.case.145: ; preds = %match.arm.11
%ua.raw120 = extractvalue { i64, i64 } %loadN, 1
%iNp121 = inttoptr i64 %ua.raw120 to ptr
%callN = call { ptr, i64 } @pointer_to_string__mptr_u8(ptr %iNp121)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %dispatch.merge.138
dispatch.case.146: ; preds = %match.arm.11
%ua.raw123 = extractvalue { i64, i64 } %loadN, 1
%iNp124 = inttoptr i64 %ua.raw123 to ptr
%callN = call { ptr, i64 } @pointer_to_string__ptr_BufAlloc(ptr %iNp124)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %dispatch.merge.138
dispatch.case.147: ; preds = %match.arm.11
%ua.raw126 = extractvalue { i64, i64 } %loadN, 1
%iNp127 = inttoptr i64 %ua.raw126 to ptr
%callN = call { ptr, i64 } @pointer_to_string__ptr_TrackingAllocator(ptr %iNp127)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %dispatch.merge.138
dispatch.case.148: ; preds = %match.arm.11
%ua.raw129 = extractvalue { i64, i64 } %loadN, 1
%iNp130 = inttoptr i64 %ua.raw129 to ptr
%callN = call { ptr, i64 } @pointer_to_string__ptr_ptr_CAllocator(ptr %iNp130)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %dispatch.merge.138
dispatch.case.149: ; preds = %match.arm.11
%ua.raw132 = extractvalue { i64, i64 } %loadN, 1
%iNp133 = inttoptr i64 %ua.raw132 to ptr
%callN = call { ptr, i64 } @pointer_to_string__ptr_s64(ptr %iNp133)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %dispatch.merge.138
dispatch.case.150: ; preds = %match.arm.11
%ua.raw135 = extractvalue { i64, i64 } %loadN, 1
%iNp136 = inttoptr i64 %ua.raw135 to ptr
%callN = call { ptr, i64 } @pointer_to_string__ptr_ptr_void(ptr %iNp136)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %dispatch.merge.138
dispatch.case.151: ; preds = %match.arm.11
%ua.raw138 = extractvalue { i64, i64 } %loadN, 1
%iNp139 = inttoptr i64 %ua.raw138 to ptr
%callN = call { ptr, i64 } @pointer_to_string__ptr_ptr_GPA(ptr %iNp139)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %dispatch.merge.138
dispatch.case.152: ; preds = %match.arm.11
%ua.raw141 = extractvalue { i64, i64 } %loadN, 1
%iNp142 = inttoptr i64 %ua.raw141 to ptr
%callN = call { ptr, i64 } @pointer_to_string__ptr_bool(ptr %iNp142)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %dispatch.merge.138
dispatch.case.153: ; preds = %match.arm.11
%ua.raw144 = extractvalue { i64, i64 } %loadN, 1
%iNp145 = inttoptr i64 %ua.raw144 to ptr
%callN = call { ptr, i64 } @pointer_to_string__ptr_AR_1_Any(ptr %iNp145)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %dispatch.merge.138
dispatch.case.154: ; preds = %match.arm.11
%ua.raw147 = extractvalue { i64, i64 } %loadN, 1
%iNp148 = inttoptr i64 %ua.raw147 to ptr
%callN = call { ptr, i64 } @pointer_to_string__ptr_Any(ptr %iNp148)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %dispatch.merge.138
dispatch.case.155: ; preds = %match.arm.11
%ua.raw150 = extractvalue { i64, i64 } %loadN, 1
%iNp151 = inttoptr i64 %ua.raw150 to ptr
%callN = call { ptr, i64 } @pointer_to_string__ptr_SL_Any(ptr %iNp151)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %dispatch.merge.138
dispatch.case.156: ; preds = %match.arm.11
%ua.raw153 = extractvalue { i64, i64 } %loadN, 1
%iNp154 = inttoptr i64 %ua.raw153 to ptr
%callN = call { ptr, i64 } @pointer_to_string__ptr_string(ptr %iNp154)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %dispatch.merge.138
dispatch.case.157: ; preds = %match.arm.11
%ua.raw156 = extractvalue { i64, i64 } %loadN, 1
%iNp157 = inttoptr i64 %ua.raw156 to ptr
%callN = call { ptr, i64 } @pointer_to_string__ptr_u8(ptr %iNp157)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %dispatch.merge.138
dispatch.case.158: ; preds = %match.arm.11
%ua.raw159 = extractvalue { i64, i64 } %loadN, 1
%iNp160 = inttoptr i64 %ua.raw159 to ptr
%callN = call { ptr, i64 } @pointer_to_string__ptr_Triple(ptr %iNp160)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %dispatch.merge.138
dispatch.case.159: ; preds = %match.arm.11
%ua.raw162 = extractvalue { i64, i64 } %loadN, 1
%iNp163 = inttoptr i64 %ua.raw162 to ptr
%callN = call { ptr, i64 } @pointer_to_string__ptr_AR_3_Any(ptr %iNp163)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %dispatch.merge.138
}
; Function Attrs: nounwind
declare ptr @build_format(ptr) #0
; Function Attrs: nounwind
declare void @BuildOptions.add_link_flag(i64, ptr) #0
; Function Attrs: nounwind
declare void @BuildOptions.add_framework(i64, ptr) #0
; Function Attrs: nounwind
declare void @BuildOptions.set_output_path(i64, ptr) #0
; Function Attrs: nounwind
declare void @BuildOptions.set_wasm_shell(i64, ptr) #0
; Function Attrs: nounwind
declare void @BuildOptions.add_asset_dir(i64, ptr, ptr) #0
; Function Attrs: nounwind
declare i64 @BuildOptions.asset_dir_count(i64) #0
; Function Attrs: nounwind
declare ptr @BuildOptions.asset_dir_src_at(i64, i64) #0
; Function Attrs: nounwind
declare ptr @BuildOptions.asset_dir_dest_at(i64, i64) #0
; Function Attrs: nounwind
declare void @BuildOptions.set_post_link_callback(i64, ptr) #0
; Function Attrs: nounwind
declare void @BuildOptions.set_post_link_module(i64, ptr) #0
; Function Attrs: nounwind
declare ptr @BuildOptions.binary_path(i64) #0
; Function Attrs: nounwind
declare void @BuildOptions.set_bundle_path(i64, ptr) #0
; Function Attrs: nounwind
declare void @BuildOptions.set_bundle_id(i64, ptr) #0
; Function Attrs: nounwind
declare void @BuildOptions.set_codesign_identity(i64, ptr) #0
; Function Attrs: nounwind
declare void @BuildOptions.set_provisioning_profile(i64, ptr) #0
; Function Attrs: nounwind
declare ptr @BuildOptions.bundle_path(i64) #0
; Function Attrs: nounwind
declare ptr @BuildOptions.bundle_id(i64) #0
; Function Attrs: nounwind
declare ptr @BuildOptions.codesign_identity(i64) #0
; Function Attrs: nounwind
declare ptr @BuildOptions.provisioning_profile(i64) #0
; Function Attrs: nounwind
declare ptr @BuildOptions.target_triple(i64) #0
; Function Attrs: nounwind
declare i1 @BuildOptions.is_macos(i64) #0
; Function Attrs: nounwind
declare i1 @BuildOptions.is_ios(i64) #0
; Function Attrs: nounwind
declare i1 @BuildOptions.is_ios_device(i64) #0
; Function Attrs: nounwind
declare i1 @BuildOptions.is_ios_simulator(i64) #0
; Function Attrs: nounwind
declare i1 @BuildOptions.is_android(i64) #0
; Function Attrs: nounwind
declare i64 @BuildOptions.framework_count(i64) #0
; Function Attrs: nounwind
declare ptr @BuildOptions.framework_at(i64, i64) #0
; Function Attrs: nounwind
declare i64 @BuildOptions.framework_path_count(i64) #0
; Function Attrs: nounwind
declare ptr @BuildOptions.framework_path_at(i64, i64) #0
; Function Attrs: nounwind
declare void @BuildOptions.set_manifest_path(i64, ptr) #0
; Function Attrs: nounwind
declare void @BuildOptions.set_keystore_path(i64, ptr) #0
; Function Attrs: nounwind
declare ptr @BuildOptions.manifest_path(i64) #0
; Function Attrs: nounwind
declare ptr @BuildOptions.keystore_path(i64) #0
; Function Attrs: nounwind
declare i64 @BuildOptions.jni_main_count(i64) #0
; Function Attrs: nounwind
declare ptr @BuildOptions.jni_main_foreign_path_at(i64, i64) #0
; Function Attrs: nounwind
declare ptr @BuildOptions.jni_main_java_source_at(i64, i64) #0
; Function Attrs: nounwind
declare i64 @build_options() #0
; Function Attrs: nounwind
declare ptr @objc_getClass(ptr) #0
; Function Attrs: nounwind
declare ptr @objc_lookUpClass(ptr) #0
; Function Attrs: nounwind
declare ptr @sel_registerName(ptr) #0
; Function Attrs: nounwind
declare ptr @class_createInstance(ptr, i64) #0
; Function Attrs: nounwind
declare ptr @object_getClass(ptr) #0
; Function Attrs: nounwind
declare ptr @objc_msgSend(ptr, ptr) #0
; Function Attrs: nounwind
declare ptr @objc_allocateClassPair(ptr, ptr, i64) #0
; Function Attrs: nounwind
declare i1 @class_addMethod(ptr, ptr, ptr, ptr) #0
; Function Attrs: nounwind
declare i1 @class_addProtocol(ptr, ptr) #0
; Function Attrs: nounwind
declare ptr @objc_getProtocol(ptr) #0
; Function Attrs: nounwind
declare void @objc_registerClassPair(ptr) #0
; Function Attrs: nounwind
declare void @NSLog(ptr) #0
; Function Attrs: nounwind
declare ptr @ns_string(ptr) #0
; Function Attrs: nounwind
declare ptr @c_string(ptr) #0
; Function Attrs: nounwind
define internal void @triple_imp(ptr sret({ i64, i64, i64 }) %0, ptr %1, ptr %2) #0 {
entry:
%alloca = alloca ptr, align 8
store ptr %0, ptr %alloca, align 8
%allocaN = alloca ptr, align 8
store ptr %1, ptr %allocaN, align 8
store { i64, i64, i64 } { i64 11, i64 22, i64 33 }, ptr %0, align 8
ret void
}
; Function Attrs: nounwind
define i32 @main() #0 {
entry:
call void @__sx_objc_selector_init()
%alloca = alloca { i64 }, align 8
store { i64 } zeroinitializer, ptr %alloca, align 8
%si = insertvalue { ptr, ptr, ptr } undef, ptr %alloca, 0
%siN = insertvalue { ptr, ptr, ptr } %si, ptr @__thunk_GPA_Allocator_alloc, 1
%siN = insertvalue { ptr, ptr, ptr } %siN, ptr @__thunk_GPA_Allocator_dealloc, 2
%siN = insertvalue { { ptr, ptr, ptr }, ptr } undef, { ptr, ptr, ptr } %siN, 0
%siN = insertvalue { { ptr, ptr, ptr }, ptr } %siN, ptr null, 1
store { { ptr, ptr, ptr }, ptr } %siN, ptr @context, align 8
%call = call ptr @objc_getClass(ptr @str.11)
%allocaN = alloca ptr, align 8
store ptr %call, ptr %allocaN, align 8
%load = load ptr, ptr %allocaN, align 8
%callN = call ptr @objc_allocateClassPair(ptr %load, ptr @str.12, i64 0)
%allocaN = alloca ptr, align 8
store ptr %callN, ptr %allocaN, align 8
%callN = call ptr @sel_registerName(ptr @str.13)
%allocaN = alloca ptr, align 8
store ptr %callN, ptr %allocaN, align 8
%loadN = load ptr, ptr %allocaN, align 8
%loadN = load ptr, ptr %allocaN, align 8
%callN = call i1 @class_addMethod(ptr %loadN, ptr %loadN, ptr @triple_imp, ptr @str.14)
%allocaN = alloca i1, align 1
store i1 %callN, ptr %allocaN, align 1
%allocaN = alloca [1 x { i64, i64 }], align 8
%loadN = load i1, ptr %allocaN, align 1
%zN = zext i1 %loadN to i64
%ba.val = insertvalue { i64, i64 } { i64 1, 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.ptr17 = getelementptr { i64, i64 }, ptr %allocaN, i64 0
%gep = getelementptr inbounds { ptr, i64 }, ptr %allocaN, i32 0, i32 0
store ptr %igp.ptr17, 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.15, i64 15 }, ptr %allocaN, align 8
%allocaN = alloca { ptr, i64 }, align 8
store { ptr, i64 } { ptr @str.16, i64 0 }, ptr %allocaN, align 8
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%callN = call { ptr, i64 } @substr({ ptr, i64 } %loadN, i64 0, i64 12)
%callN = call { ptr, i64 } @concat({ 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 %allocaN, align 8
%ig.data = extractvalue { ptr, i64 } %loadN, 0
%ig.ptr = getelementptr { i64, i64 }, ptr %ig.data, i64 0
%ig.val = load { i64, i64 }, ptr %ig.ptr, align 8
%callN = call { ptr, i64 } @any_to_string({ i64, i64 } %ig.val)
%callN = call { ptr, i64 } @concat({ 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 %allocaN, align 8
%callN = call { ptr, i64 } @substr({ ptr, i64 } %loadN, i64 14, i64 1)
%callN = call { ptr, i64 } @concat({ 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
%0 = call i64 @write(i32 1, ptr %str.ptr, i64 %str.len)
%loadN = load ptr, ptr %allocaN, align 8
call void @objc_registerClassPair(ptr %loadN)
%loadN = load ptr, ptr %allocaN, align 8
%callN = call ptr @class_createInstance(ptr %loadN, i64 0)
%allocaN = alloca ptr, align 8
store ptr %callN, ptr %allocaN, align 8
%loadN = load ptr, ptr %allocaN, align 8
%loadN = load ptr, ptr @OBJC_SELECTOR_REFERENCES_tripleValue, align 8
%objc.sret = alloca { i64, i64, i64 }, align 8
call void @objc_msgSend(ptr sret({ i64, i64, i64 }) %objc.sret, ptr %loadN, ptr %loadN)
%objc.sret.load = load { i64, i64, i64 }, ptr %objc.sret, align 8
%allocaN = alloca { i64, i64, i64 }, align 8
store { i64, i64, i64 } %objc.sret.load, ptr %allocaN, align 8
%allocaN = alloca [3 x { i64, i64 }], align 8
%loadN = load { i64, i64, i64 }, ptr %allocaN, align 8
%sg = extractvalue { i64, i64, i64 } %loadN, 0
%ba.val43 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %sg, 1
%igp.ptr44 = getelementptr { i64, i64 }, ptr %allocaN, i64 0
store { i64, i64 } %ba.val43, ptr %igp.ptr44, align 8
%loadN = load { i64, i64, i64 }, ptr %allocaN, align 8
%sgN = extractvalue { i64, i64, i64 } %loadN, 1
%ba.val47 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %sgN, 1
%igp.ptr48 = getelementptr { i64, i64 }, ptr %allocaN, i64 1
store { i64, i64 } %ba.val47, ptr %igp.ptr48, align 8
%loadN = load { i64, i64, i64 }, ptr %allocaN, align 8
%sgN = extractvalue { i64, i64, i64 } %loadN, 2
%ba.val51 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %sgN, 1
%igp.ptr52 = getelementptr { i64, i64 }, ptr %allocaN, i64 2
store { i64, i64 } %ba.val51, ptr %igp.ptr52, align 8
%allocaN = alloca { ptr, i64 }, align 8
%igp.ptr54 = getelementptr { i64, i64 }, ptr %allocaN, i64 0
%gepN = getelementptr inbounds { ptr, i64 }, ptr %allocaN, i32 0, i32 0
store ptr %igp.ptr54, ptr %gepN, align 8
%gepN = getelementptr inbounds { ptr, i64 }, ptr %allocaN, i32 0, i32 1
store i64 3, ptr %gepN, align 8
%allocaN = alloca { ptr, i64 }, align 8
store { ptr, i64 } { ptr @str.17, i64 22 }, ptr %allocaN, align 8
%allocaN = alloca { ptr, i64 }, align 8
store { ptr, i64 } { ptr @str.18, i64 0 }, ptr %allocaN, align 8
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%callN = call { ptr, i64 } @substr({ ptr, i64 } %loadN, i64 0, i64 10)
%callN = call { ptr, i64 } @concat({ 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 %allocaN, align 8
%ig.data65 = extractvalue { ptr, i64 } %loadN, 0
%ig.ptr66 = getelementptr { i64, i64 }, ptr %ig.data65, i64 0
%ig.val67 = load { i64, i64 }, ptr %ig.ptr66, align 8
%callN = call { ptr, i64 } @any_to_string({ i64, i64 } %ig.val67)
%callN = call { ptr, i64 } @concat({ 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 %allocaN, align 8
%callN = call { ptr, i64 } @substr({ ptr, i64 } %loadN, i64 12, i64 2)
%callN = call { ptr, i64 } @concat({ 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 %allocaN, align 8
%ig.data76 = extractvalue { ptr, i64 } %loadN, 0
%ig.ptr77 = getelementptr { i64, i64 }, ptr %ig.data76, i64 1
%ig.val78 = load { i64, i64 }, ptr %ig.ptr77, align 8
%callN = call { ptr, i64 } @any_to_string({ i64, i64 } %ig.val78)
%callN = call { ptr, i64 } @concat({ 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 %allocaN, align 8
%callN = call { ptr, i64 } @substr({ ptr, i64 } %loadN, i64 16, i64 2)
%callN = call { ptr, i64 } @concat({ 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 %allocaN, align 8
%ig.data87 = extractvalue { ptr, i64 } %loadN, 0
%ig.ptr88 = getelementptr { i64, i64 }, ptr %ig.data87, i64 2
%ig.val89 = load { i64, i64 }, ptr %ig.ptr88, align 8
%callN = call { ptr, i64 } @any_to_string({ i64, i64 } %ig.val89)
%callN = call { ptr, i64 } @concat({ 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 %allocaN, align 8
%callN = call { ptr, i64 } @substr({ ptr, i64 } %loadN, i64 20, i64 2)
%callN = call { ptr, i64 } @concat({ ptr, i64 } %loadN, { ptr, i64 } %callN)
store { ptr, i64 } %callN, ptr %allocaN, align 8
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%str.ptr97 = extractvalue { ptr, i64 } %loadN, 0
%str.len98 = extractvalue { ptr, i64 } %loadN, 1
%1 = call i64 @write(i32 1, ptr %str.ptr97, i64 %str.len98)
ret i32 0
}
; Function Attrs: nounwind
define internal ptr @__thunk_CAllocator_Allocator_alloc(ptr %0, i64 %1) #0 {
entry:
%call = call ptr @CAllocator.alloc(ptr %0, i64 %1)
ret ptr %call
}
; Function Attrs: nounwind
define internal void @__thunk_CAllocator_Allocator_dealloc(ptr %0, ptr %1) #0 {
entry:
call void @CAllocator.dealloc(ptr %0, ptr %1)
ret void
}
; Function Attrs: nounwind
define internal ptr @__thunk_GPA_Allocator_alloc(ptr %0, i64 %1) #0 {
entry:
%call = call ptr @GPA.alloc(ptr %0, i64 %1)
ret ptr %call
}
; Function Attrs: nounwind
define internal void @__thunk_GPA_Allocator_dealloc(ptr %0, ptr %1) #0 {
entry:
call void @GPA.dealloc(ptr %0, ptr %1)
ret void
}
; Function Attrs: nounwind
define internal { ptr, i64 } @struct_to_string__Allocator({ ptr, ptr, ptr } %0) #0 {
entry:
%alloca = alloca { ptr, ptr, ptr }, align 8
store { ptr, ptr, ptr } %0, ptr %alloca, align 8
%call = call { ptr, i64 } @concat({ ptr, i64 } { ptr @str.19, i64 9 }, { ptr, i64 } { ptr @str.20, 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.52
while.hdr.52: ; preds = %fv.merge, %entry
%load = load i64, ptr %allocaN, align 8
%icmp = icmp slt i64 %load, 3
br i1 %icmp, label %while.body.53, label %while.exit.54
while.body.53: ; preds = %while.hdr.52
%loadN = load i64, ptr %allocaN, align 8
%icmpN = icmp sgt i64 %loadN, 0
br i1 %icmpN, label %if.then.55, label %if.merge.56
while.exit.54: ; preds = %while.hdr.52
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%callN = call { ptr, i64 } @concat({ ptr, i64 } %loadN, { ptr, i64 } { ptr @str.21, i64 1 })
ret { ptr, i64 } %callN
if.then.55: ; preds = %while.body.53
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%callN = call { ptr, i64 } @concat({ ptr, i64 } %loadN, { ptr, i64 } { ptr @str.22, i64 2 })
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %if.merge.56
if.merge.56: ; preds = %if.then.55, %while.body.53
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%loadN = load i64, ptr %allocaN, align 8
%fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names, i64 0, i64 %loadN
%fn.load = load { ptr, i64 }, ptr %fn.gep, align 8
%callN = call { ptr, i64 } @concat({ 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, i64 } %loadN, { ptr, i64 } { ptr @str.25, 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({ i64, i64 } %fv.phi)
%callN = call { ptr, i64 } @concat({ 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.52
fv.default: ; preds = %if.merge.56
br label %fv.merge
fv.case: ; preds = %if.merge.56
%fv.field = extractvalue { ptr, ptr, ptr } %loadN, 0
%pNi = ptrtoint ptr %fv.field to i64
%fv.val = insertvalue { i64, i64 } { i64 17, i64 undef }, i64 %pNi, 1
br label %fv.merge
fv.case17: ; preds = %if.merge.56
%fv.field18 = extractvalue { ptr, ptr, ptr } %loadN, 1
%pNi19 = ptrtoint ptr %fv.field18 to i64
%fv.val20 = insertvalue { i64, i64 } { i64 17, i64 undef }, i64 %pNi19, 1
br label %fv.merge
fv.case21: ; preds = %if.merge.56
%fv.field22 = extractvalue { ptr, ptr, ptr } %loadN, 2
%pNi23 = ptrtoint ptr %fv.field22 to i64
%fv.val24 = insertvalue { i64, i64 } { i64 17, i64 undef }, i64 %pNi23, 1
br label %fv.merge
}
; Function Attrs: nounwind
define internal { ptr, i64 } @struct_to_string__CAllocator({} %0) #0 {
entry:
%alloca = alloca {}, align 8
store {} %0, ptr %alloca, align 1
%call = call { ptr, i64 } @concat({ ptr, i64 } { ptr @str.26, i64 10 }, { ptr, i64 } { ptr @str.27, 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.57
while.hdr.57: ; preds = %if.merge.61, %entry
%load = load i64, ptr %allocaN, align 8
%icmp = icmp slt i64 %load, 0
br i1 %icmp, label %while.body.58, label %while.exit.59
while.body.58: ; preds = %while.hdr.57
%loadN = load i64, ptr %allocaN, align 8
%icmpN = icmp sgt i64 %loadN, 0
br i1 %icmpN, label %if.then.60, label %if.merge.61
while.exit.59: ; preds = %while.hdr.57
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%callN = call { ptr, i64 } @concat({ ptr, i64 } %loadN, { ptr, i64 } { ptr @str.28, i64 1 })
ret { ptr, i64 } %callN
if.then.60: ; preds = %while.body.58
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%callN = call { ptr, i64 } @concat({ ptr, i64 } %loadN, { ptr, i64 } { ptr @str.29, i64 2 })
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %if.merge.61
if.merge.61: ; preds = %if.then.60, %while.body.58
%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.30, i64 0, i64 %loadN
%fn.load = load { ptr, i64 }, ptr %fn.gep, align 8
%callN = call { ptr, i64 } @concat({ 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, i64 } %loadN, { ptr, i64 } { ptr @str.31, 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({ i64, i64 } zeroinitializer)
%callN = call { ptr, i64 } @concat({ 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.57
}
; Function Attrs: nounwind
define internal { ptr, i64 } @struct_to_string__GPA({ i64 } %0) #0 {
entry:
%alloca = alloca { i64 }, align 8
store { i64 } %0, ptr %alloca, align 8
%call = call { ptr, i64 } @concat({ ptr, i64 } { ptr @str.32, i64 3 }, { ptr, i64 } { ptr @str.33, 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.62
while.hdr.62: ; preds = %fv.merge, %entry
%load = load i64, ptr %allocaN, align 8
%icmp = icmp slt i64 %load, 1
br i1 %icmp, label %while.body.63, label %while.exit.64
while.body.63: ; preds = %while.hdr.62
%loadN = load i64, ptr %allocaN, align 8
%icmpN = icmp sgt i64 %loadN, 0
br i1 %icmpN, label %if.then.65, label %if.merge.66
while.exit.64: ; preds = %while.hdr.62
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%callN = call { ptr, i64 } @concat({ ptr, i64 } %loadN, { ptr, i64 } { ptr @str.34, i64 1 })
ret { ptr, i64 } %callN
if.then.65: ; preds = %while.body.63
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%callN = call { ptr, i64 } @concat({ ptr, i64 } %loadN, { ptr, i64 } { ptr @str.35, i64 2 })
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %if.merge.66
if.merge.66: ; preds = %if.then.65, %while.body.63
%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.37, i64 0, i64 %loadN
%fn.load = load { ptr, i64 }, ptr %fn.gep, align 8
%callN = call { ptr, i64 } @concat({ 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, i64 } %loadN, { ptr, i64 } { ptr @str.38, 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({ i64, i64 } %fv.phi)
%callN = call { ptr, i64 } @concat({ 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.62
fv.default: ; preds = %if.merge.66
br label %fv.merge
fv.case: ; preds = %if.merge.66
%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, i64 } %0) #0 {
entry:
%alloca = alloca { ptr, i64 }, align 8
store { ptr, i64 } %0, ptr %alloca, align 8
%call = call { ptr, i64 } @concat({ ptr, i64 } { ptr @str.39, i64 10 }, { ptr, i64 } { ptr @str.40, 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.67
while.hdr.67: ; preds = %fv.merge, %entry
%load = load i64, ptr %allocaN, align 8
%icmp = icmp slt i64 %load, 2
br i1 %icmp, label %while.body.68, label %while.exit.69
while.body.68: ; preds = %while.hdr.67
%loadN = load i64, ptr %allocaN, align 8
%icmpN = icmp sgt i64 %loadN, 0
br i1 %icmpN, label %if.then.70, label %if.merge.71
while.exit.69: ; preds = %while.hdr.67
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%callN = call { ptr, i64 } @concat({ ptr, i64 } %loadN, { ptr, i64 } { ptr @str.41, i64 1 })
ret { ptr, i64 } %callN
if.then.70: ; preds = %while.body.68
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%callN = call { ptr, i64 } @concat({ ptr, i64 } %loadN, { ptr, i64 } { ptr @str.42, i64 2 })
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %if.merge.71
if.merge.71: ; preds = %if.then.70, %while.body.68
%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.45, i64 0, i64 %loadN
%fn.load = load { ptr, i64 }, ptr %fn.gep, align 8
%callN = call { ptr, i64 } @concat({ 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, i64 } %loadN, { ptr, i64 } { ptr @str.46, 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({ i64, i64 } %fv.phi)
%callN = call { ptr, i64 } @concat({ 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.67
fv.default: ; preds = %if.merge.71
br label %fv.merge
fv.case: ; preds = %if.merge.71
%fv.field = extractvalue { ptr, i64 } %loadN, 0
%pNi = ptrtoint ptr %fv.field to i64
%fv.val = insertvalue { i64, i64 } { i64 24, i64 undef }, i64 %pNi, 1
br label %fv.merge
fv.case17: ; preds = %if.merge.71
%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, i64, { ptr, ptr, ptr } } %0) #0 {
entry:
%alloca = alloca { ptr, i64, { ptr, ptr, ptr } }, align 8
store { ptr, i64, { ptr, ptr, ptr } } %0, ptr %alloca, align 8
%call = call { ptr, i64 } @concat({ ptr, i64 } { ptr @str.47, i64 5 }, { ptr, i64 } { ptr @str.48, 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.72
while.hdr.72: ; preds = %fv.merge, %entry
%load = load i64, ptr %allocaN, align 8
%icmp = icmp slt i64 %load, 3
br i1 %icmp, label %while.body.73, label %while.exit.74
while.body.73: ; preds = %while.hdr.72
%loadN = load i64, ptr %allocaN, align 8
%icmpN = icmp sgt i64 %loadN, 0
br i1 %icmpN, label %if.then.75, label %if.merge.76
while.exit.74: ; preds = %while.hdr.72
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%callN = call { ptr, i64 } @concat({ ptr, i64 } %loadN, { ptr, i64 } { ptr @str.49, i64 1 })
ret { ptr, i64 } %callN
if.then.75: ; preds = %while.body.73
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%callN = call { ptr, i64 } @concat({ ptr, i64 } %loadN, { ptr, i64 } { ptr @str.50, i64 2 })
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %if.merge.76
if.merge.76: ; preds = %if.then.75, %while.body.73
%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.54, i64 0, i64 %loadN
%fn.load = load { ptr, i64 }, ptr %fn.gep, align 8
%callN = call { ptr, i64 } @concat({ 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, i64 } %loadN, { ptr, i64 } { ptr @str.55, 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({ i64, i64 } %fv.phi)
%callN = call { ptr, i64 } @concat({ 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.72
fv.default: ; preds = %if.merge.76
br label %fv.merge
fv.case: ; preds = %if.merge.76
%fv.field = extractvalue { ptr, i64, { ptr, ptr, ptr } } %loadN, 0
%pNi = ptrtoint ptr %fv.field to i64
%fv.val = insertvalue { i64, i64 } { i64 24, i64 undef }, i64 %pNi, 1
br label %fv.merge
fv.case17: ; preds = %if.merge.76
%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.76
%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 18, i64 undef }, i64 %ba.p2i, 1
br label %fv.merge
}
; Function Attrs: nounwind
define internal { ptr, i64 } @struct_to_string__BufAlloc({ ptr, i64, i64 } %0) #0 {
entry:
%alloca = alloca { ptr, i64, i64 }, align 8
store { ptr, i64, i64 } %0, ptr %alloca, align 8
%call = call { ptr, i64 } @concat({ ptr, i64 } { ptr @str.56, i64 8 }, { ptr, i64 } { ptr @str.57, 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.77
while.hdr.77: ; preds = %fv.merge, %entry
%load = load i64, ptr %allocaN, align 8
%icmp = icmp slt i64 %load, 3
br i1 %icmp, label %while.body.78, label %while.exit.79
while.body.78: ; preds = %while.hdr.77
%loadN = load i64, ptr %allocaN, align 8
%icmpN = icmp sgt i64 %loadN, 0
br i1 %icmpN, label %if.then.80, label %if.merge.81
while.exit.79: ; preds = %while.hdr.77
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%callN = call { ptr, i64 } @concat({ ptr, i64 } %loadN, { ptr, i64 } { ptr @str.58, i64 1 })
ret { ptr, i64 } %callN
if.then.80: ; preds = %while.body.78
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%callN = call { ptr, i64 } @concat({ ptr, i64 } %loadN, { ptr, i64 } { ptr @str.59, i64 2 })
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %if.merge.81
if.merge.81: ; preds = %if.then.80, %while.body.78
%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.63, i64 0, i64 %loadN
%fn.load = load { ptr, i64 }, ptr %fn.gep, align 8
%callN = call { ptr, i64 } @concat({ 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, i64 } %loadN, { ptr, i64 } { ptr @str.64, 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({ i64, i64 } %fv.phi)
%callN = call { ptr, i64 } @concat({ 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.77
fv.default: ; preds = %if.merge.81
br label %fv.merge
fv.case: ; preds = %if.merge.81
%fv.field = extractvalue { ptr, i64, i64 } %loadN, 0
%pNi = ptrtoint ptr %fv.field to i64
%fv.val = insertvalue { i64, i64 } { i64 27, i64 undef }, i64 %pNi, 1
br label %fv.merge
fv.case17: ; preds = %if.merge.81
%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.81
%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, ptr, ptr }, i64, i64, i64 } %0) #0 {
entry:
%alloca = alloca { { ptr, ptr, ptr }, i64, i64, i64 }, align 8
store { { ptr, ptr, ptr }, i64, i64, i64 } %0, ptr %alloca, align 8
%call = call { ptr, i64 } @concat({ ptr, i64 } { ptr @str.65, i64 17 }, { ptr, i64 } { ptr @str.66, 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.82
while.hdr.82: ; preds = %fv.merge, %entry
%load = load i64, ptr %allocaN, align 8
%icmp = icmp slt i64 %load, 4
br i1 %icmp, label %while.body.83, label %while.exit.84
while.body.83: ; preds = %while.hdr.82
%loadN = load i64, ptr %allocaN, align 8
%icmpN = icmp sgt i64 %loadN, 0
br i1 %icmpN, label %if.then.85, label %if.merge.86
while.exit.84: ; preds = %while.hdr.82
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%callN = call { ptr, i64 } @concat({ ptr, i64 } %loadN, { ptr, i64 } { ptr @str.67, i64 1 })
ret { ptr, i64 } %callN
if.then.85: ; preds = %while.body.83
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%callN = call { ptr, i64 } @concat({ ptr, i64 } %loadN, { ptr, i64 } { ptr @str.68, i64 2 })
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %if.merge.86
if.merge.86: ; preds = %if.then.85, %while.body.83
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%loadN = load i64, ptr %allocaN, align 8
%fn.gep = getelementptr inbounds [4 x { ptr, i64 }], ptr @field_names.73, i64 0, i64 %loadN
%fn.load = load { ptr, i64 }, ptr %fn.gep, align 8
%callN = call { ptr, i64 } @concat({ 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, i64 } %loadN, { ptr, i64 } { ptr @str.74, 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({ i64, i64 } %fv.phi)
%callN = call { ptr, i64 } @concat({ 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.82
fv.default: ; preds = %if.merge.86
br label %fv.merge
fv.case: ; preds = %if.merge.86
%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 18, i64 undef }, i64 %ba.p2i, 1
br label %fv.merge
fv.case17: ; preds = %if.merge.86
%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.86
%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.86
%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, ptr, ptr }, ptr } %0) #0 {
entry:
%alloca = alloca { { ptr, ptr, ptr }, ptr }, align 8
store { { ptr, ptr, ptr }, ptr } %0, ptr %alloca, align 8
%call = call { ptr, i64 } @concat({ ptr, i64 } { ptr @str.75, i64 7 }, { ptr, i64 } { ptr @str.76, 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, 2
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, i64 } %loadN, { ptr, i64 } { ptr @str.77, 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, i64 } %loadN, { ptr, i64 } { ptr @str.78, 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 [2 x { ptr, i64 }], ptr @field_names.81, i64 0, i64 %loadN
%fn.load = load { ptr, i64 }, ptr %fn.gep, align 8
%callN = call { ptr, i64 } @concat({ 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, i64 } %loadN, { ptr, i64 } { ptr @str.82, 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({ i64, i64 } %fv.phi)
%callN = call { ptr, i64 } @concat({ 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, 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 18, i64 undef }, i64 %ba.p2i, 1
br label %fv.merge
fv.case17: ; preds = %if.merge.91
%fv.field18 = extractvalue { { ptr, ptr, ptr }, ptr } %loadN, 1
%pNi = ptrtoint ptr %fv.field18 to i64
%fv.val19 = insertvalue { i64, i64 } { i64 17, i64 undef }, i64 %pNi, 1
br label %fv.merge
}
; Function Attrs: nounwind
define internal { ptr, i64 } @struct_to_string__BuildOptions({} %0) #0 {
entry:
%alloca = alloca {}, align 8
store {} %0, ptr %alloca, align 1
%call = call { ptr, i64 } @concat({ ptr, i64 } { ptr @str.83, i64 12 }, { ptr, i64 } { ptr @str.84, 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 = %if.merge.96, %entry
%load = load i64, ptr %allocaN, align 8
%icmp = icmp slt i64 %load, 0
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, i64 } %loadN, { ptr, i64 } { ptr @str.85, 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, i64 } %loadN, { ptr, i64 } { ptr @str.86, 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 [0 x { ptr, i64 }], ptr @field_names.87, i64 0, i64 %loadN
%fn.load = load { ptr, i64 }, ptr %fn.gep, align 8
%callN = call { ptr, i64 } @concat({ 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, i64 } %loadN, { ptr, i64 } { ptr @str.88, 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({ i64, i64 } zeroinitializer)
%callN = call { ptr, i64 } @concat({ 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
}
; Function Attrs: nounwind
define internal { ptr, i64 } @struct_to_string__Triple({ i64, i64, i64 } %0) #0 {
entry:
%alloca = alloca { i64, i64, i64 }, align 8
store { i64, i64, i64 } %0, ptr %alloca, align 8
%call = call { ptr, i64 } @concat({ ptr, i64 } { ptr @str.89, i64 6 }, { ptr, i64 } { ptr @str.90, i64 1 })
%allocaN = alloca { ptr, i64 }, align 8
store { ptr, i64 } %call, ptr %allocaN, align 8
%allocaN = alloca i64, align 8
store i64 0, ptr %allocaN, align 8
br label %while.hdr.97
while.hdr.97: ; preds = %fv.merge, %entry
%load = load i64, ptr %allocaN, align 8
%icmp = icmp slt i64 %load, 3
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, i64 } %loadN, { ptr, i64 } { ptr @str.91, 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, i64 } %loadN, { ptr, i64 } { ptr @str.92, 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 [3 x { ptr, i64 }], ptr @field_names.96, i64 0, i64 %loadN
%fn.load = load { ptr, i64 }, ptr %fn.gep, align 8
%callN = call { ptr, i64 } @concat({ 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, i64 } %loadN, { ptr, i64 } { ptr @str.97, i64 2 })
store { ptr, i64 } %callN, ptr %allocaN, align 8
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%loadN = load { i64, 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({ i64, i64 } %fv.phi)
%callN = call { ptr, i64 } @concat({ ptr, i64 } %loadN, { ptr, i64 } %callN)
store { ptr, i64 } %callN, ptr %allocaN, align 8
%loadN = load i64, ptr %allocaN, align 8
%add = add i64 %loadN, 1
store i64 %add, ptr %allocaN, align 8
br label %while.hdr.97
fv.default: ; preds = %if.merge.101
br label %fv.merge
fv.case: ; preds = %if.merge.101
%fv.field = extractvalue { i64, i64, i64 } %loadN, 0
%fv.val = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field, 1
br label %fv.merge
fv.case17: ; preds = %if.merge.101
%fv.field18 = extractvalue { i64, i64, i64 } %loadN, 1
%fv.val19 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field18, 1
br label %fv.merge
fv.case20: ; preds = %if.merge.101
%fv.field21 = extractvalue { i64, i64, i64 } %loadN, 2
%fv.val22 = insertvalue { i64, i64 } { i64 5, i64 undef }, i64 %fv.field21, 1
br label %fv.merge
}
; Function Attrs: nounwind
define internal { ptr, i64 } @enum_to_string__OperatingSystem(i64 %0) #0 {
entry:
%alloca = alloca i64, align 8
store i64 %0, ptr %alloca, align 8
%load = load i64, ptr %alloca, align 8
%allocaN = alloca i64, align 8
store i64 %load, ptr %allocaN, align 8
%loadN = load i64, ptr %allocaN, align 8
%fn.gep = getelementptr inbounds [7 x { ptr, i64 }], ptr @field_names.106, i64 0, i64 %loadN
%fn.load = load { ptr, i64 }, ptr %fn.gep, align 8
%call = call { ptr, i64 } @concat({ ptr, i64 } { ptr @str.98, i64 1 }, { ptr, i64 } %fn.load)
%allocaN = alloca { ptr, i64 }, align 8
store { ptr, i64 } %call, ptr %allocaN, align 8
%loadN = load i64, ptr %alloca, align 8
%loadN = load i64, ptr %allocaN, align 8
%allocaN = alloca { i64, i64 }, align 8
store { i64, i64 } zeroinitializer, ptr %allocaN, align 8
%loadN = load { i64, i64 }, ptr %allocaN, align 8
%callN = call { ptr, i64 } @any_to_string({ 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.106, label %if.merge.107
if.then.106: ; preds = %entry
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%callN = call { ptr, i64 } @concat({ ptr, i64 } %loadN, { ptr, i64 } { ptr @str.108, i64 1 })
%callN = call { ptr, i64 } @concat({ ptr, i64 } { ptr @str.107, i64 1 }, { ptr, i64 } %callN)
%callN = call { ptr, i64 } @concat({ ptr, i64 } %loadN, { ptr, i64 } %callN)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %if.merge.107
if.merge.107: ; preds = %if.then.106, %entry
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
ret { ptr, i64 } %loadN
}
; Function Attrs: nounwind
define internal { ptr, i64 } @enum_to_string__Architecture(i64 %0) #0 {
entry:
%alloca = alloca i64, align 8
store i64 %0, ptr %alloca, align 8
%load = load i64, ptr %alloca, align 8
%allocaN = alloca i64, align 8
store i64 %load, ptr %allocaN, align 8
%loadN = load i64, ptr %allocaN, align 8
%fn.gep = getelementptr inbounds [5 x { ptr, i64 }], ptr @field_names.115, i64 0, i64 %loadN
%fn.load = load { ptr, i64 }, ptr %fn.gep, align 8
%call = call { ptr, i64 } @concat({ ptr, i64 } { ptr @str.109, i64 1 }, { ptr, i64 } %fn.load)
%allocaN = alloca { ptr, i64 }, align 8
store { ptr, i64 } %call, ptr %allocaN, align 8
%loadN = load i64, ptr %alloca, align 8
%loadN = load i64, ptr %allocaN, align 8
%allocaN = alloca { i64, i64 }, align 8
store { i64, i64 } zeroinitializer, ptr %allocaN, align 8
%loadN = load { i64, i64 }, ptr %allocaN, align 8
%callN = call { ptr, i64 } @any_to_string({ 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.108, label %if.merge.109
if.then.108: ; preds = %entry
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%callN = call { ptr, i64 } @concat({ ptr, i64 } %loadN, { ptr, i64 } { ptr @str.117, i64 1 })
%callN = call { ptr, i64 } @concat({ ptr, i64 } { ptr @str.116, i64 1 }, { ptr, i64 } %callN)
%callN = call { ptr, i64 } @concat({ ptr, i64 } %loadN, { ptr, i64 } %callN)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %if.merge.109
if.merge.109: ; preds = %if.then.108, %entry
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
ret { ptr, i64 } %loadN
}
; Function Attrs: nounwind
define internal { ptr, i64 } @array_to_string__AR_1_Any([1 x { i64, i64 }] %0) #0 {
entry:
%alloca = alloca [1 x { i64, i64 }], align 8
store [1 x { i64, i64 }] %0, ptr %alloca, align 8
%allocaN = alloca { ptr, i64 }, align 8
store { ptr, i64 } { ptr @str.118, i64 1 }, ptr %allocaN, align 8
%allocaN = alloca i64, align 8
store i64 0, ptr %allocaN, align 8
br label %while.hdr.114
while.hdr.114: ; preds = %if.merge.118, %entry
%load = load i64, ptr %allocaN, align 8
%icmp = icmp slt i64 %load, 1
br i1 %icmp, label %while.body.115, label %while.exit.116
while.body.115: ; preds = %while.hdr.114
%loadN = load i64, ptr %allocaN, align 8
%icmpN = icmp sgt i64 %loadN, 0
br i1 %icmpN, label %if.then.117, label %if.merge.118
while.exit.116: ; preds = %while.hdr.114
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%call = call { ptr, i64 } @concat({ ptr, i64 } %loadN, { ptr, i64 } { ptr @str.119, i64 1 })
ret { ptr, i64 } %call
if.then.117: ; preds = %while.body.115
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%callN = call { ptr, i64 } @concat({ ptr, i64 } %loadN, { ptr, i64 } { ptr @str.120, i64 2 })
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %if.merge.118
if.merge.118: ; preds = %if.then.117, %while.body.115
%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({ i64, i64 } %ba.val)
%callN = call { ptr, i64 } @concat({ 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.114
}
; Function Attrs: nounwind
define internal { ptr, i64 } @array_to_string__AR_3_Any([3 x { i64, i64 }] %0) #0 {
entry:
%alloca = alloca [3 x { i64, i64 }], align 8
store [3 x { i64, i64 }] %0, ptr %alloca, align 8
%allocaN = alloca { ptr, i64 }, align 8
store { ptr, i64 } { ptr @str.121, i64 1 }, ptr %allocaN, align 8
%allocaN = alloca i64, align 8
store i64 0, ptr %allocaN, align 8
br label %while.hdr.119
while.hdr.119: ; preds = %if.merge.123, %entry
%load = load i64, ptr %allocaN, align 8
%icmp = icmp slt i64 %load, 3
br i1 %icmp, label %while.body.120, label %while.exit.121
while.body.120: ; preds = %while.hdr.119
%loadN = load i64, ptr %allocaN, align 8
%icmpN = icmp sgt i64 %loadN, 0
br i1 %icmpN, label %if.then.122, label %if.merge.123
while.exit.121: ; preds = %while.hdr.119
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%call = call { ptr, i64 } @concat({ ptr, i64 } %loadN, { ptr, i64 } { ptr @str.122, i64 1 })
ret { ptr, i64 } %call
if.then.122: ; preds = %while.body.120
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%callN = call { ptr, i64 } @concat({ ptr, i64 } %loadN, { ptr, i64 } { ptr @str.123, i64 2 })
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %if.merge.123
if.merge.123: ; preds = %if.then.122, %while.body.120
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%loadN = load [3 x { i64, i64 }], ptr %alloca, align 8
%loadN = load i64, ptr %allocaN, align 8
%ig.tmp = alloca [3 x { i64, i64 }], align 8
store [3 x { i64, i64 }] %loadN, ptr %ig.tmp, align 8
%ig.ptr = getelementptr [3 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({ i64, i64 } %ba.val)
%callN = call { ptr, i64 } @concat({ 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.119
}
; Function Attrs: nounwind
define internal { ptr, i64 } @slice_to_string__string({ ptr, i64 } %0) #0 {
entry:
%alloca = alloca { ptr, i64 }, align 8
store { ptr, i64 } %0, ptr %alloca, align 8
%allocaN = alloca { ptr, i64 }, align 8
store { ptr, i64 } { ptr @str.124, i64 1 }, ptr %allocaN, align 8
%allocaN = alloca i64, align 8
store i64 0, ptr %allocaN, align 8
br label %while.hdr.128
while.hdr.128: ; preds = %if.merge.132, %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.129, label %while.exit.130
while.body.129: ; preds = %while.hdr.128
%loadN = load i64, ptr %allocaN, align 8
%icmpN = icmp sgt i64 %loadN, 0
br i1 %icmpN, label %if.then.131, label %if.merge.132
while.exit.130: ; preds = %while.hdr.128
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%call = call { ptr, i64 } @concat({ ptr, i64 } %loadN, { ptr, i64 } { ptr @str.125, i64 1 })
ret { ptr, i64 } %call
if.then.131: ; preds = %while.body.129
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%callN = call { ptr, i64 } @concat({ ptr, i64 } %loadN, { ptr, i64 } { ptr @str.126, i64 2 })
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %if.merge.132
if.merge.132: ; preds = %if.then.131, %while.body.129
%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({ i64, i64 } %ba.val)
%callN = call { ptr, i64 } @concat({ 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.128
}
; Function Attrs: nounwind
define internal { ptr, i64 } @slice_to_string__Any({ ptr, i64 } %0) #0 {
entry:
%alloca = alloca { ptr, i64 }, align 8
store { ptr, i64 } %0, ptr %alloca, align 8
%allocaN = alloca { ptr, i64 }, align 8
store { ptr, i64 } { ptr @str.127, i64 1 }, ptr %allocaN, align 8
%allocaN = alloca i64, align 8
store i64 0, ptr %allocaN, align 8
br label %while.hdr.133
while.hdr.133: ; preds = %if.merge.137, %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.134, label %while.exit.135
while.body.134: ; preds = %while.hdr.133
%loadN = load i64, ptr %allocaN, align 8
%icmpN = icmp sgt i64 %loadN, 0
br i1 %icmpN, label %if.then.136, label %if.merge.137
while.exit.135: ; preds = %while.hdr.133
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%call = call { ptr, i64 } @concat({ ptr, i64 } %loadN, { ptr, i64 } { ptr @str.128, i64 1 })
ret { ptr, i64 } %call
if.then.136: ; preds = %while.body.134
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%callN = call { ptr, i64 } @concat({ ptr, i64 } %loadN, { ptr, i64 } { ptr @str.129, i64 2 })
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %if.merge.137
if.merge.137: ; preds = %if.then.136, %while.body.134
%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({ i64, i64 } %ba.val)
%callN = call { ptr, i64 } @concat({ 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.133
}
; Function Attrs: nounwind
define internal { ptr, i64 } @pointer_to_string__ptr_void(ptr %0) #0 {
entry:
%alloca = alloca ptr, align 8
store ptr %0, 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.160, label %if.else.161
if.then.160: ; preds = %entry
br label %if.merge.162
if.else.161: ; preds = %entry
%loadN = load i64, ptr %allocaN, align 8
%call = call { ptr, i64 } @int_to_hex_string(i64 %loadN)
%callN = call { ptr, i64 } @concat({ ptr, i64 } { ptr @str.132, i64 3 }, { ptr, i64 } %call)
%callN = call { ptr, i64 } @concat({ ptr, i64 } { ptr @str.131, i64 5 }, { ptr, i64 } %callN)
br label %if.merge.162
if.merge.162: ; preds = %if.else.161, %if.then.160
%bp = phi { ptr, i64 } [ { ptr @str.130, i64 4 }, %if.then.160 ], [ %callN, %if.else.161 ]
ret { ptr, i64 } %bp
}
; Function Attrs: nounwind
define internal { ptr, i64 } @pointer_to_string__ptr_CAllocator(ptr %0) #0 {
entry:
%alloca = alloca ptr, align 8
store ptr %0, 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.184, label %if.else.185
if.then.184: ; preds = %entry
br label %if.merge.186
if.else.185: ; preds = %entry
%loadN = load i64, ptr %allocaN, align 8
%call = call { ptr, i64 } @int_to_hex_string(i64 %loadN)
%callN = call { ptr, i64 } @concat({ ptr, i64 } { ptr @str.135, i64 3 }, { ptr, i64 } %call)
%callN = call { ptr, i64 } @concat({ ptr, i64 } { ptr @str.134, i64 11 }, { ptr, i64 } %callN)
br label %if.merge.186
if.merge.186: ; preds = %if.else.185, %if.then.184
%bp = phi { ptr, i64 } [ { ptr @str.133, i64 4 }, %if.then.184 ], [ %callN, %if.else.185 ]
ret { ptr, i64 } %bp
}
; Function Attrs: nounwind
define internal { ptr, i64 } @pointer_to_string__ptr_GPA(ptr %0) #0 {
entry:
%alloca = alloca ptr, align 8
store ptr %0, 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.187, label %if.else.188
if.then.187: ; preds = %entry
br label %if.merge.189
if.else.188: ; preds = %entry
%loadN = load i64, ptr %allocaN, align 8
%call = call { ptr, i64 } @int_to_hex_string(i64 %loadN)
%callN = call { ptr, i64 } @concat({ ptr, i64 } { ptr @str.138, i64 3 }, { ptr, i64 } %call)
%callN = call { ptr, i64 } @concat({ ptr, i64 } { ptr @str.137, i64 4 }, { ptr, i64 } %callN)
br label %if.merge.189
if.merge.189: ; preds = %if.else.188, %if.then.187
%bp = phi { ptr, i64 } [ { ptr @str.136, i64 4 }, %if.then.187 ], [ %callN, %if.else.188 ]
ret { ptr, i64 } %bp
}
; Function Attrs: nounwind
define internal { ptr, i64 } @pointer_to_string__ptr_ArenaChunk(ptr %0) #0 {
entry:
%alloca = alloca ptr, align 8
store ptr %0, 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.190, label %if.else.191
if.then.190: ; preds = %entry
br label %if.merge.192
if.else.191: ; preds = %entry
%loadN = load i64, ptr %allocaN, align 8
%call = call { ptr, i64 } @int_to_hex_string(i64 %loadN)
%callN = call { ptr, i64 } @concat({ ptr, i64 } { ptr @str.141, i64 3 }, { ptr, i64 } %call)
%callN = call { ptr, i64 } @concat({ ptr, i64 } { ptr @str.140, i64 11 }, { ptr, i64 } %callN)
br label %if.merge.192
if.merge.192: ; preds = %if.else.191, %if.then.190
%bp = phi { ptr, i64 } [ { ptr @str.139, i64 4 }, %if.then.190 ], [ %callN, %if.else.191 ]
ret { ptr, i64 } %bp
}
; Function Attrs: nounwind
define internal { ptr, i64 } @pointer_to_string__ptr_Arena(ptr %0) #0 {
entry:
%alloca = alloca ptr, align 8
store ptr %0, 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.193, label %if.else.194
if.then.193: ; preds = %entry
br label %if.merge.195
if.else.194: ; preds = %entry
%loadN = load i64, ptr %allocaN, align 8
%call = call { ptr, i64 } @int_to_hex_string(i64 %loadN)
%callN = call { ptr, i64 } @concat({ ptr, i64 } { ptr @str.144, i64 3 }, { ptr, i64 } %call)
%callN = call { ptr, i64 } @concat({ ptr, i64 } { ptr @str.143, i64 6 }, { ptr, i64 } %callN)
br label %if.merge.195
if.merge.195: ; preds = %if.else.194, %if.then.193
%bp = phi { ptr, i64 } [ { ptr @str.142, i64 4 }, %if.then.193 ], [ %callN, %if.else.194 ]
ret { ptr, i64 } %bp
}
; Function Attrs: nounwind
define internal { ptr, i64 } @pointer_to_string__mptr_u8(ptr %0) #0 {
entry:
%alloca = alloca ptr, align 8
store ptr %0, 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.196, label %if.else.197
if.then.196: ; preds = %entry
br label %if.merge.198
if.else.197: ; preds = %entry
%loadN = load i64, ptr %allocaN, align 8
%call = call { ptr, i64 } @int_to_hex_string(i64 %loadN)
%callN = call { ptr, i64 } @concat({ ptr, i64 } { ptr @str.147, i64 3 }, { ptr, i64 } %call)
%callN = call { ptr, i64 } @concat({ ptr, i64 } { ptr @str.146, i64 5 }, { ptr, i64 } %callN)
br label %if.merge.198
if.merge.198: ; preds = %if.else.197, %if.then.196
%bp = phi { ptr, i64 } [ { ptr @str.145, i64 4 }, %if.then.196 ], [ %callN, %if.else.197 ]
ret { ptr, i64 } %bp
}
; Function Attrs: nounwind
define internal { ptr, i64 } @pointer_to_string__ptr_BufAlloc(ptr %0) #0 {
entry:
%alloca = alloca ptr, align 8
store ptr %0, 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.199, label %if.else.200
if.then.199: ; preds = %entry
br label %if.merge.201
if.else.200: ; preds = %entry
%loadN = load i64, ptr %allocaN, align 8
%call = call { ptr, i64 } @int_to_hex_string(i64 %loadN)
%callN = call { ptr, i64 } @concat({ ptr, i64 } { ptr @str.150, i64 3 }, { ptr, i64 } %call)
%callN = call { ptr, i64 } @concat({ ptr, i64 } { ptr @str.149, i64 9 }, { ptr, i64 } %callN)
br label %if.merge.201
if.merge.201: ; preds = %if.else.200, %if.then.199
%bp = phi { ptr, i64 } [ { ptr @str.148, i64 4 }, %if.then.199 ], [ %callN, %if.else.200 ]
ret { ptr, i64 } %bp
}
; Function Attrs: nounwind
define internal { ptr, i64 } @pointer_to_string__ptr_TrackingAllocator(ptr %0) #0 {
entry:
%alloca = alloca ptr, align 8
store ptr %0, 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.202, label %if.else.203
if.then.202: ; preds = %entry
br label %if.merge.204
if.else.203: ; preds = %entry
%loadN = load i64, ptr %allocaN, align 8
%call = call { ptr, i64 } @int_to_hex_string(i64 %loadN)
%callN = call { ptr, i64 } @concat({ ptr, i64 } { ptr @str.153, i64 3 }, { ptr, i64 } %call)
%callN = call { ptr, i64 } @concat({ ptr, i64 } { ptr @str.152, i64 18 }, { ptr, i64 } %callN)
br label %if.merge.204
if.merge.204: ; preds = %if.else.203, %if.then.202
%bp = phi { ptr, i64 } [ { ptr @str.151, i64 4 }, %if.then.202 ], [ %callN, %if.else.203 ]
ret { ptr, i64 } %bp
}
; Function Attrs: nounwind
define internal { ptr, i64 } @pointer_to_string__ptr_ptr_CAllocator(ptr %0) #0 {
entry:
%alloca = alloca ptr, align 8
store ptr %0, 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.205, label %if.else.206
if.then.205: ; preds = %entry
br label %if.merge.207
if.else.206: ; preds = %entry
%loadN = load i64, ptr %allocaN, align 8
%call = call { ptr, i64 } @int_to_hex_string(i64 %loadN)
%callN = call { ptr, i64 } @concat({ ptr, i64 } { ptr @str.156, i64 3 }, { ptr, i64 } %call)
%callN = call { ptr, i64 } @concat({ ptr, i64 } { ptr @str.155, i64 12 }, { ptr, i64 } %callN)
br label %if.merge.207
if.merge.207: ; preds = %if.else.206, %if.then.205
%bp = phi { ptr, i64 } [ { ptr @str.154, i64 4 }, %if.then.205 ], [ %callN, %if.else.206 ]
ret { ptr, i64 } %bp
}
; Function Attrs: nounwind
define internal { ptr, i64 } @pointer_to_string__ptr_s64(ptr %0) #0 {
entry:
%alloca = alloca ptr, align 8
store ptr %0, 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.208, label %if.else.209
if.then.208: ; preds = %entry
br label %if.merge.210
if.else.209: ; preds = %entry
%loadN = load i64, ptr %allocaN, align 8
%call = call { ptr, i64 } @int_to_hex_string(i64 %loadN)
%callN = call { ptr, i64 } @concat({ ptr, i64 } { ptr @str.159, i64 3 }, { ptr, i64 } %call)
%callN = call { ptr, i64 } @concat({ ptr, i64 } { ptr @str.158, i64 4 }, { ptr, i64 } %callN)
br label %if.merge.210
if.merge.210: ; preds = %if.else.209, %if.then.208
%bp = phi { ptr, i64 } [ { ptr @str.157, i64 4 }, %if.then.208 ], [ %callN, %if.else.209 ]
ret { ptr, i64 } %bp
}
; Function Attrs: nounwind
define internal { ptr, i64 } @pointer_to_string__ptr_ptr_void(ptr %0) #0 {
entry:
%alloca = alloca ptr, align 8
store ptr %0, 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.211, label %if.else.212
if.then.211: ; preds = %entry
br label %if.merge.213
if.else.212: ; preds = %entry
%loadN = load i64, ptr %allocaN, align 8
%call = call { ptr, i64 } @int_to_hex_string(i64 %loadN)
%callN = call { ptr, i64 } @concat({ ptr, i64 } { ptr @str.162, i64 3 }, { ptr, i64 } %call)
%callN = call { ptr, i64 } @concat({ ptr, i64 } { ptr @str.161, i64 6 }, { ptr, i64 } %callN)
br label %if.merge.213
if.merge.213: ; preds = %if.else.212, %if.then.211
%bp = phi { ptr, i64 } [ { ptr @str.160, i64 4 }, %if.then.211 ], [ %callN, %if.else.212 ]
ret { ptr, i64 } %bp
}
; Function Attrs: nounwind
define internal { ptr, i64 } @pointer_to_string__ptr_ptr_GPA(ptr %0) #0 {
entry:
%alloca = alloca ptr, align 8
store ptr %0, 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.214, label %if.else.215
if.then.214: ; preds = %entry
br label %if.merge.216
if.else.215: ; preds = %entry
%loadN = load i64, ptr %allocaN, align 8
%call = call { ptr, i64 } @int_to_hex_string(i64 %loadN)
%callN = call { ptr, i64 } @concat({ ptr, i64 } { ptr @str.165, i64 3 }, { ptr, i64 } %call)
%callN = call { ptr, i64 } @concat({ ptr, i64 } { ptr @str.164, i64 5 }, { ptr, i64 } %callN)
br label %if.merge.216
if.merge.216: ; preds = %if.else.215, %if.then.214
%bp = phi { ptr, i64 } [ { ptr @str.163, i64 4 }, %if.then.214 ], [ %callN, %if.else.215 ]
ret { ptr, i64 } %bp
}
; Function Attrs: nounwind
define internal { ptr, i64 } @pointer_to_string__ptr_bool(ptr %0) #0 {
entry:
%alloca = alloca ptr, align 8
store ptr %0, 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.217, label %if.else.218
if.then.217: ; preds = %entry
br label %if.merge.219
if.else.218: ; preds = %entry
%loadN = load i64, ptr %allocaN, align 8
%call = call { ptr, i64 } @int_to_hex_string(i64 %loadN)
%callN = call { ptr, i64 } @concat({ ptr, i64 } { ptr @str.168, i64 3 }, { ptr, i64 } %call)
%callN = call { ptr, i64 } @concat({ ptr, i64 } { ptr @str.167, i64 5 }, { ptr, i64 } %callN)
br label %if.merge.219
if.merge.219: ; preds = %if.else.218, %if.then.217
%bp = phi { ptr, i64 } [ { ptr @str.166, i64 4 }, %if.then.217 ], [ %callN, %if.else.218 ]
ret { ptr, i64 } %bp
}
; Function Attrs: nounwind
define internal { ptr, i64 } @pointer_to_string__ptr_AR_1_Any(ptr %0) #0 {
entry:
%alloca = alloca ptr, align 8
store ptr %0, 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.220, label %if.else.221
if.then.220: ; preds = %entry
br label %if.merge.222
if.else.221: ; preds = %entry
%loadN = load i64, ptr %allocaN, align 8
%call = call { ptr, i64 } @int_to_hex_string(i64 %loadN)
%callN = call { ptr, i64 } @concat({ ptr, i64 } { ptr @str.171, i64 3 }, { ptr, i64 } %call)
%callN = call { ptr, i64 } @concat({ ptr, i64 } { ptr @str.170, i64 7 }, { ptr, i64 } %callN)
br label %if.merge.222
if.merge.222: ; preds = %if.else.221, %if.then.220
%bp = phi { ptr, i64 } [ { ptr @str.169, i64 4 }, %if.then.220 ], [ %callN, %if.else.221 ]
ret { ptr, i64 } %bp
}
; Function Attrs: nounwind
define internal { ptr, i64 } @pointer_to_string__ptr_Any(ptr %0) #0 {
entry:
%alloca = alloca ptr, align 8
store ptr %0, 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.223, label %if.else.224
if.then.223: ; preds = %entry
br label %if.merge.225
if.else.224: ; preds = %entry
%loadN = load i64, ptr %allocaN, align 8
%call = call { ptr, i64 } @int_to_hex_string(i64 %loadN)
%callN = call { ptr, i64 } @concat({ ptr, i64 } { ptr @str.174, i64 3 }, { ptr, i64 } %call)
%callN = call { ptr, i64 } @concat({ ptr, i64 } { ptr @str.173, i64 4 }, { ptr, i64 } %callN)
br label %if.merge.225
if.merge.225: ; preds = %if.else.224, %if.then.223
%bp = phi { ptr, i64 } [ { ptr @str.172, i64 4 }, %if.then.223 ], [ %callN, %if.else.224 ]
ret { ptr, i64 } %bp
}
; Function Attrs: nounwind
define internal { ptr, i64 } @pointer_to_string__ptr_SL_Any(ptr %0) #0 {
entry:
%alloca = alloca ptr, align 8
store ptr %0, 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.226, label %if.else.227
if.then.226: ; preds = %entry
br label %if.merge.228
if.else.227: ; preds = %entry
%loadN = load i64, ptr %allocaN, align 8
%call = call { ptr, i64 } @int_to_hex_string(i64 %loadN)
%callN = call { ptr, i64 } @concat({ ptr, i64 } { ptr @str.177, i64 3 }, { ptr, i64 } %call)
%callN = call { ptr, i64 } @concat({ ptr, i64 } { ptr @str.176, i64 6 }, { ptr, i64 } %callN)
br label %if.merge.228
if.merge.228: ; preds = %if.else.227, %if.then.226
%bp = phi { ptr, i64 } [ { ptr @str.175, i64 4 }, %if.then.226 ], [ %callN, %if.else.227 ]
ret { ptr, i64 } %bp
}
; Function Attrs: nounwind
define internal { ptr, i64 } @pointer_to_string__ptr_string(ptr %0) #0 {
entry:
%alloca = alloca ptr, align 8
store ptr %0, 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.229, label %if.else.230
if.then.229: ; preds = %entry
br label %if.merge.231
if.else.230: ; preds = %entry
%loadN = load i64, ptr %allocaN, align 8
%call = call { ptr, i64 } @int_to_hex_string(i64 %loadN)
%callN = call { ptr, i64 } @concat({ ptr, i64 } { ptr @str.180, i64 3 }, { ptr, i64 } %call)
%callN = call { ptr, i64 } @concat({ ptr, i64 } { ptr @str.179, i64 7 }, { ptr, i64 } %callN)
br label %if.merge.231
if.merge.231: ; preds = %if.else.230, %if.then.229
%bp = phi { ptr, i64 } [ { ptr @str.178, i64 4 }, %if.then.229 ], [ %callN, %if.else.230 ]
ret { ptr, i64 } %bp
}
; Function Attrs: nounwind
define internal { ptr, i64 } @pointer_to_string__ptr_u8(ptr %0) #0 {
entry:
%alloca = alloca ptr, align 8
store ptr %0, 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.232, label %if.else.233
if.then.232: ; preds = %entry
br label %if.merge.234
if.else.233: ; preds = %entry
%loadN = load i64, ptr %allocaN, align 8
%call = call { ptr, i64 } @int_to_hex_string(i64 %loadN)
%callN = call { ptr, i64 } @concat({ ptr, i64 } { ptr @str.183, i64 3 }, { ptr, i64 } %call)
%callN = call { ptr, i64 } @concat({ ptr, i64 } { ptr @str.182, i64 3 }, { ptr, i64 } %callN)
br label %if.merge.234
if.merge.234: ; preds = %if.else.233, %if.then.232
%bp = phi { ptr, i64 } [ { ptr @str.181, i64 4 }, %if.then.232 ], [ %callN, %if.else.233 ]
ret { ptr, i64 } %bp
}
; Function Attrs: nounwind
define internal { ptr, i64 } @pointer_to_string__ptr_Triple(ptr %0) #0 {
entry:
%alloca = alloca ptr, align 8
store ptr %0, 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(i64 %loadN)
%callN = call { ptr, i64 } @concat({ ptr, i64 } { ptr @str.186, i64 3 }, { ptr, i64 } %call)
%callN = call { ptr, i64 } @concat({ ptr, i64 } { ptr @str.185, i64 7 }, { ptr, i64 } %callN)
br label %if.merge.237
if.merge.237: ; preds = %if.else.236, %if.then.235
%bp = phi { ptr, i64 } [ { ptr @str.184, i64 4 }, %if.then.235 ], [ %callN, %if.else.236 ]
ret { ptr, i64 } %bp
}
; Function Attrs: nounwind
define internal { ptr, i64 } @pointer_to_string__ptr_AR_3_Any(ptr %0) #0 {
entry:
%alloca = alloca ptr, align 8
store ptr %0, 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.238, label %if.else.239
if.then.238: ; preds = %entry
br label %if.merge.240
if.else.239: ; preds = %entry
%loadN = load i64, ptr %allocaN, align 8
%call = call { ptr, i64 } @int_to_hex_string(i64 %loadN)
%callN = call { ptr, i64 } @concat({ ptr, i64 } { ptr @str.189, i64 3 }, { ptr, i64 } %call)
%callN = call { ptr, i64 } @concat({ ptr, i64 } { ptr @str.188, i64 7 }, { ptr, i64 } %callN)
br label %if.merge.240
if.merge.240: ; preds = %if.else.239, %if.then.238
%bp = phi { ptr, i64 } [ { ptr @str.187, i64 4 }, %if.then.238 ], [ %callN, %if.else.239 ]
ret { ptr, i64 } %bp
}
declare i64 @write(i32, ptr, i64)
define internal void @__sx_objc_selector_init() {
entry:
%sel = call ptr @sel_registerName(ptr @OBJC_METH_VAR_NAME_)
store ptr %sel, ptr @OBJC_SELECTOR_REFERENCES_tripleValue, align 8
ret void
}