Files
sx/tests/expected/ffi-objc-call-06-sret-return.ir
agra 5cc62e63c3 bundling: fs/process stdlib + post-link callback + Apple .app in sx
Campaign Weeks 3-6 of /Users/agra/.claude/plans/lets-plan-to-move-splendid-pumpkin.md
land in one push: the bundling pipeline that used to live in
src/target.zig (createBundle, embedFramework, extractEntitlements,
buildInfoPlist, codesign) now lives in
library/modules/platform/bundle.sx and runs in the IR interpreter
after target.link() returns.

New language-side surface:
- library/modules/fs.sx — POSIX libc bindings (open/read/write/close,
  mkdir/unlink/rmdir, chmod, rename, access, basename/dirname). Variadic
  open() lowers to C's varargs via the new args: ..T form. Direct libc
  calls bypass *File method dispatch so they work from the post-link
  IR interpreter.
- library/modules/process.sx — popen-based run(cmd) returning
  ProcessResult{ exit_code, stdout }, plus env() and find_executable().
- library/modules/std.sx — xml_escape(s) and variadic path_join(parts).
- library/modules/compiler.sx — BuildOptions grows
  set_post_link_callback / set_post_link_module / binary_path
  accessors; bundle_path/bundle_id/codesign_identity/provisioning_profile
  setters + accessors; per-target predicates is_macos/is_ios/
  is_ios_device/is_ios_simulator + target_triple; framework_count /
  framework_at(i) / framework_path_count / framework_path_at(i);
  add_asset_dir(src, dest) + asset_dir_count / src_at / dest_at.

Compiler-side wiring:
- src/ir/compiler_hooks.zig — BuildConfig now carries post_link_callback_fn,
  post_link_module, binary_path, bundle_*, target_triple,
  target_frameworks, target_framework_paths, asset_dirs. Hook registry
  exposes every accessor; getters return "" / 0 for unset fields so
  bundle.sx can treat absent values uniformly.
- src/ir/host_ffi.zig (new) — dlsym(RTLD_DEFAULT) + arity-switched cdecl
  trampolines so #foreign("c") declarations resolve through the host
  libc during #run / post-link interpretation.
- src/ir/interp.zig — callForeign dispatch; build_config pointer
  injection so accessor hooks see live state during re-entry.
- src/core.zig — keeps the IR module alive past generateCode; exposes
  invokeByName / invokeByFuncId so main.zig can re-enter the
  interpreter after linking.
- src/main.zig — wires bundle/codesign/provisioning CLI flags +
  target_triple + framework lists into BuildConfig; invokes the
  post-link callback (by FuncId or by <module>.bundle_main lookup) once
  target.link() returns. When --bundle is set but no callback is
  registered, auto-falls-back to post_link_module = "platform.bundle"
  so the legacy --bundle CLI keeps working for any program that imports
  modules/platform/bundle.sx.

Apple .app bundler (library/modules/platform/bundle.sx):
- Single bundle_main entry covers macOS, iOS simulator, iOS device.
  Per-target Info.plist switch keys off is_ios()/is_ios_simulator() —
  iOS emits UIDeviceFamily / LSRequiresIPhoneOS /
  UIApplicationSceneManifest / DTPlatformName (iPhoneOS or
  iPhoneSimulator); macOS emits the minimal CFBundle* set.
- iOS-only steps:
  - Provisioning embed: fs.read_file + fs.write_file to
    <bundle>/embedded.mobileprovision.
  - Framework embed: recursive cp -R per -F search path into
    <bundle>/Frameworks/<Name>.framework/ (until fs.sx grows list_dir).
  - Entitlements extraction: four process.run calls (security cms -D,
    plutil -extract Entitlements xml1, plutil -extract
    ApplicationIdentifierPrefix.0, plutil -replace application-identifier)
    resolving the wildcard <TEAM>.* -> <TEAM>.<bundle_id>.
  - Real codesign with --entitlements when present.
- Asset dirs (add_asset_dir): recursive cp -R src/. into <bundle>/dest/.
  Missing src is treated as "nothing to do" so projects can register
  add_asset_dir("assets", "assets") unconditionally.

Parser:
- parseStmt() now accepts #import \"path\"; and #framework \"Name\"; as
  statement-position tokens. Needed for top-level
  inline if OS == .android { #import \"modules/platform/android.sx\"; }
  blocks (issue-0042 flatten pass surfaces them); chess's
  inline-if-with-#import was rejected at parse time before this fix.

Removals from src/target.zig:
- createBundle, embedFramework, extractEntitlements, buildInfoPlist,
  codesign (~210 lines). main.zig no longer calls createBundle after
  link(); the sx callback is the single entry point.

Tests / regression markers (all run under sx run host JIT):
- examples/115-post-link-callback.sx — callback registration round-trip.
- examples/116-fs-roundtrip.sx — fs.write_file -> fs.read_file -> exists.
- examples/117-process-roundtrip.sx — process.run + env + find_executable.
- examples/118-macos-bundle.sx — macOS .app via bundle_main callback.
- examples/119-interp-cast-ptr-cmp.sx — cast(T) val under interpreter.
- examples/120-interp-variadic-any.sx — variadic ..Any indexing in IR
  interpreter.
- examples/121-ios-sim-bundle.sx — iOS-sim cross-compile + .app with
  iOS-shaped Info.plist (added to tests/cross_compile.sh as the
  ios-sim tuple).
- examples/122-ios-device-bundle.sx — iOS device cross-compile +
  full codesign pipeline (provisioning embed + entitlements
  extraction + --entitlements codesign). Manually verified end-to-end:
  installed via xcrun devicectl device install app + launched
  successfully on iPhone 17 Pro.
- examples/123-inline-if-import-in-body.sx — locks in the parser fix.

zig build && zig build test && bash tests/run_examples.sh => 141 passed,
0 failed; bash tests/cross_compile.sh => 7 passed, 0 failed.
2026-05-22 19:03:31 +03:00

2996 lines
129 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
@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 [4 x i8] c"GPA\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
@fld.str.30 = private constant [12 x i8] c"alloc_count\00"
@field_names.31 = private constant [1 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.30, i64 11 }]
@str.32 = private unnamed_addr constant [3 x i8] c": \00", align 1
@str.33 = private unnamed_addr constant [11 x i8] c"ArenaChunk\00", align 1
@str.34 = private unnamed_addr constant [2 x i8] c"{\00", align 1
@str.35 = private unnamed_addr constant [2 x i8] c"}\00", align 1
@str.36 = private unnamed_addr constant [3 x i8] c", \00", align 1
@fld.str.37 = private constant [5 x i8] c"next\00"
@fld.str.38 = private constant [4 x i8] c"cap\00"
@field_names.39 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.37, i64 4 }, { ptr, i64 } { ptr @fld.str.38, i64 3 }]
@str.40 = private unnamed_addr constant [3 x i8] c": \00", align 1
@str.41 = private unnamed_addr constant [6 x i8] c"Arena\00", align 1
@str.42 = private unnamed_addr constant [2 x i8] c"{\00", align 1
@str.43 = private unnamed_addr constant [2 x i8] c"}\00", align 1
@str.44 = private unnamed_addr constant [3 x i8] c", \00", align 1
@fld.str.45 = private constant [6 x i8] c"first\00"
@fld.str.46 = private constant [10 x i8] c"end_index\00"
@fld.str.47 = private constant [7 x i8] c"parent\00"
@field_names.48 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.45, i64 5 }, { ptr, i64 } { ptr @fld.str.46, i64 9 }, { ptr, i64 } { ptr @fld.str.47, i64 6 }]
@str.49 = private unnamed_addr constant [3 x i8] c": \00", align 1
@str.50 = private unnamed_addr constant [9 x i8] c"BufAlloc\00", align 1
@str.51 = private unnamed_addr constant [2 x i8] c"{\00", align 1
@str.52 = private unnamed_addr constant [2 x i8] c"}\00", align 1
@str.53 = private unnamed_addr constant [3 x i8] c", \00", align 1
@fld.str.54 = private constant [4 x i8] c"buf\00"
@fld.str.55 = private constant [4 x i8] c"len\00"
@fld.str.56 = private constant [4 x i8] c"pos\00"
@field_names.57 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.54, i64 3 }, { ptr, i64 } { ptr @fld.str.55, i64 3 }, { ptr, i64 } { ptr @fld.str.56, i64 3 }]
@str.58 = private unnamed_addr constant [3 x i8] c": \00", align 1
@str.59 = private unnamed_addr constant [8 x i8] c"Context\00", align 1
@str.60 = private unnamed_addr constant [2 x i8] c"{\00", align 1
@str.61 = private unnamed_addr constant [2 x i8] c"}\00", align 1
@str.62 = private unnamed_addr constant [3 x i8] c", \00", align 1
@fld.str.63 = private constant [10 x i8] c"allocator\00"
@fld.str.64 = private constant [5 x i8] c"data\00"
@field_names.65 = private constant [2 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.63, i64 9 }, { ptr, i64 } { ptr @fld.str.64, i64 4 }]
@str.66 = private unnamed_addr constant [3 x i8] c": \00", align 1
@str.67 = private unnamed_addr constant [13 x i8] c"BuildOptions\00", align 1
@str.68 = private unnamed_addr constant [2 x i8] c"{\00", align 1
@str.69 = private unnamed_addr constant [2 x i8] c"}\00", align 1
@str.70 = private unnamed_addr constant [3 x i8] c", \00", align 1
@field_names.71 = private constant [0 x { ptr, i64 }] zeroinitializer
@str.72 = private unnamed_addr constant [3 x i8] c": \00", align 1
@str.73 = private unnamed_addr constant [7 x i8] c"Triple\00", align 1
@str.74 = private unnamed_addr constant [2 x i8] c"{\00", align 1
@str.75 = private unnamed_addr constant [2 x i8] c"}\00", align 1
@str.76 = private unnamed_addr constant [3 x i8] c", \00", align 1
@fld.str.77 = private constant [2 x i8] c"a\00"
@fld.str.78 = private constant [2 x i8] c"b\00"
@fld.str.79 = private constant [2 x i8] c"c\00"
@field_names.80 = private constant [3 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.77, i64 1 }, { ptr, i64 } { ptr @fld.str.78, i64 1 }, { ptr, i64 } { ptr @fld.str.79, i64 1 }]
@str.81 = private unnamed_addr constant [3 x i8] c": \00", align 1
@str.82 = private unnamed_addr constant [2 x i8] c".\00", align 1
@fld.str.83 = private constant [6 x i8] c"macos\00"
@fld.str.84 = private constant [6 x i8] c"linux\00"
@fld.str.85 = private constant [8 x i8] c"windows\00"
@fld.str.86 = private constant [5 x i8] c"wasm\00"
@fld.str.87 = private constant [4 x i8] c"ios\00"
@fld.str.88 = private constant [8 x i8] c"android\00"
@fld.str.89 = private constant [8 x i8] c"unknown\00"
@field_names.90 = private constant [7 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.83, i64 5 }, { ptr, i64 } { ptr @fld.str.84, i64 5 }, { ptr, i64 } { ptr @fld.str.85, i64 7 }, { ptr, i64 } { ptr @fld.str.86, i64 4 }, { ptr, i64 } { ptr @fld.str.87, i64 3 }, { ptr, i64 } { ptr @fld.str.88, i64 7 }, { ptr, i64 } { ptr @fld.str.89, i64 7 }]
@str.91 = private unnamed_addr constant [2 x i8] c"(\00", align 1
@str.92 = private unnamed_addr constant [2 x i8] c")\00", align 1
@str.93 = private unnamed_addr constant [2 x i8] c".\00", align 1
@fld.str.94 = private constant [8 x i8] c"aarch64\00"
@fld.str.95 = private constant [7 x i8] c"x86_64\00"
@fld.str.96 = private constant [7 x i8] c"wasm32\00"
@fld.str.97 = private constant [7 x i8] c"wasm64\00"
@fld.str.98 = private constant [8 x i8] c"unknown\00"
@field_names.99 = private constant [5 x { ptr, i64 }] [{ ptr, i64 } { ptr @fld.str.94, i64 7 }, { ptr, i64 } { ptr @fld.str.95, i64 6 }, { ptr, i64 } { ptr @fld.str.96, i64 6 }, { ptr, i64 } { ptr @fld.str.97, i64 6 }, { ptr, i64 } { ptr @fld.str.98, i64 7 }]
@str.100 = private unnamed_addr constant [2 x i8] c"(\00", align 1
@str.101 = private unnamed_addr constant [2 x i8] c")\00", align 1
@str.102 = private unnamed_addr constant [2 x i8] c"[\00", align 1
@str.103 = private unnamed_addr constant [2 x i8] c"]\00", align 1
@str.104 = private unnamed_addr constant [3 x i8] c", \00", align 1
@str.105 = private unnamed_addr constant [2 x i8] c"[\00", align 1
@str.106 = private unnamed_addr constant [2 x i8] c"]\00", align 1
@str.107 = private unnamed_addr constant [3 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
@str.110 = private unnamed_addr constant [3 x i8] c", \00", align 1
@str.111 = private unnamed_addr constant [2 x i8] c"[\00", align 1
@str.112 = private unnamed_addr constant [2 x i8] c"]\00", align 1
@str.113 = private unnamed_addr constant [3 x i8] c", \00", align 1
@str.114 = private unnamed_addr constant [5 x i8] c"null\00", align 1
@str.115 = private unnamed_addr constant [6 x i8] c"*void\00", align 1
@str.116 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1
@str.117 = private unnamed_addr constant [5 x i8] c"null\00", align 1
@str.118 = private unnamed_addr constant [5 x i8] c"*GPA\00", align 1
@str.119 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1
@str.120 = private unnamed_addr constant [5 x i8] c"null\00", align 1
@str.121 = private unnamed_addr constant [12 x i8] c"*ArenaChunk\00", align 1
@str.122 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1
@str.123 = private unnamed_addr constant [5 x i8] c"null\00", align 1
@str.124 = private unnamed_addr constant [7 x i8] c"*Arena\00", align 1
@str.125 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1
@str.126 = private unnamed_addr constant [5 x i8] c"null\00", align 1
@str.127 = private unnamed_addr constant [6 x i8] c"[*]u8\00", align 1
@str.128 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1
@str.129 = private unnamed_addr constant [5 x i8] c"null\00", align 1
@str.130 = private unnamed_addr constant [10 x i8] c"*BufAlloc\00", align 1
@str.131 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1
@str.132 = private unnamed_addr constant [5 x i8] c"null\00", align 1
@str.133 = private unnamed_addr constant [6 x i8] c"**GPA\00", align 1
@str.134 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1
@str.135 = private unnamed_addr constant [5 x i8] c"null\00", align 1
@str.136 = private unnamed_addr constant [5 x i8] c"*s64\00", align 1
@str.137 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1
@str.138 = private unnamed_addr constant [5 x i8] c"null\00", align 1
@str.139 = private unnamed_addr constant [7 x i8] c"**void\00", align 1
@str.140 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1
@str.141 = private unnamed_addr constant [5 x i8] c"null\00", align 1
@str.142 = private unnamed_addr constant [6 x i8] c"*bool\00", align 1
@str.143 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1
@str.144 = private unnamed_addr constant [5 x i8] c"null\00", align 1
@str.145 = private unnamed_addr constant [8 x i8] c"*[1]Any\00", align 1
@str.146 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1
@str.147 = private unnamed_addr constant [5 x i8] c"null\00", align 1
@str.148 = private unnamed_addr constant [5 x i8] c"*Any\00", align 1
@str.149 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1
@str.150 = private unnamed_addr constant [5 x i8] c"null\00", align 1
@str.151 = private unnamed_addr constant [7 x i8] c"*[]Any\00", align 1
@str.152 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1
@str.153 = private unnamed_addr constant [5 x i8] c"null\00", align 1
@str.154 = private unnamed_addr constant [8 x i8] c"*string\00", align 1
@str.155 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1
@str.156 = private unnamed_addr constant [5 x i8] c"null\00", align 1
@str.157 = private unnamed_addr constant [4 x i8] c"*u8\00", align 1
@str.158 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1
@str.159 = private unnamed_addr constant [5 x i8] c"null\00", align 1
@str.160 = private unnamed_addr constant [8 x i8] c"*Triple\00", align 1
@str.161 = private unnamed_addr constant [4 x i8] c"@0x\00", align 1
@str.162 = private unnamed_addr constant [5 x i8] c"null\00", align 1
@str.163 = private unnamed_addr constant [8 x i8] c"*[3]Any\00", align 1
@str.164 = 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 ptr @memcpy(ptr, ptr, i64)
declare ptr @memset(ptr, i32, i64)
declare void @free(ptr)
; Function Attrs: nounwind
declare void @GPA.create(ptr sret({ ptr, ptr, ptr }), ptr) #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
%malloc = call ptr @malloc(i64 %loadN)
ret ptr %malloc
}
; 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 void @Arena.create(ptr sret({ ptr, ptr, ptr }), ptr, 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 void @BufAlloc.create(ptr sret({ ptr, ptr, ptr }), ptr, 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
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
%1 = 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.data50 = extractvalue { ptr, i64 } %loadN, 0
%igp.ptr51 = getelementptr i8, ptr %igp.data50, i64 %loadN
store i8 46, ptr %igp.ptr51, 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.data59 = extractvalue { ptr, i64 } %loadN, 0
%igp.ptr60 = getelementptr i8, ptr %igp.data59, i64 %loadN
%loadN = load i64, ptr %allocaN, align 8
%2 = call ptr @memset(ptr %igp.ptr60, 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.data67 = extractvalue { ptr, i64 } %loadN, 0
%igp.ptr68 = getelementptr i8, ptr %igp.data67, i64 %loadN
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%dptrN = extractvalue { ptr, i64 } %loadN, 0
%loadN = load i64, ptr %allocaN, align 8
%3 = call ptr @memcpy(ptr %igp.ptr68, 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.158
while.hdr.158: ; preds = %if.merge.163, %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.159, label %while.exit.160
while.body.159: ; preds = %while.hdr.158
%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.161, label %if.else.162
while.exit.160: ; preds = %while.hdr.158
ret void
if.then.161: ; preds = %while.body.159
%loadN = load i64, ptr %allocaN, align 8
%addN = add i64 %loadN, 48
br label %if.merge.163
if.else.162: ; preds = %while.body.159
%loadN = load i64, ptr %allocaN, align 8
%sub = sub i64 %loadN, 10
%addN = add i64 %sub, 97
br label %if.merge.163
if.merge.163: ; preds = %if.else.162, %if.then.161
%bp = phi i64 [ %addN, %if.then.161 ], [ %addN, %if.else.162 ]
%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.158
}
; 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.148, label %if.merge.149
if.then.148: ; preds = %entry
ret { ptr, i64 } { ptr @str.3, i64 1 }
if.merge.149: ; 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.150, label %if.merge.151
if.then.150: ; preds = %if.merge.149
%loadN = load i64, ptr %allocaN, align 8
%add = add i64 %loadN, 65536
store i64 %add, ptr %allocaN, align 8
br label %if.merge.151
if.merge.151: ; preds = %if.then.150, %if.merge.149
%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.152, label %if.merge.153
if.then.152: ; preds = %if.merge.151
%loadN = load i64, ptr %allocaN, align 8
%addN = add i64 %loadN, 65536
store i64 %addN, ptr %allocaN, align 8
br label %if.merge.153
if.merge.153: ; preds = %if.then.152, %if.merge.151
%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.154, label %if.merge.155
if.then.154: ; preds = %if.merge.153
%loadN = load i64, ptr %allocaN, align 8
%addN = add i64 %loadN, 65536
store i64 %addN, ptr %allocaN, align 8
br label %if.merge.155
if.merge.155: ; preds = %if.then.154, %if.merge.153
%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.156, label %if.merge.157
if.then.156: ; preds = %if.merge.155
%loadN = load i64, ptr %allocaN, align 8
%addN = add i64 %loadN, 65536
store i64 %addN, ptr %allocaN, align 8
br label %if.merge.157
if.merge.157: ; preds = %if.then.156, %if.merge.155
%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.164
while.hdr.164: ; preds = %if.merge.168, %if.merge.157
%loadN = load i64, ptr %allocaN, align 8
%icmpN = icmp slt i64 %loadN, 15
br i1 %icmpN, label %while.body.165, label %while.exit.166
while.body.165: ; preds = %while.hdr.164
%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.167, label %if.merge.168
while.exit.166: ; preds = %if.then.167, %while.hdr.164
%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.167: ; preds = %while.body.165
br label %while.exit.166
if.merge.168: ; preds = %while.body.165
%loadN = load i64, ptr %allocaN, align 8
%addN = add i64 %loadN, 1
store i64 %addN, ptr %allocaN, align 8
br label %while.hdr.164
}
; 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
%2 = 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
%3 = 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
%3 = 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 26, label %match.arm.6
i64 28, label %match.arm.6
i64 32, label %match.arm.6
i64 34, label %match.arm.6
i64 30, label %match.arm.7
i64 31, label %match.arm.7
i64 40, label %match.arm.9
i64 47, label %match.arm.9
i64 29, label %match.arm.10
i64 39, 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 25, label %match.arm.11
i64 27, label %match.arm.11
i64 35, label %match.arm.11
i64 36, label %match.arm.11
i64 37, label %match.arm.11
i64 38, label %match.arm.11
i64 41, label %match.arm.11
i64 42, label %match.arm.11
i64 43, label %match.arm.11
i64 44, label %match.arm.11
i64 45, label %match.arm.11
i64 46, label %match.arm.11
i64 48, label %match.arm.11
i64 13, label %match.arm.12
]
match.merge.0: ; preds = %dispatch.merge.126, %dispatch.merge.112, %dispatch.merge.98, %dispatch.merge.90, %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
%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 26, label %dispatch.case.46
i64 28, label %dispatch.case.47
i64 32, label %dispatch.case.48
i64 34, label %dispatch.case.49
]
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.91 [
i64 30, label %dispatch.case.92
i64 31, label %dispatch.case.93
]
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.99 [
i64 40, label %dispatch.case.100
i64 47, label %dispatch.case.101
]
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.113 [
i64 29, label %dispatch.case.114
i64 39, label %dispatch.case.115
]
match.arm.11: ; preds = %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.127 [
i64 17, label %dispatch.case.128
i64 20, label %dispatch.case.129
i64 22, label %dispatch.case.130
i64 24, label %dispatch.case.131
i64 25, label %dispatch.case.132
i64 27, label %dispatch.case.133
i64 35, label %dispatch.case.134
i64 36, label %dispatch.case.135
i64 37, label %dispatch.case.136
i64 38, label %dispatch.case.137
i64 41, label %dispatch.case.138
i64 42, label %dispatch.case.139
i64 43, label %dispatch.case.140
i64 44, label %dispatch.case.141
i64 45, label %dispatch.case.142
i64 46, label %dispatch.case.143
i64 48, label %dispatch.case.144
]
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.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 { i64 }, ptr %ua.ptr47, align 8
%callN = call { ptr, i64 } @struct_to_string__GPA({ i64 } %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 { ptr, i64 }, ptr %ua.ptr51, align 8
%callN = call { ptr, i64 } @struct_to_string__ArenaChunk({ ptr, 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, ptr, ptr } }, ptr %ua.ptr55, align 8
%callN = call { ptr, i64 } @struct_to_string__Arena({ ptr, i64, { ptr, ptr, ptr } } %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, i64 }, ptr %ua.ptr59, align 8
%callN = call { ptr, i64 } @struct_to_string__BufAlloc({ ptr, i64, i64 } %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, ptr, ptr }, ptr }, ptr %ua.ptr63, align 8
%callN = call { ptr, i64 } @struct_to_string__Context({ { ptr, ptr, ptr }, ptr } %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 %ua.ptr67, align 1
%callN = call { ptr, i64 } @struct_to_string__BuildOptions({} %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 { i64, i64, i64 }, ptr %ua.ptr71, align 8
%callN = call { ptr, i64 } @struct_to_string__Triple({ i64, i64, i64 } %ua.load72)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %dispatch.merge.40
dispatch.merge.90: ; preds = %dispatch.case.93, %dispatch.case.92, %dispatch.default.91
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
store { ptr, i64 } %loadN, ptr %allocaN, align 8
br label %match.merge.0
dispatch.default.91: ; preds = %match.arm.7
store { ptr, i64 } { ptr @str.7, i64 0 }, ptr %allocaN, align 8
br label %dispatch.merge.90
dispatch.case.92: ; preds = %match.arm.7
%ua.raw75 = extractvalue { i64, i64 } %loadN, 1
%callN = call { ptr, i64 } @enum_to_string__OperatingSystem(i64 %ua.raw75)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %dispatch.merge.90
dispatch.case.93: ; preds = %match.arm.7
%ua.raw77 = extractvalue { i64, i64 } %loadN, 1
%callN = call { ptr, i64 } @enum_to_string__Architecture(i64 %ua.raw77)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %dispatch.merge.90
dispatch.merge.98: ; preds = %dispatch.case.101, %dispatch.case.100, %dispatch.default.99
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
store { ptr, i64 } %loadN, ptr %allocaN, align 8
br label %match.merge.0
dispatch.default.99: ; preds = %match.arm.9
store { ptr, i64 } { ptr @str.8, i64 0 }, ptr %allocaN, align 8
br label %dispatch.merge.98
dispatch.case.100: ; preds = %match.arm.9
%ua.raw80 = extractvalue { i64, i64 } %loadN, 1
%ua.ptr81 = inttoptr i64 %ua.raw80 to ptr
%ua.load82 = load [1 x { i64, i64 }], ptr %ua.ptr81, align 8
%callN = call { ptr, i64 } @array_to_string__AR_1_Any([1 x { i64, i64 }] %ua.load82)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %dispatch.merge.98
dispatch.case.101: ; preds = %match.arm.9
%ua.raw84 = extractvalue { i64, i64 } %loadN, 1
%ua.ptr85 = inttoptr i64 %ua.raw84 to ptr
%ua.load86 = load [3 x { i64, i64 }], ptr %ua.ptr85, align 8
%callN = call { ptr, i64 } @array_to_string__AR_3_Any([3 x { i64, i64 }] %ua.load86)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %dispatch.merge.98
dispatch.merge.112: ; preds = %dispatch.case.115, %dispatch.case.114, %dispatch.default.113
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
store { ptr, i64 } %loadN, ptr %allocaN, align 8
br label %match.merge.0
dispatch.default.113: ; preds = %match.arm.10
store { ptr, i64 } { ptr @str.9, i64 0 }, ptr %allocaN, align 8
br label %dispatch.merge.112
dispatch.case.114: ; preds = %match.arm.10
%ua.raw89 = extractvalue { i64, i64 } %loadN, 1
%ua.ptr90 = inttoptr i64 %ua.raw89 to ptr
%ua.load91 = load { ptr, i64 }, ptr %ua.ptr90, align 8
%callN = call { ptr, i64 } @slice_to_string__string({ ptr, i64 } %ua.load91)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %dispatch.merge.112
dispatch.case.115: ; preds = %match.arm.10
%ua.raw93 = extractvalue { i64, i64 } %loadN, 1
%ua.ptr94 = inttoptr i64 %ua.raw93 to ptr
%ua.load95 = load { ptr, i64 }, ptr %ua.ptr94, align 8
%callN = call { ptr, i64 } @slice_to_string__Any({ ptr, i64 } %ua.load95)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %dispatch.merge.112
dispatch.merge.126: ; preds = %dispatch.case.144, %dispatch.case.143, %dispatch.case.142, %dispatch.case.141, %dispatch.case.140, %dispatch.case.139, %dispatch.case.138, %dispatch.case.137, %dispatch.case.136, %dispatch.case.135, %dispatch.case.134, %dispatch.case.133, %dispatch.case.132, %dispatch.case.131, %dispatch.case.130, %dispatch.case.129, %dispatch.case.128, %dispatch.default.127
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
store { ptr, i64 } %loadN, ptr %allocaN, align 8
br label %match.merge.0
dispatch.default.127: ; preds = %match.arm.11
store { ptr, i64 } { ptr @str.10, i64 0 }, ptr %allocaN, align 8
br label %dispatch.merge.126
dispatch.case.128: ; preds = %match.arm.11
%ua.raw98 = extractvalue { i64, i64 } %loadN, 1
%iNp = inttoptr i64 %ua.raw98 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.126
dispatch.case.129: ; preds = %match.arm.11
%ua.raw100 = extractvalue { i64, i64 } %loadN, 1
%iNp101 = inttoptr i64 %ua.raw100 to ptr
%callN = call { ptr, i64 } @pointer_to_string__ptr_GPA(ptr %iNp101)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %dispatch.merge.126
dispatch.case.130: ; preds = %match.arm.11
%ua.raw103 = extractvalue { i64, i64 } %loadN, 1
%iNp104 = inttoptr i64 %ua.raw103 to ptr
%callN = call { ptr, i64 } @pointer_to_string__ptr_ArenaChunk(ptr %iNp104)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %dispatch.merge.126
dispatch.case.131: ; preds = %match.arm.11
%ua.raw106 = extractvalue { i64, i64 } %loadN, 1
%iNp107 = inttoptr i64 %ua.raw106 to ptr
%callN = call { ptr, i64 } @pointer_to_string__ptr_Arena(ptr %iNp107)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %dispatch.merge.126
dispatch.case.132: ; preds = %match.arm.11
%ua.raw109 = extractvalue { i64, i64 } %loadN, 1
%iNp110 = inttoptr i64 %ua.raw109 to ptr
%callN = call { ptr, i64 } @pointer_to_string__mptr_u8(ptr %iNp110)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %dispatch.merge.126
dispatch.case.133: ; preds = %match.arm.11
%ua.raw112 = extractvalue { i64, i64 } %loadN, 1
%iNp113 = inttoptr i64 %ua.raw112 to ptr
%callN = call { ptr, i64 } @pointer_to_string__ptr_BufAlloc(ptr %iNp113)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %dispatch.merge.126
dispatch.case.134: ; preds = %match.arm.11
%ua.raw115 = extractvalue { i64, i64 } %loadN, 1
%iNp116 = inttoptr i64 %ua.raw115 to ptr
%callN = call { ptr, i64 } @pointer_to_string__ptr_ptr_GPA(ptr %iNp116)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %dispatch.merge.126
dispatch.case.135: ; preds = %match.arm.11
%ua.raw118 = extractvalue { i64, i64 } %loadN, 1
%iNp119 = inttoptr i64 %ua.raw118 to ptr
%callN = call { ptr, i64 } @pointer_to_string__ptr_s64(ptr %iNp119)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %dispatch.merge.126
dispatch.case.136: ; preds = %match.arm.11
%ua.raw121 = extractvalue { i64, i64 } %loadN, 1
%iNp122 = inttoptr i64 %ua.raw121 to ptr
%callN = call { ptr, i64 } @pointer_to_string__ptr_ptr_void(ptr %iNp122)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %dispatch.merge.126
dispatch.case.137: ; preds = %match.arm.11
%ua.raw124 = extractvalue { i64, i64 } %loadN, 1
%iNp125 = inttoptr i64 %ua.raw124 to ptr
%callN = call { ptr, i64 } @pointer_to_string__ptr_bool(ptr %iNp125)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %dispatch.merge.126
dispatch.case.138: ; preds = %match.arm.11
%ua.raw127 = extractvalue { i64, i64 } %loadN, 1
%iNp128 = inttoptr i64 %ua.raw127 to ptr
%callN = call { ptr, i64 } @pointer_to_string__ptr_AR_1_Any(ptr %iNp128)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %dispatch.merge.126
dispatch.case.139: ; preds = %match.arm.11
%ua.raw130 = extractvalue { i64, i64 } %loadN, 1
%iNp131 = inttoptr i64 %ua.raw130 to ptr
%callN = call { ptr, i64 } @pointer_to_string__ptr_Any(ptr %iNp131)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %dispatch.merge.126
dispatch.case.140: ; preds = %match.arm.11
%ua.raw133 = extractvalue { i64, i64 } %loadN, 1
%iNp134 = inttoptr i64 %ua.raw133 to ptr
%callN = call { ptr, i64 } @pointer_to_string__ptr_SL_Any(ptr %iNp134)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %dispatch.merge.126
dispatch.case.141: ; preds = %match.arm.11
%ua.raw136 = extractvalue { i64, i64 } %loadN, 1
%iNp137 = inttoptr i64 %ua.raw136 to ptr
%callN = call { ptr, i64 } @pointer_to_string__ptr_string(ptr %iNp137)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %dispatch.merge.126
dispatch.case.142: ; preds = %match.arm.11
%ua.raw139 = extractvalue { i64, i64 } %loadN, 1
%iNp140 = inttoptr i64 %ua.raw139 to ptr
%callN = call { ptr, i64 } @pointer_to_string__ptr_u8(ptr %iNp140)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %dispatch.merge.126
dispatch.case.143: ; preds = %match.arm.11
%ua.raw142 = extractvalue { i64, i64 } %loadN, 1
%iNp143 = inttoptr i64 %ua.raw142 to ptr
%callN = call { ptr, i64 } @pointer_to_string__ptr_Triple(ptr %iNp143)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %dispatch.merge.126
dispatch.case.144: ; preds = %match.arm.11
%ua.raw145 = extractvalue { i64, i64 } %loadN, 1
%iNp146 = inttoptr i64 %ua.raw145 to ptr
%callN = call { ptr, i64 } @pointer_to_string__ptr_AR_3_Any(ptr %iNp146)
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %dispatch.merge.126
}
; 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 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 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_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.50
while.hdr.50: ; preds = %fv.merge, %entry
%load = load i64, ptr %allocaN, align 8
%icmp = icmp slt i64 %load, 3
br i1 %icmp, label %while.body.51, label %while.exit.52
while.body.51: ; preds = %while.hdr.50
%loadN = load i64, ptr %allocaN, align 8
%icmpN = icmp sgt i64 %loadN, 0
br i1 %icmpN, label %if.then.53, label %if.merge.54
while.exit.52: ; preds = %while.hdr.50
%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.53: ; preds = %while.body.51
%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.54
if.merge.54: ; preds = %if.then.53, %while.body.51
%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.50
fv.default: ; preds = %if.merge.54
br label %fv.merge
fv.case: ; preds = %if.merge.54
%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.54
%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.54
%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__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.26, i64 3 }, { 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.55
while.hdr.55: ; preds = %fv.merge, %entry
%load = load i64, ptr %allocaN, align 8
%icmp = icmp slt i64 %load, 1
br i1 %icmp, label %while.body.56, label %while.exit.57
while.body.56: ; preds = %while.hdr.55
%loadN = load i64, ptr %allocaN, align 8
%icmpN = icmp sgt i64 %loadN, 0
br i1 %icmpN, label %if.then.58, label %if.merge.59
while.exit.57: ; preds = %while.hdr.55
%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.58: ; preds = %while.body.56
%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.59
if.merge.59: ; preds = %if.then.58, %while.body.56
%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.31, 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.32, 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.55
fv.default: ; preds = %if.merge.59
br label %fv.merge
fv.case: ; preds = %if.merge.59
%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.33, i64 10 }, { ptr, i64 } { ptr @str.34, 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.60
while.hdr.60: ; preds = %fv.merge, %entry
%load = load i64, ptr %allocaN, align 8
%icmp = icmp slt i64 %load, 2
br i1 %icmp, label %while.body.61, label %while.exit.62
while.body.61: ; preds = %while.hdr.60
%loadN = load i64, ptr %allocaN, align 8
%icmpN = icmp sgt i64 %loadN, 0
br i1 %icmpN, label %if.then.63, label %if.merge.64
while.exit.62: ; preds = %while.hdr.60
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%callN = call { ptr, i64 } @concat({ ptr, i64 } %loadN, { ptr, i64 } { ptr @str.35, i64 1 })
ret { ptr, i64 } %callN
if.then.63: ; preds = %while.body.61
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%callN = call { ptr, i64 } @concat({ ptr, i64 } %loadN, { ptr, i64 } { ptr @str.36, i64 2 })
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %if.merge.64
if.merge.64: ; preds = %if.then.63, %while.body.61
%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.39, 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.40, 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.60
fv.default: ; preds = %if.merge.64
br label %fv.merge
fv.case: ; preds = %if.merge.64
%fv.field = extractvalue { ptr, i64 } %loadN, 0
%pNi = ptrtoint ptr %fv.field to i64
%fv.val = insertvalue { i64, i64 } { i64 22, i64 undef }, i64 %pNi, 1
br label %fv.merge
fv.case17: ; preds = %if.merge.64
%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.41, i64 5 }, { ptr, i64 } { ptr @str.42, 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.65
while.hdr.65: ; preds = %fv.merge, %entry
%load = load i64, ptr %allocaN, align 8
%icmp = icmp slt i64 %load, 3
br i1 %icmp, label %while.body.66, label %while.exit.67
while.body.66: ; preds = %while.hdr.65
%loadN = load i64, ptr %allocaN, align 8
%icmpN = icmp sgt i64 %loadN, 0
br i1 %icmpN, label %if.then.68, label %if.merge.69
while.exit.67: ; preds = %while.hdr.65
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%callN = call { ptr, i64 } @concat({ ptr, i64 } %loadN, { ptr, i64 } { ptr @str.43, i64 1 })
ret { ptr, i64 } %callN
if.then.68: ; preds = %while.body.66
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%callN = call { ptr, i64 } @concat({ ptr, i64 } %loadN, { ptr, i64 } { ptr @str.44, i64 2 })
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %if.merge.69
if.merge.69: ; preds = %if.then.68, %while.body.66
%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.48, 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.49, 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.65
fv.default: ; preds = %if.merge.69
br label %fv.merge
fv.case: ; preds = %if.merge.69
%fv.field = extractvalue { ptr, i64, { ptr, ptr, ptr } } %loadN, 0
%pNi = ptrtoint ptr %fv.field to i64
%fv.val = insertvalue { i64, i64 } { i64 22, i64 undef }, i64 %pNi, 1
br label %fv.merge
fv.case17: ; preds = %if.merge.69
%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.69
%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.50, i64 8 }, { ptr, i64 } { ptr @str.51, 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.70
while.hdr.70: ; preds = %fv.merge, %entry
%load = load i64, ptr %allocaN, align 8
%icmp = icmp slt i64 %load, 3
br i1 %icmp, label %while.body.71, label %while.exit.72
while.body.71: ; preds = %while.hdr.70
%loadN = load i64, ptr %allocaN, align 8
%icmpN = icmp sgt i64 %loadN, 0
br i1 %icmpN, label %if.then.73, label %if.merge.74
while.exit.72: ; preds = %while.hdr.70
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%callN = call { ptr, i64 } @concat({ ptr, i64 } %loadN, { ptr, i64 } { ptr @str.52, i64 1 })
ret { ptr, i64 } %callN
if.then.73: ; preds = %while.body.71
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%callN = call { ptr, i64 } @concat({ ptr, i64 } %loadN, { ptr, i64 } { ptr @str.53, i64 2 })
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %if.merge.74
if.merge.74: ; preds = %if.then.73, %while.body.71
%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.57, 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.58, 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.70
fv.default: ; preds = %if.merge.74
br label %fv.merge
fv.case: ; preds = %if.merge.74
%fv.field = extractvalue { ptr, i64, i64 } %loadN, 0
%pNi = ptrtoint ptr %fv.field to i64
%fv.val = insertvalue { i64, i64 } { i64 25, i64 undef }, i64 %pNi, 1
br label %fv.merge
fv.case17: ; preds = %if.merge.74
%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.74
%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__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.59, i64 7 }, { ptr, i64 } { ptr @str.60, 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.75
while.hdr.75: ; preds = %fv.merge, %entry
%load = load i64, ptr %allocaN, align 8
%icmp = icmp slt i64 %load, 2
br i1 %icmp, label %while.body.76, label %while.exit.77
while.body.76: ; preds = %while.hdr.75
%loadN = load i64, ptr %allocaN, align 8
%icmpN = icmp sgt i64 %loadN, 0
br i1 %icmpN, label %if.then.78, label %if.merge.79
while.exit.77: ; preds = %while.hdr.75
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%callN = call { ptr, i64 } @concat({ ptr, i64 } %loadN, { ptr, i64 } { ptr @str.61, i64 1 })
ret { ptr, i64 } %callN
if.then.78: ; preds = %while.body.76
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%callN = call { ptr, i64 } @concat({ ptr, i64 } %loadN, { ptr, i64 } { ptr @str.62, i64 2 })
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %if.merge.79
if.merge.79: ; preds = %if.then.78, %while.body.76
%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.65, 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.66, 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.75
fv.default: ; preds = %if.merge.79
br label %fv.merge
fv.case: ; preds = %if.merge.79
%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.79
%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.67, i64 12 }, { ptr, i64 } { ptr @str.68, 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.80
while.hdr.80: ; preds = %if.merge.84, %entry
%load = load i64, ptr %allocaN, align 8
%icmp = icmp slt i64 %load, 0
br i1 %icmp, label %while.body.81, label %while.exit.82
while.body.81: ; preds = %while.hdr.80
%loadN = load i64, ptr %allocaN, align 8
%icmpN = icmp sgt i64 %loadN, 0
br i1 %icmpN, label %if.then.83, label %if.merge.84
while.exit.82: ; preds = %while.hdr.80
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%callN = call { ptr, i64 } @concat({ ptr, i64 } %loadN, { ptr, i64 } { ptr @str.69, i64 1 })
ret { ptr, i64 } %callN
if.then.83: ; preds = %while.body.81
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%callN = call { ptr, i64 } @concat({ ptr, i64 } %loadN, { ptr, i64 } { ptr @str.70, i64 2 })
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %if.merge.84
if.merge.84: ; preds = %if.then.83, %while.body.81
%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.71, 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.72, 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.80
}
; 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.73, i64 6 }, { ptr, i64 } { ptr @str.74, 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.85
while.hdr.85: ; preds = %fv.merge, %entry
%load = load i64, ptr %allocaN, align 8
%icmp = icmp slt i64 %load, 3
br i1 %icmp, label %while.body.86, label %while.exit.87
while.body.86: ; preds = %while.hdr.85
%loadN = load i64, ptr %allocaN, align 8
%icmpN = icmp sgt i64 %loadN, 0
br i1 %icmpN, label %if.then.88, label %if.merge.89
while.exit.87: ; preds = %while.hdr.85
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%callN = call { ptr, i64 } @concat({ ptr, i64 } %loadN, { ptr, i64 } { ptr @str.75, i64 1 })
ret { ptr, i64 } %callN
if.then.88: ; preds = %while.body.86
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%callN = call { ptr, i64 } @concat({ ptr, i64 } %loadN, { ptr, i64 } { ptr @str.76, i64 2 })
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %if.merge.89
if.merge.89: ; preds = %if.then.88, %while.body.86
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%loadN = load i64, ptr %allocaN, align 8
%fn.gep = getelementptr inbounds [3 x { ptr, i64 }], ptr @field_names.80, i64 0, i64 %loadN
%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.81, 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.85
fv.default: ; preds = %if.merge.89
br label %fv.merge
fv.case: ; preds = %if.merge.89
%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.89
%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.89
%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.90, i64 0, i64 %loadN
%fn.load = load { ptr, i64 }, ptr %fn.gep, align 8
%call = call { ptr, i64 } @concat({ ptr, i64 } { ptr @str.82, 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.94, label %if.merge.95
if.then.94: ; 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.92, i64 1 })
%callN = call { ptr, i64 } @concat({ ptr, i64 } { ptr @str.91, 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.95
if.merge.95: ; preds = %if.then.94, %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.99, i64 0, i64 %loadN
%fn.load = load { ptr, i64 }, ptr %fn.gep, align 8
%call = call { ptr, i64 } @concat({ ptr, i64 } { ptr @str.93, 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.96, label %if.merge.97
if.then.96: ; 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.101, i64 1 })
%callN = call { ptr, i64 } @concat({ ptr, i64 } { ptr @str.100, 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.97
if.merge.97: ; preds = %if.then.96, %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.102, i64 1 }, ptr %allocaN, align 8
%allocaN = alloca i64, align 8
store i64 0, ptr %allocaN, align 8
br label %while.hdr.102
while.hdr.102: ; preds = %if.merge.106, %entry
%load = load i64, ptr %allocaN, align 8
%icmp = icmp slt i64 %load, 1
br i1 %icmp, label %while.body.103, label %while.exit.104
while.body.103: ; preds = %while.hdr.102
%loadN = load i64, ptr %allocaN, align 8
%icmpN = icmp sgt i64 %loadN, 0
br i1 %icmpN, label %if.then.105, label %if.merge.106
while.exit.104: ; preds = %while.hdr.102
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%call = call { ptr, i64 } @concat({ ptr, i64 } %loadN, { ptr, i64 } { ptr @str.103, i64 1 })
ret { ptr, i64 } %call
if.then.105: ; preds = %while.body.103
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%callN = call { ptr, i64 } @concat({ ptr, i64 } %loadN, { ptr, i64 } { ptr @str.104, i64 2 })
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %if.merge.106
if.merge.106: ; preds = %if.then.105, %while.body.103
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%loadN = load [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.102
}
; 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.105, i64 1 }, ptr %allocaN, align 8
%allocaN = alloca i64, align 8
store i64 0, ptr %allocaN, align 8
br label %while.hdr.107
while.hdr.107: ; preds = %if.merge.111, %entry
%load = load i64, ptr %allocaN, align 8
%icmp = icmp slt i64 %load, 3
br i1 %icmp, label %while.body.108, label %while.exit.109
while.body.108: ; preds = %while.hdr.107
%loadN = load i64, ptr %allocaN, align 8
%icmpN = icmp sgt i64 %loadN, 0
br i1 %icmpN, label %if.then.110, label %if.merge.111
while.exit.109: ; preds = %while.hdr.107
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%call = call { ptr, i64 } @concat({ ptr, i64 } %loadN, { ptr, i64 } { ptr @str.106, i64 1 })
ret { ptr, i64 } %call
if.then.110: ; preds = %while.body.108
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%callN = call { ptr, i64 } @concat({ ptr, i64 } %loadN, { ptr, i64 } { ptr @str.107, i64 2 })
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %if.merge.111
if.merge.111: ; preds = %if.then.110, %while.body.108
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%loadN = load [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.107
}
; 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.108, i64 1 }, ptr %allocaN, align 8
%allocaN = alloca i64, align 8
store i64 0, ptr %allocaN, align 8
br label %while.hdr.116
while.hdr.116: ; preds = %if.merge.120, %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.117, label %while.exit.118
while.body.117: ; preds = %while.hdr.116
%loadN = load i64, ptr %allocaN, align 8
%icmpN = icmp sgt i64 %loadN, 0
br i1 %icmpN, label %if.then.119, label %if.merge.120
while.exit.118: ; preds = %while.hdr.116
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%call = call { ptr, i64 } @concat({ ptr, i64 } %loadN, { ptr, i64 } { ptr @str.109, i64 1 })
ret { ptr, i64 } %call
if.then.119: ; preds = %while.body.117
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%callN = call { ptr, i64 } @concat({ ptr, i64 } %loadN, { ptr, i64 } { ptr @str.110, i64 2 })
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %if.merge.120
if.merge.120: ; preds = %if.then.119, %while.body.117
%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.116
}
; 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.111, i64 1 }, ptr %allocaN, align 8
%allocaN = alloca i64, align 8
store i64 0, ptr %allocaN, align 8
br label %while.hdr.121
while.hdr.121: ; preds = %if.merge.125, %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.122, label %while.exit.123
while.body.122: ; preds = %while.hdr.121
%loadN = load i64, ptr %allocaN, align 8
%icmpN = icmp sgt i64 %loadN, 0
br i1 %icmpN, label %if.then.124, label %if.merge.125
while.exit.123: ; preds = %while.hdr.121
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%call = call { ptr, i64 } @concat({ ptr, i64 } %loadN, { ptr, i64 } { ptr @str.112, i64 1 })
ret { ptr, i64 } %call
if.then.124: ; preds = %while.body.122
%loadN = load { ptr, i64 }, ptr %allocaN, align 8
%callN = call { ptr, i64 } @concat({ ptr, i64 } %loadN, { ptr, i64 } { ptr @str.113, i64 2 })
store { ptr, i64 } %callN, ptr %allocaN, align 8
br label %if.merge.125
if.merge.125: ; preds = %if.then.124, %while.body.122
%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.121
}
; 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.145, label %if.else.146
if.then.145: ; preds = %entry
br label %if.merge.147
if.else.146: ; 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.116, i64 3 }, { ptr, i64 } %call)
%callN = call { ptr, i64 } @concat({ ptr, i64 } { ptr @str.115, i64 5 }, { ptr, i64 } %callN)
br label %if.merge.147
if.merge.147: ; preds = %if.else.146, %if.then.145
%bp = phi { ptr, i64 } [ { ptr @str.114, i64 4 }, %if.then.145 ], [ %callN, %if.else.146 ]
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.169, label %if.else.170
if.then.169: ; preds = %entry
br label %if.merge.171
if.else.170: ; 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.119, i64 3 }, { ptr, i64 } %call)
%callN = call { ptr, i64 } @concat({ ptr, i64 } { ptr @str.118, i64 4 }, { ptr, i64 } %callN)
br label %if.merge.171
if.merge.171: ; preds = %if.else.170, %if.then.169
%bp = phi { ptr, i64 } [ { ptr @str.117, i64 4 }, %if.then.169 ], [ %callN, %if.else.170 ]
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.172, label %if.else.173
if.then.172: ; preds = %entry
br label %if.merge.174
if.else.173: ; 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.122, i64 3 }, { ptr, i64 } %call)
%callN = call { ptr, i64 } @concat({ ptr, i64 } { ptr @str.121, i64 11 }, { ptr, i64 } %callN)
br label %if.merge.174
if.merge.174: ; preds = %if.else.173, %if.then.172
%bp = phi { ptr, i64 } [ { ptr @str.120, i64 4 }, %if.then.172 ], [ %callN, %if.else.173 ]
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.175, label %if.else.176
if.then.175: ; preds = %entry
br label %if.merge.177
if.else.176: ; 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.125, i64 3 }, { ptr, i64 } %call)
%callN = call { ptr, i64 } @concat({ ptr, i64 } { ptr @str.124, i64 6 }, { ptr, i64 } %callN)
br label %if.merge.177
if.merge.177: ; preds = %if.else.176, %if.then.175
%bp = phi { ptr, i64 } [ { ptr @str.123, i64 4 }, %if.then.175 ], [ %callN, %if.else.176 ]
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.178, label %if.else.179
if.then.178: ; preds = %entry
br label %if.merge.180
if.else.179: ; 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.128, i64 3 }, { ptr, i64 } %call)
%callN = call { ptr, i64 } @concat({ ptr, i64 } { ptr @str.127, i64 5 }, { ptr, i64 } %callN)
br label %if.merge.180
if.merge.180: ; preds = %if.else.179, %if.then.178
%bp = phi { ptr, i64 } [ { ptr @str.126, i64 4 }, %if.then.178 ], [ %callN, %if.else.179 ]
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.181, label %if.else.182
if.then.181: ; preds = %entry
br label %if.merge.183
if.else.182: ; 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.131, i64 3 }, { ptr, i64 } %call)
%callN = call { ptr, i64 } @concat({ ptr, i64 } { ptr @str.130, i64 9 }, { ptr, i64 } %callN)
br label %if.merge.183
if.merge.183: ; preds = %if.else.182, %if.then.181
%bp = phi { ptr, i64 } [ { ptr @str.129, i64 4 }, %if.then.181 ], [ %callN, %if.else.182 ]
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.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.134, i64 3 }, { ptr, i64 } %call)
%callN = call { ptr, i64 } @concat({ ptr, i64 } { ptr @str.133, i64 5 }, { ptr, i64 } %callN)
br label %if.merge.186
if.merge.186: ; preds = %if.else.185, %if.then.184
%bp = phi { ptr, i64 } [ { ptr @str.132, i64 4 }, %if.then.184 ], [ %callN, %if.else.185 ]
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.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.137, i64 3 }, { ptr, i64 } %call)
%callN = call { ptr, i64 } @concat({ ptr, i64 } { ptr @str.136, 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.135, i64 4 }, %if.then.187 ], [ %callN, %if.else.188 ]
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.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.140, i64 3 }, { ptr, i64 } %call)
%callN = call { ptr, i64 } @concat({ ptr, i64 } { ptr @str.139, i64 6 }, { ptr, i64 } %callN)
br label %if.merge.192
if.merge.192: ; preds = %if.else.191, %if.then.190
%bp = phi { ptr, i64 } [ { ptr @str.138, i64 4 }, %if.then.190 ], [ %callN, %if.else.191 ]
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.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.143, i64 3 }, { ptr, i64 } %call)
%callN = call { ptr, i64 } @concat({ ptr, i64 } { ptr @str.142, i64 5 }, { ptr, i64 } %callN)
br label %if.merge.195
if.merge.195: ; preds = %if.else.194, %if.then.193
%bp = phi { ptr, i64 } [ { ptr @str.141, i64 4 }, %if.then.193 ], [ %callN, %if.else.194 ]
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.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.146, i64 3 }, { ptr, i64 } %call)
%callN = call { ptr, i64 } @concat({ ptr, i64 } { ptr @str.145, i64 7 }, { ptr, i64 } %callN)
br label %if.merge.198
if.merge.198: ; preds = %if.else.197, %if.then.196
%bp = phi { ptr, i64 } [ { ptr @str.144, i64 4 }, %if.then.196 ], [ %callN, %if.else.197 ]
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.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.149, i64 3 }, { ptr, i64 } %call)
%callN = call { ptr, i64 } @concat({ ptr, i64 } { ptr @str.148, i64 4 }, { ptr, i64 } %callN)
br label %if.merge.201
if.merge.201: ; preds = %if.else.200, %if.then.199
%bp = phi { ptr, i64 } [ { ptr @str.147, i64 4 }, %if.then.199 ], [ %callN, %if.else.200 ]
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.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.152, i64 3 }, { ptr, i64 } %call)
%callN = call { ptr, i64 } @concat({ ptr, i64 } { ptr @str.151, i64 6 }, { ptr, i64 } %callN)
br label %if.merge.204
if.merge.204: ; preds = %if.else.203, %if.then.202
%bp = phi { ptr, i64 } [ { ptr @str.150, i64 4 }, %if.then.202 ], [ %callN, %if.else.203 ]
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.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.155, i64 3 }, { ptr, i64 } %call)
%callN = call { ptr, i64 } @concat({ ptr, i64 } { ptr @str.154, i64 7 }, { ptr, i64 } %callN)
br label %if.merge.207
if.merge.207: ; preds = %if.else.206, %if.then.205
%bp = phi { ptr, i64 } [ { ptr @str.153, i64 4 }, %if.then.205 ], [ %callN, %if.else.206 ]
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.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.158, i64 3 }, { ptr, i64 } %call)
%callN = call { ptr, i64 } @concat({ ptr, i64 } { ptr @str.157, i64 3 }, { ptr, i64 } %callN)
br label %if.merge.210
if.merge.210: ; preds = %if.else.209, %if.then.208
%bp = phi { ptr, i64 } [ { ptr @str.156, i64 4 }, %if.then.208 ], [ %callN, %if.else.209 ]
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.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.161, i64 3 }, { ptr, i64 } %call)
%callN = call { ptr, i64 } @concat({ ptr, i64 } { ptr @str.160, i64 7 }, { ptr, i64 } %callN)
br label %if.merge.213
if.merge.213: ; preds = %if.else.212, %if.then.211
%bp = phi { ptr, i64 } [ { ptr @str.159, i64 4 }, %if.then.211 ], [ %callN, %if.else.212 ]
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.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.164, i64 3 }, { ptr, i64 } %call)
%callN = call { ptr, i64 } @concat({ ptr, i64 } { ptr @str.163, i64 7 }, { ptr, i64 } %callN)
br label %if.merge.216
if.merge.216: ; preds = %if.else.215, %if.then.214
%bp = phi { ptr, i64 } [ { ptr @str.162, i64 4 }, %if.then.214 ], [ %callN, %if.else.215 ]
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
}